

**OKI**

## **INSTRUCTION MANUAL**

---

# **MSM66201**

**CMOS SINGLE CHIP 8/16 BIT  
MICROCONTROLLER**

---



**FIRST EDITION**  
ISSUE DATE: SEP 1991

## **PREFACE**

This manual provides an overview of the MSM66201 and explains its instruction set for programming.

The MSM66201 contains on-chip I/O ports, A/D converters, serial ports, timers, PWM, and other powerful hardware. For information on the functions and control of this hardware, please refer to the *MSM66201 User's Manual*. The explanations presented in this manual assume that the reader understands the contents of the *MSM66201 User's Manual*.

Beyond remembering the hardware configuration of the microcontroller, the first problem encountered by a designer trying to create a program will be how to access the on-chip hardware and memory, and which instructions to use.

The MSM66201 places internal hardware and its control registers in a mapped data memory space. Therefore, control of the MSM66201's on-chip hardware can be considered equivalent to determining how to access its memory space. The fastest way to understand the MSM66201 instruction set is to understand how its memory space is addressed.

Chapter 1, "Overview," explains use and design considerations for the MSM66201's memory configuration and for addressing the hardware mapped in its memory space.

Chapter 2, "Addressing Modes," explains memory space addressing and its syntax, and provides examples.

Chapter 3, "Details of Instructions," provides a chart of the MSM66201 instructions broken down by function, and it gives detailed explanation of each instruction in alphabetical order. A list of byte counts and cycle counts is also provided.

## Chapter 1. Overview

|                                                             |            |
|-------------------------------------------------------------|------------|
| <b>1. Key Features of the MSM66201 Microcontroller.....</b> | <b>1-1</b> |
| <b>2. Memory Configuration .....</b>                        | <b>1-3</b> |
| 2.1 Program Memory Space.....                               | 1-3        |
| 2.1.1 Structure of Program Memory Space .....               | 1-3        |
| (1) Vector Table Space .....                                | 1-3        |
| (2) VCAL Table Space .....                                  | 1-5        |
| (3) Conventional Coding of Program Space.....               | 1-5        |
| 2.1.2 Accessing the Program Memory Space .....              | 1-7        |
| (1) Access by PC .....                                      | 1-7        |
| (2) Access by Instructions .....                            | 1-7        |
| 2.2 Data Memory Space.....                                  | 1-8        |
| 2.2.1 Structure of Data Memory Space .....                  | 1-8        |
| (1) Concept of Page .....                                   | 1-8        |
| (2) Configuration of Page 0 .....                           | 1-10       |
| (3) Local Registers .....                                   | 1-13       |
| 2.2.2 Accessing Data Memory Space .....                     | 1-15       |
| (1) Accessing the General Data Space .....                  | 1-15       |
| (2) Accessing the System Stack Space .....                  | 1-17       |
| 2.2.3 Word Boundary.....                                    | 1-17       |
| «Instructions that are Influenced by Word Boundary».....    | 1-20       |
| 2.2.4 Data Descriptor (DD) and Stack Flag (SF).....         | 1-21       |
| (1) Data Descriptor (DD) .....                              | 1-21       |
| 2.3 Concept of Segments .....                               | 1-25       |
| «Description of Absolute Segment» .....                     | 1-26       |
| «Description of Relocatable Segment» .....                  | 1-29       |
| «Partial Segment» .....                                     | 1-33       |

## Chapter 2. Addressing Modes

|                                                                            |            |
|----------------------------------------------------------------------------|------------|
| <b>1. RAM Addressing Modes .....</b>                                       | <b>2-1</b> |
| 1.1 Register Addressing .....                                              | 2-1        |
| (1) Accumulator Addressing.....                                            | 2-1        |
| (2) Pointing Register Addressing .....                                     | 2-1        |
| (3) Control Register Addressing .....                                      | 2-2        |
| (4) Local Register Addressing.....                                         | 2-2        |
| (5) System Stack Pointer Addressing .....                                  | 2-3        |
| 1.2 Page Addressing .....                                                  | 2-3        |
| (1) Current Page Addressing .....                                          | 2-3        |
| (2) Zero Page Addressing .....                                             | 2-4        |
| 1.3 Pointing Register Indirect Addressing .....                            | 2-5        |
| (1) Data Pointer Indirect Addressing.....                                  | 2-5        |
| (2) User Stack Pointer Indirect Addressing (with 8-bit Displacement) ..... | 2-5        |
| (3) Index Register Indirect Addressing (with 16-bit Displacement) .....    | 2-6        |
| 1.4 Immediate Addressing .....                                             | 2-7        |
| «Advice About RAM Addressing».....                                         | 2-7        |
| <b>2. ROM Addressing Modes .....</b>                                       | <b>2-8</b> |
| 2.1 Direct Addressing .....                                                | 2-8        |
| 2.2 Indirect Addressing .....                                              | 2-8        |
| (1) Single Indirect Addressing .....                                       | 2-8        |
| (2) Double Indirect Addressing .....                                       | 2-9        |

---

**MSM66201 Instruction Manual**  
**Table of Contents**

---

|                                                |             |
|------------------------------------------------|-------------|
| (3) Indirect Addressing with 16-bit base ..... | 2-10        |
| <b>3. Bit Addressing Modes .....</b>           | <b>2-12</b> |
| <b>4. Logical Bit Address Space.....</b>       | <b>2-13</b> |

**Chapter 3. Details of Instructions**

|                                               |              |
|-----------------------------------------------|--------------|
| <b>1. Classification of Instructions.....</b> | <b>3-1</b>   |
| <b>2. Instruction Set.....</b>                | <b>3-5</b>   |
| <b>3. Summary List of Instructions .....</b>  | <b>3-180</b> |

## **1. Key Features of the MSM66201 Microcontroller**

The MSM66201 is a single chip microcontroller (SCMC) specifically designed for efficient programming and high speed data processing.

SCMCs were originally developed to replace control devices for home equipment, particularly electrical and electronic appliances. The internal memory capacity of early SCMCs ranged from 2 to 4K bytes for ROM and from 128 to 256 bytes for RAM. Internal hardware was limited to ports, timers, counters and LCD drivers. The instruction sets available with these early SCMCs included some novel bit manipulations for control; however, the number of arithmetic instructions and addressing modes as well as the quality of these SCMCs were all inferior to what could be obtained with microprocessors.

With the recent development of DRAM and general memory based on large-scale IC technology, the internal memory capacity of SCMCs has increased tremendously, and the CPU processing speed of SCMCs has jumped from several microseconds to several hundred nanoseconds. Consequently the applications for SCMCs are expanding and gradually invading many areas previously occupied by microprocessors. SCMCs are now used for many devices which require high speed processing of large volume of data such as telephone switchboards, high-performance printers, and automobile engine control units.

Such applications for SCMCs have in turn created new functional requirements beyond the need for increased internal memory capacity. These functional requirements must be satisfied by the architecture of future SCMCs, and they are listed below.

1. Increased parallel processing capability
2. Added internal hardware to perform such functions as A/D and D/A conversions, improved communication control, and various display drivers
3. In addition to the hardware development requirements described in item 2, internal hardware readily applicable to the end products is needed
4. Compatibility with large data memory space
5. High speed program processing/low consumption of electrical power

The MSM66201 satisfies these requirements with the following architecture.

### **(1) Based on Concepts of Application Specific ICs (ASICs)**

Future SCMCs must be ASIC oriented as stated in item 3 above. To meet this requirement, the CPU core of the MSM66201 is designed to be independent of I/O (internal peripheral units). Oki Electric Industry Co. Ltd. intends to develop various I/O units which are readily integrated in the end products with the standard CPUs. The great advantages of developing such a family of I/O units are the flexibility of architecture permitted for the product design, and the reuse of the software developed for the standard CPU in all products. The MSM66201 is the vanguard of SCMCs which are developed based on such a concept.

### **(2) 64K Byte Program Memory Space**

The MSM66201 provides a program memory space of 64K bytes. Any address within the memory space is accessible directly or indirectly by CALL or JUMP instructions. The memory space can also store the program constants.

### **(3) Hierarchy of 64M Byte Data Memory Space**

The MSM66201 provides a data memory space of 64M bytes. The memory space consists of three levels, namely banks, pages, and local registers.

## **Chapter 1 Overview**

### **MSM66201 Key Features**

---

The memory space is divided into 256 pages, each holding 256 bytes. The MSM66201 addressing system is designed to place all of the data required for a single processing action on the same page to achieve quick and efficient addressing. To make the data processing within a page effective, each page is divided in 32 areas of 8 bytes, and local registers may be placed in any area.

**(4) Complete Bit Manipulation Instruction**

The MSM66201 permits individual manipulation of any bit in the data memory space. Also, it is possible to manipulate directly and indirectly any bit in a byte. Transfer between the carry flag(C) and a bit is also possible.

**(5) Ease of Array and Pointer Manipulation**

The MSM66201 provides 2 index registers of 16 bits and 8 sets of pointing register of 16 bits. These pointers make it possible to access any address of the data memory space. The contents of the registers are automatically saved when a program interrupt occurs and the context switch-over takes effect. Creating data arrays and manipulating pointers is easy on the MSM66201.

**(6) Organized Instructions**

In the MSM66201 design, the internal hardware and registers are allocated to the memory space, and numerous addressing modes to access data are available; therefore, it is possible to manage and control all resources of the MSM66201 with a few instructions. The transfer and arithmetic instructions are plain and clear, consequently program coding is easy, and programs produced are easy to understand.

**(7) Extremely Quick Switching of Program Context**

The MSM66201 design permits extremely quick switching of the program context when a program interrupt handler functions or a task switching is executed in a multitasking program.

**(8) Memory Mapped I/O**

In the MSM66201, the internal I/O units such as I/O ports and timers are allocated to the data memory space (memory mapped I/O). Consequently no specific input and output instructions are required; these instructions are replaced by the data addressing instructions. This scheme produces not only a simple instruction system but also a flexible design that makes adding and modifying of internal I/O hardware easy. The MSM66201 is really developed to meet the ASIC requirements of the future, and the memory mapped I/O design enhances the ASIC features of the MSM66201.

## 2. Memory Configuration

The memory space of the MSM66201 is divided into the program and data memory spaces which are described in subsections 2.1 and 2.2 respectively. In subsection 2.3, the concept of data segments that are allocated to the memory space for assembler operation is described.

[NOTE] The program memory space (or program space) is sometimes called ROM (Read Only Memory) space because ROM is usually its main constituent element. Likewise the data memory space (or data space) is sometimes called RAM (Random Access Memory) space because RAM is usually its main constituent element.

### 2.1 Program Memory Space

#### 2.1.1 Structure of the Program Memory Space

The program space of the MSM66201 accommodates 64K bytes (0000<sub>H</sub> to FFFF<sub>H</sub>) maximum; 40 bytes (0000<sub>H</sub> to 0027<sub>H</sub>) of which forms the vector table space composed of 20x2-byte segments. Another 16 bytes (0028<sub>H</sub> to 0037<sub>H</sub>) form the VCAL table space of 8x2-byte segments as shown in Figure 1-1.

##### (1) Vector Table Space

The vector table space saves the vector addresses when the reset instructions (reset input, BRK and WDT) are executed or interrupts are caused by the peripheral hardware. Each vector address is saved in 2 bytes (16 bits); the lower and upper bytes of the vector address are stored respectively in the lower and upper addresses of the RAM. The vector table is described by the assembler with pseudo instructions. (See the following examples)

| Examples of Assembler Coding for Vector Table |            |                         |
|-----------------------------------------------|------------|-------------------------|
| <pre>CSEG AT 0000H</pre>                      |            |                         |
|                                               |            |                         |
| DW                                            | START      | ----- 0000 <sub>H</sub> |
| DW                                            | BRK_RESET  | ----- 0002 <sub>H</sub> |
| DW                                            | WDT_RESET  | ----- 0004 <sub>H</sub> |
| DW                                            | NMI_ENTRY  | ----- 0006 <sub>H</sub> |
| DW                                            | INT0_ENTRY | ----- 0008 <sub>H</sub> |
|                                               |            | ⋮                       |
| DW                                            | INT1_ENTRY | ----- 0026 <sub>H</sub> |

Please note that at a reset or interrupt, the contents of the concerned vector table (vector addresses) are set in the PC; no jump instruction into the vector table space is specified. Also, it is mandatory to allocate addresses 0 through 1 to the vector addresses for reset input, but the remaining addresses (2 through 27<sub>H</sub>) need not be specified when no corresponding reset and interrupt instructions are executed, and the unused area may be used to enter programs.

## **Chapter 1 Overview**

### **Memory Configuration**

---

The allocation of the vector table is shown in Table 1-1.



**Figure 1-1. Structure of Program Memory Space**

**Table 1-1. Allocation of Vector Table**

| Address           | Corresponding reset process or interrupt             |
|-------------------|------------------------------------------------------|
| 0000 <sub>H</sub> | Reset by RESET input                                 |
| 0002 <sub>H</sub> | Reset by BRK instruction                             |
| 0004 <sub>H</sub> | Reset by WDT / Reset by operation code trap function |
| 0006 <sub>H</sub> | Interrupt by NMI pin input                           |
| 0008 <sub>H</sub> | Interrupt by INT0 pin input                          |
| 000A <sub>H</sub> | Interrupt by serial port readying for receiving      |
| 000C <sub>H</sub> | Interrupt by serial port readying for transmit       |
| 000E <sub>H</sub> | Interrupt by BRG for serial port receive             |
| 0010 <sub>H</sub> | Interrupt by timer 0 overflow                        |
| 0012 <sub>H</sub> | Interrupt by event occurrence of timer 0             |
| 0014 <sub>H</sub> | Interrupt by timer 1 overflow                        |
| 0016 <sub>H</sub> | Interrupt by event occurrence of timer 1             |
| 0018 <sub>H</sub> | Interrupt by timer 2 overflow                        |
| 001A <sub>H</sub> | Interrupt by event occurrence of timer 2             |
| 001C <sub>H</sub> | Interrupt by timer 3 overflow                        |
| 001E <sub>H</sub> | Interrupt by event occurrence of timer 3             |
| 0020 <sub>H</sub> | Interrupt by end of A/D conversion                   |
| 0022 <sub>H</sub> | Interrupt by PWM timer overflow                      |
| 0024 <sub>H</sub> | Interrupt by BRG for serial port transmit            |
| 0026 <sub>H</sub> | Interrupt by INT1 pin input                          |

- [NOTES]
1. The preceding allocation is applicable only for the MSM66201. The MSM66201 is designed as the basic unit of a family of microcontrollers (nx8/300 series) that is based on ASIC concepts, and the MSM66201 is marketed as a standard product. Therefore it is possible to install customer specific internal I/O units which are different from the standard MSM66201 as long as the CPU remains the same. For such cases, the allocation of the vector table may change. Also the number of interrupts may increase beyond the standard memory space (0000<sub>H</sub> to 0027<sub>H</sub>) capacity; the excess interrupt vector addresses must be allocated behind the VCAL table space(following 0038<sub>H</sub>).
  2. When an address of 16-bit length is stored in data memory, in a register, or is transferred, the lower byte of the data is stored in the lower address of the memory or register and the upper byte is stored in the upper address. This rule is implicitly applicable in the MSM66201 device unless it is stated otherwise.

#### (2) VCAL Table Space

The MSM66201 uses a vector call instruction (VCAL) which is one byte long. The addresses of the VCAL table (0028<sub>H</sub> through 0037<sub>H</sub>) are entered in the operand of the VCAL instruction. When the VCAL instruction is executed, the vector address of the VCAL table specified by the operand is set in the PC after the return address is saved in the system stack.

The VCAL table is entered by a DW pseudo instruction like the vector table. When VCAL instructions are not used, the VCAL table area can be used for entering programs.

#### (3) Conventional Coding of Program Space

As stated in the articles (1) and (2), the address area from 0000<sub>H</sub> to 0037<sub>H</sub> is allocated to the tables. Also, as stated in (1), the area excluding from 0000<sub>H</sub> to 0001<sub>H</sub> may be used for entering

## Chapter 1 Overview

### Memory Configuration

programs, however it is recommended that this be avoided. Enter programs in the addresses higher than 0038H, because later program changes may require the addition of instructions for interrupts and VCAL.

The following three examples are produced using these rules.

#### Conventional Coding of Program Space

##### MAIN SEGMENT CODE

```
CSEG AT 0000H
;
;
;
    *-----*
    • Vector Table •
    *-----*
;
DW START      ; Reset
DW BRK_RESET  ; Break instruction
;
;
DW INT1_ENTRY ; INT1 Interrupt
```

Coding Vector Table

```
;
    *-----*
    • VCAL Table •
    *-----*
;
VCAL0: DW      ERROR_PROCESS
VCAL1: DW      PORT_INIT_PROCESS
VCAL2: DW      RAM_INIT_PROCESS
;
DS     10      ; Reserved for future
```

Coding VCAL Table

```
;
    *-----*
    • Main Routine •
    *-----*
;
RSEG MAIN
;
START:
;
;
;
;
END
```

Program Body

### **2.1.2 Accessing Program Memory Space**

Accessing program memory space is performed in two ways: by PC, or by instruction.

#### **(1) Access by PC**

Accessing the program memory by using the PC is usually performed when a program is being executed. The PC always contains the address of the memory where the next instruction to be executed is stored. The contents of the address indicated by the PC is the instruction. Following the execution of an instruction, the contents of PC is automatically increased an amount equal to the number of bytes of the executed instruction by hardware. When a reset input is given from an external pin or an interrupt occurs, the PC contents is replaced by the value stored in the vector table. These operations are done by the hardware; the programmer need not be concerned with them. However, the PC count can be changed by the programmer if necessary. For instance, it is possible to replace the PC contents with the value stored in the VCAL table by executing a VCAL instruction. Also, the PC contents can be replaced by the addresses specified by the operands of the following instructions upon their executions.

#### **Instructions that Can Replace PC Contents**

|                                      |
|--------------------------------------|
| SJ, J, JC, JBS, JBR, JRNZ, SCAL, CAL |
|--------------------------------------|

Refer to Chapter 3 for details of these instructions.

#### **(2) Access by Instruction**

The MSM66201 provides instructions that allow accessing the program memory space.

#### **Instructions to Access Program Space**

|                      |
|----------------------|
| LS, LCB, CMPC, CMPCB |
|----------------------|

With the use of these instructions, it is possible to transfer the contents of the program memory to the accumulator or compare the program memory to the accumulator.

The following addressing modes are available for specifying the locations of memory space when these instructions are used.

- Direct Addressing: specify the address in the space of 64K bytes directly using immediate addressing.
- Simple Indirect Addressing: specify the address indirectly according to the contents of data memory such as a local register (er0 to er3), pointing register (DP, X1, X2, USP), or system stack pointer (SSP).
- Double Indirect Addressing: specify the address indirectly according to the content of the data memory which is addressed indirectly by the contents of a pointing register (DP, X1, X2, USP).
- Indirect addressing with a 16-bit base: specify the address by offsetting from the base address in the 64K byte memory space; the amount of offset is specified by the contents of a pointing register (DP, X1, X2, USP) or the contents of another data memory.

For the details of the instructions and addressing modes, refer to Chapter 3 and Section 2 of Chapter 2 respectively.

## **2.2 Data Memory Space**

### **2.2.1 Structure of Data Memory**

#### **(1) Concept of Page**

This article explains the concept of *pages*.

Generally, the data memory space used for a program module or unit process is not so large. In other words, the upper bits of the addresses of the data in the space which are addressed during a unit process hardly change. So, if the data memory space is divided into blocks of an appropriate size for a unit process, and all of the data involved in a program is stored in one block, addressing the data for the process may be achieved by simply offsetting each data from the base address of the block. Such a configuration of data memory space will shorten the access time as well as the machine codes.

Using such concepts, the architecture of the MSM66201 divides each data memory bank into blocks of 256 bytes. This block is called a *page*. Thus, a bank of 64K bytes consists of 256 pages of 256 bytes.

In Figure 1-2, the configuration of the data memory is shown.



**Figure 1-2. Page Configuration of Data Memory**

As shown in Figure 1-2, the pages are numbered progressively, starting at the lowest address, as Page 0, Page 1, Page 2, up to Page 255. The page numbers used are specified by bits 12 through 5 of LRB, and the page thus specified is called the current page.

When only the on-chip data space of the MSM66201 is used, the corresponding addresses used are 0000<sub>H</sub> through 027F<sub>H</sub>, and the only corresponding pages used are Pages 0, 1, and 2.

## Chapter 1 Overview

### Memory Configuration

Furthermore, only 128 bytes are useable in Page 2. The configuration of the data memory space used for on-chip space only is shown in Figure 1-3.



Figure 1-3. Page Configuration of Data Memory (On-Chip Space)

Addressing by offsetting within the current page is called current page addressing; its details are given in Chapter 2. Current page addressing is allowed with most instructions in the MSM66201 instruction set, and our chip designers made their best effort to realize very fast memory access with current page addressing. This fits the concept that the data space for each module should be located within one page, and in that situation current page addressing would be used most frequently.

#### (2) Configuration of Page 0

All of the pages (256 total) thus defined are basically similar except for Page 0. Initially, the special function register (SFR) and the pointing register (PR) are allocated to Page 0. (See Figure 1-4)

Secondly, to access the contents of Page 0, zero page addressing, which does not depend on LRB, is available. This is in addition to the familiar current page addressing, which is LRB dependent.

These items are further explained in the following paragraphs.

SFR

The internal hardware of the MSM66201 will be accessed at every stage of a program, therefore it is desirable to allocate the hardware to page 0 in a memory-mapped I/O configuration to increase the program efficiency. The configuration of memory-mapped I/O requires fewer instructions to control the hardware units compared to the I/O-mapped I/O configuration, and it also provides the flexibility to modify the internal hardware while the CPU stays unaltered (one of the beneficial features of ASICs).



Figure 1-4. Configuration of Page 0

Considering the foregoing factors, the internal hardware of the MSM66201 such as timers, counters, A/D converters, and so on, and the registers which control the memory-mapped I/O hardware, are allocated to the addresses from 0000H to 007FH of Page 0. The general term for these hardware units is "Special Function Register" or SFR for short; the latter abbreviation is used in this book.

SFR includes, in addition to timers, A/D converters and so on, the general purpose registers which are listed in the following table; these are used for arithmetic and memory management.

General Purpose Registers Included in SFR

|     |                      |
|-----|----------------------|
| SSP | System Stack Pointer |
| LRB | Local Register Base  |
| PSW | Program Status Word  |
| ACC | Accumulator          |

## Chapter 1 Overview

### Memory Configuration

#### Pointing Register (PR)

The pointing registers are allocated to addresses  $0080_H$  through  $00BF_H$  of Page 0. They are 16-bit registers and function as pointers when addressing the program or data memory.

The pointing register is composed of the following four registers which form a set.

- X1 ..... Index Register 1
- X2 ..... Index Register 2
- DP ..... Data Pointer
- USP ..... User Stack Pointer

Eight pointing registers or eight sets of the foregoing units are allocated to Page 0 and they are named PR0, PR1, PR2 ... PR7. (See Figure 1-5).

For the details of pointing register's function, refer to Section 3 of this chapter and the description of addressing modes in Chapter 3.

As shown in Figure 1-5, selecting the register out of eight units is performed by the lower 3 bits of PSW whose group name is System Control Base (SCB).



Figure 1-5. Pointing Registers

#### Zero Page Addressing

As described in (1), the data memory space of the MSM66201 is divided into pages, each of which contains 256 bytes, and the work area of a program module is basically contained within a page. SFR and the pointing registers are contained within Page 0; however, these units are expected to be referred to throughout various stages of program execution, resulting in a changing value of LRB. Such a situation degrades program efficiency. To avoid this, zero page addressing which does not depend on LRB is provided for the data within Page 0. This addressing mode is in addition to universal current page

addressing. The practical application of zero page addressing is described in the *Addressing Modes* in Chapter 2.

As shown in Figure 1-6, addresses  $0000_H$  through  $00FF_H$  of Page 0 are RAM. When these addresses are used for space to store global variables like the external variables of a C compiler, zero page addressing can be employed to enhance program efficiency.

**(3) Local Registers**

As described in the articles (1) through (2), the data memory space is stratified in 256 pages. The upper eleven bits, from 12 to 5, of LRB are used to identify the banks and pages, and the remaining lower five bits of the 13-bit register are used to set the base for local registers.

As described in (1), the data memory space is divided into 256-byte pages. Each page provides register space in 8-byte units. The architecture of the MSM66201 permits the allocation of registers to any convenient addresses within the current page rather than specific fixed addresses. Such registers are called *local registers* and their base addresses are specified by the lowest five bits of LRB. (See Figure 1-6)

The local registers are used to store the data when transfer or arithmetic instructions are executed. The unit of the register can be either byte or word. For byte unit operations, each register forms 8 bits x 8 register sets, and the data is entered starting at the lowest, as r0, r1, r2 . . . r7. The corresponding configuration for word operations is 16 bits x 4 register sets with data entry starting at the lowest, as er0, er1, er2, er3.

**Chapter 1 Overview**  
**Memory Configuration**

---



**Figure 1-6. Local Register Space**

### 2.2.2 Accessing Data Memory Space

There are three kinds of data memory accessing:

- (1) Addressing the general data space
- (2) Addressing the system stack space

Detailed descriptions follow.

#### (1) Accessing the General Data Space

The general data space is all data space other than the spaces which are allocated to the system and user stacks. (Note that the general space includes SFRs, which include ACC, PSW, LRB, etc.)

All addressing of the general data space is performed by the instructions. More than half of the instructions used by the MSM66201 are for addressing the general data space. They are listed below. The details of these instructions are described in Chapter 3, *Details of Instructions*.

**Instructions for Addressing the General Data Space**

|                                     |                                 |                                                         |                           |                                   |
|-------------------------------------|---------------------------------|---------------------------------------------------------|---------------------------|-----------------------------------|
| • Data transfer instructions        | (Load)<br>(Move)<br>(Exchange)  | L, LB<br>MOV, MOVB<br>XCHG, XCHGB, XNBL                 | (Store)<br>(Clear)        | ST, STB<br>CLR, CLRB              |
| • Rotate/Shift instructions         | (Rotate)<br>(Shift)             | ROL, ROLB, ROR, RORB<br>SLL, SLLB, SRL, SRIB, SRA, SRAB |                           |                                   |
| • Increment/Decrement instructions  |                                 | INC, INCB, DEC, DECB                                    |                           |                                   |
| • Arithmetic operation instructions | (Multiply)<br>(Add)             | MUL, MULB<br>ADD, ADDB, ADC, ADCB                       | (Divide)<br>(Subtract)    | DIV, DIVB<br>SUB, SUBB, SBC, SBCB |
| • Logic operation instructions      | (Logical AND)<br>(Exclusive OR) | AND, ANDB<br>XOR, XORB                                  |                           | (Logical OR) OR, ORB              |
| • Compare instructions              | CMP, CMPB                       |                                                         |                           |                                   |
| • Bit manipulation instructions     | (Set bit)<br>(Test bit)         | SB, SBR<br>TBR                                          | (Reset bit)<br>(Move bit) | RB, RBR<br>MBR                    |

Almost all of the addressing instructions may operate in word length (16-bit length) or byte length (8-bit length) modes. Each instruction accommodates these operations with two distinctive codes like MOV and MOVB, or ADD and ADDB. In Chapter 3, the details of the instructions are given.

In some instructions primarily for the accumulator, the same machine codes, depending on the flag called *data descriptor* (DD), perform both byte and word operations. This flag is allocated in PSW, and constitute the most notable features of the MSM66201 control system with their ability to provide multiple instructions. The functions of these two flags are detailed in 2.2.4.

This section provides additional information about addressing modes for the general data memory. Although the previously described instructions perform the addressing, the programmer must enter the mnemonic codes (MOV, ADD, CMP, etc.) in the assembler source program. These mnemonic codes define the operations, and the objects of the operations are the addresses of the data space specified by the operands following the mnemonic codes.

## **Chapter 1 Overview**

### **Memory Configuration**

---

For example, transfer instruction MOV is entered as

MOV operand\_1, operand\_2

This instruction orders the transfer of the contents of operand\_2 into operand\_1 using word units. Operand\_1 and operand\_2 specify the addresses that are the objects of the operation. There are various ways to specify or note the addresses of the objects. Addressing notation defines how to access the data space, or in other words, defines the addressing mode.

Two of the addressing modes for the general data space have been described in 2.2.1. They are listed below, and further detailed in Chapter 2.

#### **1. Current page addressing**

#### **2. Zero page addressing**

In zero page addressing, the address or symbol which is the object of an operation is entered as it is. In current page addressing, a descriptive word off for addressing is placed preceding the address or symbol which is the object. For example, to transfer in word length units the data space which is labelled WORK\_1 in the current page to the address A0H of Page 0, the following code is used.

MOV 0A0H, off WORK\_1

Current page and zero page addressing modes are the basic modes; however, the following additional addressing modes are available to enhance program efficiency as listed below.

#### **3. Register addressing**

#### **4. Pointing register indirect addressing**

The register addressing is specifically used to access the general purpose registers within Page 0. The registers include SSP, LRB, PSW, ACC, X1, X2, DP and USP and the local registers in the current page (r0, r1, r2, r3, r4, r5, r6, r7 or er0, er1, er2, er3). The name of the specific register is entered in the statement except for ACC which changes to A. For example, the following entry will transfer er0 to ACC.

MOV A, er0

Pointing register indirect addressing is used for programs that require accessing arrays allocated in the data space with the use of pointers, or for accessing data that can be stored indirectly with pointers to improve overall program efficiency. There are three variations to this addressing mode.

The first variation is indirect addressing with a base using X1 and X2. Array-type data are conveniently handled with this access scheme in which the amount of offset from the base is processed by X1 and X2. For example, the following entry will transfer the 10th array element, SEG\_DATA[10], in the array SEG\_DATA to the accumulator after X1 is set to 10.

MOV A, SEG\_DATA[X1]

The second variation is indirect addressing by the data pointer (DP) that is used as a pointer for general indirect addressing. For example, the following entry will move the data of a byte length pointed to by DP to local register r0.

**MOV B r0, [DP]**

The third variation is indirect addressing by USP. The effective address is generated by USP and the signed ( $\pm$ ) displacement.

**MOV B A, +2[USP]**

The access modes for the general data memory space have been outlined in the preceding sections; however, the functional details of the instructions and the thorough descriptions of the addressing modes are not given. Refer to Chapter III for functional details of each instruction. Refer to Chapter II for details on addressing.

There is one more addressing mode for the general data space which is termed *bit addressing*. Bit addressing, as well as the bit segment, will be described in 2.3, "Concept of Segments".

## (2) Accessing the System Stack Space

The system stack is the stack space that is indirectly accessed by system stack pointer (SSP). Accessing the system stack space is performed in the following cases.

1. SCAL, CAL and VCAL instructions are executed
2. Interrupts occur
3. PUSH S instruction is executed
4. RT and RTI instructions are executed
5. POPS instruction is executed

The system stack space is generally called *stack space*, and it is used to save the return address when call instructions are executed (case 1). It is also used to save the return address and the contents of ACC, LRB and PSW when interrupts occur (case 2). The system stack space can be used to stack PR, ACC and LRB directly using the PUSH S instruction (case 3). The RT instruction returns the return address to PC which is saved in the system stack space by CALL instructions (case 4). RTI instruction is used to return from interrupts and to return PSW, LRB, ACC and the return address from the system stack. The POPS instruction is used to pop the data in the system stack which has been put in by PUSH S instruction (case 5).

### 2.2.3 Word Boundary

In 2.2.2, three categories of accessing the data space are established:

1. Accessing the general data space
2. Accessing the system stack

In category 1, it has been said that accessing the general data space can be entered in word unit or in byte unit. When the word unit is used, the existence of the word boundary must be observed.

The word boundary is the borderline between word units, and it follows behind every odd-numbered address. As shown in Figure 1-7, there is no word boundary between addresses 0 and 1, hence a word that consists of addresses 0 and 1 is permissible. On the other hand, there is a word boundary behind address 3 because it is an odd-numbered address. Therefore, a word that consists of addresses 3 and 4 crosses the word boundary, and such a word is not usable for the accessing operation. In short, each word must start at an even-numbered address.

## **Chapter 1 Overview**

### **Memory Configuration**

---

Using the transfer instruction, MOV as an example, the operation of the CPU core is explained. When the contents of addresses in the data memory space are transferred to the accumulator by zero page addressing, the following entry will transfer the contents of the addresses C0H and C1H to the accumulator.

```
MOV A, 0C0H
```

The corresponding machine code is given as:

```
B5 C0 99
```

The C0 in the second byte corresponds to the address of the second operand. When these codes are executed by CPU, the contents of the two bytes which starts at address C0H will be transferred.

If the C0H of the example address is replaced with C1H, the entry is changed as shown.

```
MOV A, 0C1H
```

As mentioned previously, the words used in the access operation must start at an even-numbered address and be 2 bytes wide. However the 0C1H of the last entry is an odd-numbered address which creates a logical inconsistency, and consequently the assembler issues a warning. The assembler, however proceeds to change the address code as shown.

```
B5 C1 99
```

When the CPU executes these codes, the process is identical to the original one where the two bytes of data in addresses 0C0H and 0C1H are transferred to the accumulator. Thus the combination of 0C1H and 0C2H is ineffective, because the CPU forces the LSB (lowest bit) of the effective address to be 0 in the accessing process.



**Figure 1-7. Word Boundary**

## **Chapter 1 Overview**

### **Memory Configuration**

---



**Figure 1-8. Address Generation Process in Accessing Word Long Data Space**

#### ***Instructions that are Influenced by Word Boundary***

The instructions that are influenced by word boundaries are specified here. Word boundaries exists for almost all the instructions that access the general data space in word length units, and for all instructions used to access the system stack space. These instructions are listed in Table 1-3-1 and Table 1-3-2.

**Table 1-3-1. Instructions Influenced by Word Boundary**

|                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"> <li>• Data transfer instructions</li> <li>• Rotate/Shift instructions</li> <li>• Increment/Decrement instructions</li> <li>• Arithmetic operation instructions</li> <li>• Logic operation instructions</li> <li>• Compare instructions</li> </ul> | <ul style="list-style-type: none"> <li>L, ST, MOV, CLR, XCHG</li> <li>ROL, ROR, SLL, SRL, SRA</li> <li>INC, DEC</li> <li>ADD, ADC, SUB, SBC</li> <li>AND, OR, XOR</li> <li>CMP</li> </ul> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Table 1-3-2. Instructions Influenced by Word Boundary**

|                                                                                                                                                                                          |                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"> <li>• Call instructions</li> <li>• Return instructions</li> <li>• Push/Pop for system stack</li> <li>• Save into system stack at interrupt</li> </ul> | <ul style="list-style-type: none"> <li>SCAL, CAL, VCAL</li> <li>RT, RTI</li> <li>PUSHS, POPS</li> </ul> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|

The instructions unaffected by the word boundary are the instructions for accessing the user stack (PUSHU, POPU), and ROM addressing.

Thus, it is possible to push the data in the user stack without regard to their order; the data may be in byte or word length. Also, it is possible to refer to the ROM table starting at an odd-numbered address.

When a programmer codes a source program, the addresses referred to are seldom entered in numbers such as shown below:

MOV A, 0C0H

The addresses displayed in the operands are usually symbols which are defined in the data segment as labels or defined by DATA pseudo instructions. The data segment is the terminology used for assembler, and its concept is described in detail in 2.3. For the time being, it may be considered to be synonymous to the data memory space.

When the data space of a word unit is entered in a program, the data segments become meaningful. The data segments that contain the work space accessed by word-unit instructions must meet the requirement that the starting bytes (addresses) be even-numbered. In other words, labels for data segments used for the operand of an access instruction that uses word units must be assigned to even-numbered addresses.

When an odd-numbered address is entered for the operand of an access instruction that operates with words in the general data space, the assembler issues a warning message for errors only when the operand is evaluated as an absolute value.

When the operand is evaluated as a relocatable value, the symbol for the operand has the attribute of a relocatable data segment, and the real value of the relocatable value or symbol can not be known until the memory allocation is completed by the linker. This means that the assembler itself is unable to check the value. The currently available linker (RL66K) lacks the capability to perform such a checking function. (Linker improvement is planned.)

The starting byte of the data segment that is accessed by the instructions which operate on words must be able to instruct the assembler to allocate an even-numbered address. Therefore, the relocatable assembler (RAS66K) interprets the pseudo instruction segment to define segments with the added requirements for word attributes (no crossing of word boundaries). The segment with word attributes is assigned so that the starting address is always an even number.

This checking of word boundaries is performed only for cases in which the addressing entry in the operand indicates directly the accessing object as is done in page addressing. Addressing the general data space can also be done by other methods such as indirect addressing by pointing register, where the operand is entered with an indirect address. For such a case, the assembler is unable to check the word boundary because the assembler needs to know the contents of the register used for indirect addressing prior to checking the word boundary. For the assembler to know the contents of a register it is necessary to check the entire program flow, and this is far beyond the assembler's function. Therefore, managing the word boundary in indirect addressing is entirely the responsibility of the programmer.

#### **2.2.4 Data Descriptor (DD)**

MSM66201 provides a special flag called data descriptor (DD)

DD is associated with manipulation and transfer instructions for the accumulator of the MSM66201. DD affects the length of data accessed.

DD flag is described in the following articles.

##### **(i) DD allocation**

DD is allocated to bit 12 of the program status word (PSW).

## Chapter 1 Overview

### Memory Configuration



#### (ii) Function of DD

Prior to the description of the function of DD, the mnemonic used for the MSM66201 will be explained. The instructions for the MSM66201 are generally classified in two groups: the instructions that operate on almost all of the resources in word length units, and the remaining instructions that operate in byte units. The mnemonic expressions for the latter group of instructions are distinguished from the former with suffix B as shown in the following examples.

Word long MOVE instruction : MOV  
Byte long MOVE instruction : MOVB  
Word long ADD instruction : ADD  
Byte long ADD instruction : ADDB  
Word long logical AND : AND  
Byte long logical AND : ANDB

The corresponding machine codes for the word based and byte based instructions are generally different. The exception to this is the instructions which operate on the accumulator where the same machine code is used for both instructions of word and byte unit in conjunction with the use of DD. With DD=1, the instructions operate in word length, and with DD=0, they operate in byte length. Such instructions influenced by DD are listed in (iii).

#### (iii) Instructions Influenced by DD

|       |         |                                                    |
|-------|---------|----------------------------------------------------|
| ST    | A , obj | store in accumulator instruction                   |
| STB   | A , obj |                                                    |
| SWAP  |         | swap instruction for accumulator                   |
| SWAPB |         |                                                    |
| ROL   | A       | left rotation instruction for accumulator          |
| ROLB  | A       |                                                    |
| ROR   | A       | right rotation instruction for accumulator         |
| RORB  | A       |                                                    |
| SRA   | A       | right arithmetic shift instruction for accumulator |
| SRAB  | A       |                                                    |
| SLL   | A       | left logical shift instruction for accumulator     |
| SLLB  | A       |                                                    |
| SRL   | A       | right logical shift instruction for accumulator    |
| SRLB  | A       |                                                    |

## Chapter 1 Overview Memory Configuration

The term *obj* above represents the addressing entry (like r0, er0, [DP], 100H and off 0C0H) which is legally used as the operand of the instruction. Note that all instructions are for operations that use the accumulator.

The machine code for each pair of the instructions listed above is the same. Basically, for an instruction, the mnemonic and the machine code form a one to one correspondence. The assembler of the MSM66201, however, allows two mnemonic terms for a machine code.

For example, the machine code 88 causes the contents of the accumulator to be stored in local register 0. With DD=1, the instruction operates in word units; the contents of the accumulator are extended to 16 bits and transferred to the local register er0. With DD=0, the operation is in byte units, and the lower 8 bits (A<sub>L</sub>) are transferred to the local register r0. The mnemonic statements for these instructions follow.

```
ST A, er0      word length operation  
STB A, r0       byte length operation
```

Providing two mnemonic terms for one machine code has two advantages. The first advantage is that the programmer can transmit his intention to the assembler: "the operation should be in word or byte length." The second advantage is that when the programmer or a third person reviews the source program, the unit of the operation is easy to see.

Even if the assembler understands the programmer's intention, the assembler must have some capability to verify the unit of operation. For instance, the programmer intends to use byte units in the store instruction and enters in the source program as shown. However, if DD=1 at the time of

```
STB A, r0
```

program execution, the CPU will execute the instruction in word unit contrary to the programmer's intention. It is desirable for the assembler to provide some security means to verify the consistency between the programmer's intention and the DD value. However, the assembler cannot obtain the DD value because DD is specified by the program as explained later in detail.

As a supplementary checking means, the assembler provides the USING DATA pseudo instruction by which the programmer indicates to the assembler the value of DD to be used. To implement this process, the programmer enters

"USING DATA WORD"

In the source program which is equivalent to the message "Following this statement, DD=1 in this program" by the programmer. Similarly, the entry of

"USING DATA BYTE"

is equal to the message "Following this statement, DD=0 in this program". When DD is given by the USING DATA instruction, the assembler verifies the DD dependent instructions for consistency between the data unit of the instruction and DD; an error warning is issued if inconsistencies are found.

If no such verification of DD consistency is required, the statement "USING DATA ANY" is entered in the program. The USING DATA statement provides some degree of verification of consistency regarding the data length. However, it does not guarantee that the program is executed with the DD value specified by the USING DATA pseudo instruction. Please note that no error messages from the assembler does not guarantee consistency. Final responsibility rests with the programmer.

### *(iv) Changing the DD's value*

The DD's value can be reentered in three ways. Initially, the DD's value is reset directly by PSW access instructions when they are executed. Alternatively, DD is reentered automatically by the specific instructions that influence DD. DD can also be initialized by reset processing.

#### 1. Directly Accessing PSW

Since DD is allocated to bit 12 of the PSW, it can be changed directly by PSW access instructions, the following are some of the practical examples.

## Chapter 1 Overview

### Memory Configuration

ANDB PSWH, 11101111B ..... DD is reset, remaining bits unaffected  
ORB PSWH, 00010000B ..... DD is set, remaining bits unaffected  
XORB PSWH, 00010000B ..... DD is inverted, remaining bits unaffected  
SB PSWH. 4 (or SB DD) .... DD is set  
RB PSWH. 4 (or RB DD) ... DD is reset

#### 2. Specific Instructions Which Affect DD

When the following instructions are executed, DD is set automatically.

##### Commands that Set DD

|       |        |                                                                    |
|-------|--------|--------------------------------------------------------------------|
| L     | A, obj | load instruction of word length for accumulator                    |
| MOV   | A, obj | move instruction of word length for accumulator                    |
| CLR   | A      | clear instruction of word length for accumulator                   |
| POPS  | A      | pop (from system stack) instruction of word length for accumulator |
| EXTND | A      | extend code instruction for accumulator                            |

When the following instructions are executed, DD is reset automatically.

##### Commands that Reset DD

|      |        |                                                  |
|------|--------|--------------------------------------------------|
| LB   | A, obj | load instruction of byte length for accumulator  |
| MOVB | A, obj | move instruction of byte length for accumulator  |
| CLRB | A      | clear instruction of byte length for accumulator |

As shown in the above lists, the instructions that affect DD all transport the data from somewhere to the accumulator except for EXTND. When the concerned data is word long, DD is set, and DD is reset when the data is byte long. The instructions that are influenced by DD have been described in (iii). Each instruction in the group somehow operates on the accumulator. To operate on the accumulator, it is necessary to transfer the data from some place to the accumulator prior to the operation. For data which is transferred in word length, the accumulator will operate in word length. Similarly for data which is transferred in byte lengths, the accumulator will also operate in byte lengths. Thus, the matching of DD and the unit of the data is maintained.

#### 3. Initialization by Reset Processing

DD is initialized or set to 0 by the reset processing. The reset processing is executed for the following

1. A proper reset pulse is applied to the RESET pin.
2. A BRK instruction is executed.
3. Overflow exists in WDT (watch dog timer).

*«Caution: Setting DD at Program Interrupts»*

The interrupt procedure does not set or reset DD. DD is unrelated to the processes occurring following an interrupt, hence the value of DD cannot be predicted. When the interrupt procedure includes instructions that are affected by DD, it becomes necessary to initialize the flag. But the contents of the flag (namely

PSW) need not be saved, because they are saved automatically at the time of interrupt and returned by RTI (return from interrupt) instruction.

### 2.3 Concept of Segments

The concept of segments is used for managing the data of the assembler and the linker. As mentioned previously, the MSM66201 provides two memory spaces, the program and data memory spaces. When the programmer codes the assembler source program, he must tell the assembler in which memory space the entry is allocated. Then, the assembler employs segments that correspond to the physical memory space. Segments may be considered as logical spaces. The code segment of the assembler corresponds to the program space, while the data and bit segments correspond to the data space. For example, the program statement "Now, the following entry is to be saved in the program memory" becomes the assembler statement "Now the following entry is to be saved in the code segment". Thus the code segment is almost synonymous to the program memory.

The situation for the data memory is slightly different. The data memory is usually accessed using word or byte units, and occasionally a bit unit is used such as for setting flags. Such flag may be identified as "n<sup>th</sup> bit of address q" or "bit address n" which is more efficient in managing data (in the view of some programmers).

In the bit segment, bit 0 of byte 0 in the data memory is simply called the bit 0 address and the following bits are numerically sequenced in bit units as shown in Figure 1-9.

In the data segment, the data space is addressed in byte units, so the bit segment may seem to be created only to define the flags in an extreme sense.

The absolute segment is used for the entry of the data space of fixed address such as the vector table and VCAL table; it is also used when a certain data space is allocated to specific addresses for program convenience. The relocatable segment is used for the entry of the codes and the space that do not require specific addresses. The use of relocatable segment is recommended for programs in which many programmers are involved simultaneously, or for programs intended to be a submodule of a future program.

|              | Byte location |       |       |       |       |       |       |       |
|--------------|---------------|-------|-------|-------|-------|-------|-------|-------|
| D            | 7             | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| A            | F             | E     | D     | C     | B     | A     | 9     | 8     |
| T            | 17            | 16    | 15    | 14    | 13    | 12    | 11    | 10    |
| A            | 1F            | 1E    | 1D    | 1C    | 1B    | 1A    | 19    | 18    |
|              | 27            | 26    | 25    | 24    | 23    | 22    | 21    | 20    |
| M            |               |       |       |       |       |       |       |       |
| E            |               |       |       |       |       |       |       |       |
| M            |               |       |       |       |       |       |       |       |
| O            |               |       |       |       |       |       |       |       |
| R            | 7FFF7         | 7FFF6 | 7FFF5 | 7FFF4 | 7FFF3 | 7FFF2 | 7FFF1 | 7FFF0 |
| Y            | 7FFF          | 7FFE  | 7FFFD | 7FFFC | 7FFFB | 7FFFA | 7FFF9 | 7FFF8 |
| Bit location | 7             | 6     | 5     | 4     | 3     | 2     | 1     | 0     |

Figure 1-9. Bit Addresses

## Chapter 1 Overview Memory Configuration



Figure 1-10 Segment Classification

The concept and outline of segments have been described so far. The following section describes the entry of segments to a real source program.

### -Description of Absolute Segments-

For the assembler, three pseudo instructions are available to specify the segment type. Prior to the segment entry, these pseudo instructions: (CSEG, DSEG, and BSEG) are entered to declare the segment type.

|      |                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------|
| CSEG | This pseudo instruction declares that the following entries are to be located in the absolute code segment. |
| DSEG | This pseudo instruction declares that the following entries are to be located in the absolute data segment. |
| BSEG | This pseudo instruction declares that the following entries are to be located in the absolute bit segment   |

{ CSEG  
DSEG  
BSEG } [AT starting address]

The absolute code segment is used to enter the vector table, the VCAL table, and the ROM table, which is accessed by ROM reference instructions. The real statements entered will be labels, pseudo instructions which specify the data of word length (DW) and the data of byte length (DB), and the storage defining pseudo instruction (DS).

Refer to 2.1.1 for actual entry of statements.

When the relocatable assembler is used, the program main body (the instruction mnemonics of the MSM66201) is almost always entered in the relocatable code segment.

The actual entry of absolute data segment is explained here. The absolute data segment is entered to assign the data space to a specific addresses—for example, to assign the data space for global use to Page 0, or to allocate the stack space to certain fixed addresses. The entry of the absolute data segment is usually performed by the label and storage defining pseudo instruction (DS).

In Figure 1-11, the example entry assigns data of word length to WK\_0, WK\_1, WK\_2, WK\_3, and data of byte length to BUF\_0, BUF\_1, BUF\_2, BUF\_3 starting at the address 00C0H. When only the label values of the preceding example are desired to be defined, the DATA pseudo instruction may be used. The corresponding entry is shown in Figure 1-12. The latter entry differs from the former entry in that data space allocation is not possible for the latter. When the relocatable assembler is used with the latter entry, another relocatable segment might be allocated to the space behind 00C0H. This may be a concern.

while no such concern exists for the absolute assembler. DATA pseudo instruction is used for suballocation of the general data space or renaming of the label. An example of suballocation is shown in Figure 1-13. By placing the entry in Figure 1-13 after the entry in Figure 1-11, a data space of word length is suballocated to the low and high byte spaces.

```
DSEG    AT      00C0H
;
WK_0:  DS      2      ; Space for word long data
WK_1:  DS      2
WK_2:  DS      2
WK_3:  DS      2
;
BUF_0: DS      1      ; Space for byte long data
BUF_1: DS      1
BUF_2: DS      1
BUF_3: DS      1
;
```

**Figure 1-11. Absolute Data Segment**

```
WK_0:  DATA    00C0H
WK_1:  DATA    WK_0+2
WK_2:  DATA    WK_0+4
WK_3:  DATA    WK_0+6
;
BUF_0: DATA    0C08H
BUF_1: DATA    BUF_0+1
BUF_2: DATA    BUF_0+2
BUF_3: DATA    BUF_0+3
;
```

**Figure 1-12. Specifying by DATA Pseudo Instruction**

```
WK_0L  DATA    WK_0  ; Low byte of WK_0
WK_0H  DATA    WK_0+1 ; High byte of WK_0
WK_1L  DATA    WK_1  ; Low byte of WK_1
WK_1H  DATA    WK_1+1 ; High byte of WK_1
WK_2L  DATA    WK_2  ; Low byte of WK_2
WK_2H  DATA    WK_2+1 ; High byte of WK_2
WK_3L  DATA    WK_3  ; Low byte of WK_3
WK_3H  DATA    WK_3+1 ; High byte of WK_4
;
```

**Figure 1-13. Specifying by DATA Pseudo Instruction**

## Chapter 1 Overview

### Memory Configuration

As the last item described in this discussion on absolute segments, an example of a real program entry of bit segments is introduced.

The entry of a bit segment is performed by the label and bit long space defining pseudo instruction (DBIT), just as the entry of the data segment is done. The exact address arrangement of the bit segment is as shown in Figure 1-9. It is rather unwieldy to enter the address behind the AT portion of the BSEG pseudo instruction or the operand of the ORG pseudo instruction that controls the location counter directly with the bit addresses. For instance, bit 2 of byte address 1 is bit address 10. It is coded as 0001H.2, hence the following relationship exists.

$$\text{address bit} = \text{address byte. } n = \text{address byte} \times 8 + n$$

An example of the entry of bit segments is described here. The following entry specifies the value of the four flags FLG\_0, FLG\_1, FLG\_2, and FLG\_3 starting at bit 0 of byte address D0H.

```
BSEG AT 00D0H.0
;
FLG_0: DBIT 1
FLG_1: DBIT 1
FLG_2: DBIT 1
FLG_3: DBIT 1
```

Figure 1-14. Entry of Absolute Bit Segment

In Figure 1-14, the first line statement "DSEG AT 00D0H.0" may be substituted by the statement "BSEG AT 0104".

The absolute bit segment may overlap partially or fully the absolute data segment. For example, the word long data space WK\_0 is defined as the data segment; this is shown in Figure 1-13. For convenience, it became necessary for the lower four bits starting at WK\_0 to be accessed using bit units, and the four bits are identified in the bit unit as WK\_00, WK\_01, WK\_02 and WK\_03. The new entry is easily made as shown in Figure 1-17 where the bit segment starts at WK\_0.0. The assembler does not issue a warning for the overlapping condition.

There are two ways to specify the symbol which has the attribute of a bit segment. One way is to specify the label within the bit segment as shown in Figure 1-15, and the other way is to specify the label directly using a BIT pseudo instruction. The BIT pseudo instruction imparts values and the bit segment attribute to the symbol as shown in Figure 1-16.

```
BSEG AT WK_0.0
;
WK_00: DBIT 1
WK_01: DBIT 1
WK_02: DBIT 1
WK_03: DBIT 1
```

Figure 1-15. Bit Segment Is Overlaid on Data Segment of Figure 1-12

|        |     |        |
|--------|-----|--------|
| WK_00: | BIT | WK_0.0 |
| WK_01: | BIT | WK_0.1 |
| WK_02: | BIT | WK_0.2 |
| WK_03: | BIT | WK_0.3 |

**Figure 1-15. Equivalent Result (to Figure 1-15) Obtained by  
BIT Pseudo Instruction**

[NOTE] The description of the coding formats and the functions of the assembler pseudo instructions given here is not complete because the main objective is to explain the concept of segments. For the details of the coding formats and the functions of the assembler pseudo instructions, refer to the assembler manual.

*-Description of Relocatable Segments-*

The entry of relocatable segments is described here, and it is more complex than the entry of the absolute segment. For the absolute segment, the entry is started by simply stating the pseudo instruction such as CSEG, DSEG or BSEG. For the relocatable segment, the name and type of segment are declared by the SEGMENT pseudo instruction, and even the type of relocation is declared if necessary. The entry format of the SEGMENT pseudo instruction is shown below.

| segment name | SEGMENT | segment type | [relocation type] |
|--------------|---------|--------------|-------------------|
|--------------|---------|--------------|-------------------|

The square bracket, [ ], for the relocation type implies that this entry in the statement is optional. This segment defining statement can be placed anywhere in the program as long as it precedes the RSEG pseudo instruction. However, it is usually placed at the head of program with other symbol defining statements.

The segment type specifies the segment to be defined: either code, data, or bit segment. The relocation type means the restricting factors when the linker allocates the segment to the memory addresses. The segment and relocation types are shown below.

**Segment Type**

|      |                                 |
|------|---------------------------------|
| CODE | defined segment is code segment |
| DATA | defined segment is data segment |
| BIT  | defined segment is bit segment  |

**Relocation Type**

|         |                                                                                         |
|---------|-----------------------------------------------------------------------------------------|
| UNIT    | match segment head with unit boundary                                                   |
| WORD    | match segment head with word boundary                                                   |
| OCT     | match segment head with 8-byte boundary                                                 |
| PAGE    | match segment head with page head                                                       |
| NUMBERn | match segment head with boundary of n units where n=1, 2, 4, 8, . . . 2048 (power of 2) |
| INPAGE  | match segment head within page                                                          |

In the following description, the unit means the smallest unit of segment used in the accessing operation involved; hence the unit for the code and data segments is a byte, while it is a bit for the bit segment.

## **Chapter 1 Overview**

---

### **Memory Configuration**

The UNIT in the relocation type above means "allocate any place". Without declaration of the relocation type listed in the above table, the assembler assumes that the segment possesses the UNIT attributes and processes the segment accordingly. Therefore, UNIT is not usually used unless its explicit understanding is required. As it is easily understood from the preceding discussions, the attributes of WORD and OCT concern the word boundary and the local register accordingly.

PAGE and INPAGE obviously take into account the page structure of the data space. NUMBER n permits the specification and allocation of boundaries which can not be defined by WORD, OCT and PAGE. Number, in this case, means so many units, and the unit is byte for code and data segments and bit for the bit segment. The attributes of UNIT, WORD, OCT and PAGE are inclusive in ascending order. For example, specifying OCT (its attributes) necessarily specifies all of the attributes of UNIT and WORD, and specifying PAGE satisfies all of the attributes of UNIT, WORD and OCT.

To enter the relocatable segment statement, the RSEG pseudo instruction whose format is shown below is used. This starts the entry of the segment indicated in the format.

|      |              |
|------|--------------|
| RSEG | segment name |
|------|--------------|

Following the entry of RSEG pseudo instruction, each segment is entered in the same manner as for the absolute segment, so no further description is given. It should be noted that overlapping the data and bit segments is not allowed for relocatable segments, while a similar overlapping for absolute segments is permissible.

For reference, an example entry is given in the following pages for an actual case where the absolute and relocatable segments coexists. Following this example, another important concept for the relocatable segment, "partial segment", will be explained.

(Example of Segment Entry)

```
MAIN      SEGMENT  CODE      ; Main Routine
MAIN_BUF   SEGMENT  DATA WORD ; Buffer Area for Main Routine
MAIN_FLG   SEGMENT  BIT       ; Flag Area for Main Routine
;
STACK_SIZE EQU      256      ; Stack Size
;
; ***** Definition of Stack Space *****
DSEG      AT      0280H-STACK_SIZE    ; Reserve a stack space with a size of
DS        STACK_SIZE-1           ; STACK_SIZE starting at address 0280H
STACK_BTM DS      1
;
; ***** Vector Table *****
CSEG      AT      00C0H.0
DW        START             ; Reset vector
DS        38                ; Reserved for future
;
; ***** VCAL Table *****
CSEG      AT      0028H
DS        16                ; Reserved for future
;
; ***** Flag Definition *****
BSEG      AT      00C0H.0
FLG0:    DBIT    1
FLG1:    DBIT    1
FLG2:    DBIT    1
FLG3:    DBIT    1
DBIT    4                ; Reserved for future
;
; ***** ROM Table *****
CSEG      AT      3C00H
TBL_1:   DW      56DCH, 0013H, 9FA4H, 0A37H
TBL_2:   DB      03H, 05H, 5FH, 87H, 0C4H, 0A1H
;
; ***** WORK *****
DSEG      AT      00C1H
WK_0:    DS      2
WK_1:    DS      2
WK_2:    DS      2
WK_3:    DS      2
;
```

(Continued on next page)

**Chapter 1 Overview**  
**Memory Configuration**

---



***«Partial Segments»***

Sometimes, when creating program code, relocatable segments are referred to as partial segments. Here is an example. Imagine the situation in which three programmers, A, B, and C, are in the process of designing a program as a team. Assume that a module in the program calls six subroutines which are named SUB1, SUB2, SUB3, SUB4, SUB5 and SUB6, respectively. Programmer A is assigned to SUB1 and SUB2, Programmer B to SUB3 and SUB 4, and Programmer C is assigned to SUB5 and SUB6. Each programmer works on his assigned subroutines independently using three different files. The completed files are assembled independently and the resulting relocatable objects are linked by the linker. The six subroutines, SUB1 through SUB6, are lumped in the code segment named SUBROOT that will be allocated to a continuous area of the memory space. Then, to implement the preceding plan, the programmers enter their statements in the source programs in the following manner.

1. Define the relocatable code segment named SUBROOT by SEGMENT pseudo instruction.
2. Each programmer enters RSEG SUBROOT prior to entering SUB1 through SUB6.

| Programmer A's File                                                                                                                      | Programmer B's File                                                                                                                | Programmer C's File                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| <pre>SEGMENT SUBROOT CODE     ! RSEG SUBROOT SUB1: Statements of SUB1 subroutine  RSEG SUBROOT SUB2: Statements of SUB2 subroutine</pre> | <pre>SEGMENT SUBROOT CODE RSEG SUBROOT SUB3: Statements of SUB3 subroutine  RSEG SUBROOT SUB4: Statements of SUB4 subroutine</pre> | <pre>SEGMENT SUBROOT CODE RSEG SUBROOT SUB5: Statements of SUB5 subroutine  RSEG SUBROOT SUB6: Statements of SUB6 subroutine !</pre> |

**Figure 1-17. Example of Partial Segment Coding**

The files, some of which are in shown in Figure 1-17, are assembled by the assembler RAS66K, and each of the resulting three object files contain two of the relocatable segments named SUBROOT. When the three object files are linked, the linker will find six relocatable segments of the identical name; however, the linker will consider them as one entity of SUBROOT, and allocate the six segments to a continuous memory space. Each of the six segments prior to the last allocation by the linker is called a partial segment. Each partial segment:

- is a relocatable segment
- has an identical segment name
- has identical segment attributes
- has identical relocation attributes
- implies the existence of plural segments

Among relocation attributes, the UNIT attribute should agree with all other attributes.

The linker regards the partial segments as the subdivisions of one larger segment whenever they are found, and allocates them to a continuous space.

# Chapter 2. Addressing Modes

---

|                                                                            |             |
|----------------------------------------------------------------------------|-------------|
| <b>1. RAM Addressing Modes .....</b>                                       | <b>2-1</b>  |
| 1.1 Register Addressing .....                                              | 2-1         |
| (1) Accumulator Addressing .....                                           | 2-1         |
| (2) Pointing Register Addressing .....                                     | 2-1         |
| (3) Control Register Addressing .....                                      | 2-2         |
| (4) Local Register Addressing .....                                        | 2-2         |
| (5) System Stack Pointer Addressing .....                                  | 2-3         |
| 1.2 Page Addressing .....                                                  | 2-3         |
| (1) Current Page Addressing .....                                          | 2-3         |
| (2) Zero Page Addressing .....                                             | 2-4         |
| 1.3 Pointing Register Indirect Addressing .....                            | 2-5         |
| (1) Data Pointer Indirect Addressing .....                                 | 2-5         |
| (2) User Stack Pointer Indirect Addressing (with 8-bit Displacement) ..... | 2-5         |
| (3) Index Register Indirect Addressing (with 16-bit Displacement) .....    | 2-6         |
| 1.4 Immediate Addressing .....                                             | 2-7         |
| -Advice About RAM Addressing-                                              | 2-7         |
| <b>2. ROM Addressing Modes .....</b>                                       | <b>2-8</b>  |
| 2.1 Direct Addressing .....                                                | 2-8         |
| 2.2 Indirect Addressing .....                                              | 2-8         |
| (1) Single Indirect Addressing .....                                       | 2-8         |
| (2) Double Indirect Addressing .....                                       | 2-9         |
| (3) Indirect Addressing with 16-bit base .....                             | 2-10        |
| <b>3. Bit Addressing Modes.....</b>                                        | <b>2-12</b> |
| <b>4. Logical Bit Address Space .....</b>                                  | <b>2-13</b> |

## **Chapter 2 Addressing Modes**

### **RAM Addressing Modes**

---

The MSM66201 provides two independent memory spaces, namely the program and data memory spaces. The MSM66201 accommodates the accessing of these memory spaces through a number of different addressing modes. The program memory space usually consists of ROM and is referred to as ROM space in this chapter. The data memory space generally consists of RAM and is referred to as RAM space. The RAM space includes registers, counters, ports and other pieces belonging to SFR, as well as the pointing and local registers. Addressing the RAM and ROM is referred to as RAM addressing and ROM addressing respectively.

## **1. RAM Addressing Modes**

Except for a few cases, RAM addressing modes are generally used for the operands of the instructions. There are five major classes of RAM addressing modes, which are listed below:

1. Register addressing
2. Page addressing
3. Pointing register indirect addressing
4. Stack addressing
5. Immediate addressing

### **1.1 Register addressing**

Register addressing, for accessing the contents of the registers, includes the following:

#### **(1) Accumulator addressing**

|          |   |
|----------|---|
| [Symbol] | A |
|----------|---|

The above is the addressing mode for the accumulator. It is applicable equally to word long and byte long data.

**Example:**      L        A, #0              LB        A, #0  
                  MOV     A, er0              MOVB    A, #0

#### **(2) Pointing register addressing**

|          |                               |
|----------|-------------------------------|
| [Symbol] | DP        (data pointer)      |
|          | USP      (user stack pointer) |
|          | X1, X2 (index register)       |

This addressing mode is for pointing registers, handling the registers individually. This addressing mode can be used in word length instruction only.

**[NOTE]** There are eight units of pointing registers (PR0 through PR7), and the units to be accessed by These modes are specified by the system control base (SCB).

## Chapter 2 Addressing Modes

### RAM Addressing Modes

Example:      L       A, DP                  MOV    USP, A  
                  MOV    X1, #2000H  
                  ROL    X2

#### (3) Control register addressing

|          |      |                                  |
|----------|------|----------------------------------|
| [Symbol] | LRB  | (local register base)            |
|          | PSW  | (program status word)            |
|          | PSWH | (program status word upper byte) |
|          | PSWL | (program status word lower byte) |

Above, the addressing modes for the local register base and program status word are shown. LRB and PSW are applicable only to word long data, while PSWH and PSWL are applicable only to byte long data.

Example:      L       A, LRB                  MOV    PSW, #00H  
                  MOVB  PSWH, A                  ROLB  PSWL

#### (4) Local register addressing

|          |         |                                      |
|----------|---------|--------------------------------------|
| [Symbol] | r0—r7   | (local register addressing)          |
|          | er0—er3 | (extended local register addressing) |

Above, the addressing modes for local registers are shown. The base address of the set of the local registers is generated by adding three bits of 0 to the contents of LRB (local register base).

Furthermore, r0—r7, and er0—er3, may respectively be stated as R0—R7, and ER0—ER3.



## **Chapter 2 Addressing Modes**

### **RAM Addressing Modes**

#### **(5) System stack pointer addressing**

|          |     |
|----------|-----|
| [Symbol] | SSP |
|----------|-----|

Above, the addressing mode for the system stack pointer is shown. It is applicable only to word long data.

**Example:**      MOV     A, SSP                  MOV     SSP, #1000H

### **1.2 Page addressing**

In this addressing mode, an address is specified by offsetting from the starting address of the page. There are two modes of page addressing: current page addressing and zero page addressing modes. In current page addressing, the offset is given from the starting address of the page indicated by LRB (local register). In zero page addressing, the offset within Page 0 is not affected by LRB.

#### **(1) Current page addressing**

|          |                  |                             |
|----------|------------------|-----------------------------|
| [Symbol] | off <sup>1</sup> | N <sub>8</sub> <sup>2</sup> |
|----------|------------------|-----------------------------|

As shown in the diagram, bits 12 through 5 of LRB indicate the page address in RAM space. Bits 4 through 0 of LRB with an additional 3 bits form the address (8 bits) within the page. All 8 bits are 0 for the base address of the page, and the offset (0 ~ 255) is given from the base address.

This addressing mode is applicable to word long data and byte long data.

**[NOTE]** <sup>1</sup> "off" is the agreed code to specify current page addressing. It may be written as "OFF". However, the latter expression resembles OFFH for the immediate value. To avoid possible confusion, the use of "off" is recommended.

<sup>2</sup> N<sub>8</sub> is the amount of the offset within the page. However, at the coding of the source program, the absolute, non-offset address itself or a symbol such as the label is entered. The programmer should not be concerned with offsetting.

## Chapter 2 Addressing Modes

### RAM Addressing Modes



Example:      L      A, off 2000H      MOV    A, off WORK\_01  
                  LB     A, off 2000H      MOVB A, off WORK\_01

#### (2) Zero Page addressing



Above is the zero page addressing mode, where the offset is given within Page 0 (addresses 0 through  $0FFH$ ) in the RAM space. This addressing mode is applicable to word long and byte long data.



**[NOTE]** SFR is located in Page 0. To simplify the entry of addresses to SFR, the assembler defines the data address symbols, some of which are easily mistaken as one of the special assembler symbols used to describe the addressing modes. Care should be observed. For instance, A is a special assembler symbol used to describe addressing modes such as ACC for zero page addressing, and off ACC for current page addressing.

## Chapter 2 Addressing Modes

### RAM Addressing Modes

More examples of confusing symbols are listed below.

|                   |      |             |                         |
|-------------------|------|-------------|-------------------------|
| <b>Example 1:</b> | MOV  | PSW, A      | register addressing     |
|                   | MOV  | APSW, A     | zero page addressing    |
|                   | MOV  | off APSW, A | current page addressing |
| <b>Example 2:</b> | MOV  | LRB, A      | register addressing     |
|                   | MOV  | ALRB, A     | zero page addressing    |
|                   | MOV  | off ALRB, A | current page addressing |
| <b>Example 3:</b> | MOV  | SSP, A      | register addressing     |
|                   | MOV  | ASSP, A     | zero page addressing    |
|                   | MOV  | off ASSP, A | current page addressing |
| <b>Example 4:</b> | MOVB | PSW, A      | register addressing     |
|                   | MOVB | APSW, A     | zero page addressing    |
|                   | MOVB | off APSW, A | current page addressing |

### 1.3 Pointing register indirect addressing

This addressing mode is performed by the pointing registers using indirect addressing, and it is used for both word and byte length instructions.

#### (1) Data pointer indirect addressing

|          |      |
|----------|------|
| [Symbol] | [DP] |
|----------|------|

The RAM space whose address is specified by the contents of the data pointer is accessed by this mode.



|                 |    |         |
|-----------------|----|---------|
| <b>Example:</b> | L  | A, [DP] |
|                 | LB | A, [DP] |

#### (2) User stack pointer indirect addressing (with 8-bit displacement)

|          |                 |
|----------|-----------------|
| [Symbol] | $\pm N_8$ [USP] |
|----------|-----------------|

## Chapter 2 Addressing Modes

### RAM Addressing Modes

The RAM space whose address is specified by the sum of the user stack pointer contents and  $\pm N_8$  (displacement) is accessed.  $\pm N_8$  is in the range from +127 to -128 or the equivalent range specified by symbols.



[NOTE] In the machine code,  $\pm N_8$  is the displacement code sign which is given by the uppermost bit; however, the integer between +127 and -128 itself is used at program entry. For instance, the code for the displacement of -1 is FFH and the entry seems to be 0FFH[USP]; however, it is incorrect for the assembler, because its value exceeds +127. The correct entry in this case is -1 [USP].

Example:      L        A, 70H[USP]                  LB        A, -120[USP]  
                  ADD     A, DISP1[USP]

#### (3) Index register indirect addressing (with 16-bit base)

|          |                            |
|----------|----------------------------|
| [Symbol] | $N_{16}[X_1], N_{16}[X_2]$ |
|----------|----------------------------|

The RAM space whose address is the sum of the base address  $N_{16}$  (16 bits) and the contents of the index register is accessed.

The addition of  $N_{16}$  and  $X_1$ , or  $N_{16}$  and  $X_2$  is performed in 16 bit length without sign, and the overflow is ignored. The maximum space addressable is 64K bytes; namely, the entire space of the current bank.

## Chapter 2 Addressing Modes

### RAM Addressing Modes



Example: L A, 5000H[X1] LB A, TBL\_BASE[X2]

#### 1.4 Immediate addressing

[Symbol] #N8, #N<sub>16</sub>

The number or symbol in the operand itself specifies the address. The operand statement is #N<sub>16</sub> for word long data and #N8 for byte long data.

Example: MOV er0, #1234H MOVB r0, #12H

##### *Advice About RAM Addressing*

In RAM addressing modes, there is not a 64K-space direct addressing mode. The design of the CPU is based on the idea of processing a job completely within a page of 256 bytes. The data area required for the job is contained in the page as much as possible so that direct page addressing (off N8) can be used.

On the other hand, some data area need to be accessed by many processes. For example, a global variable area may need to be accessed by multiple subroutines. Special function registers (SFR) are another good example. This is why SFR is allocated to Page 0, and usually accessed by zero page addressing. Also, allocating a global variable area to Page 0 enables the use of zero page addressing regardless of the value of the local register (LRB).

When direct accesses are desired beyond the page limit of 256 bytes, the index-register indirect addressing with a 16-bit base (N<sub>16</sub>[X1], N<sub>16</sub>[X2]) is used. X1 and X2 are 0 while N<sub>16</sub> is the address of the object in this case. However, the preceding addressing is not efficient because of the large numbers of bytes required for the instruction and the number of cycles it uses. Current page addressing used with careful data arrangement or register addressing with the local registers strategically placed in the areas should be employed as much as possible for better program efficiency.

## Chapter 2 Addressing Modes

### ROM Addressing Modes

---

## 2. ROM Addressing Modes

ROM addressing is used for accessing program memory space which consists of on-chip ROM and external program memory. ROM addressing is classified into two types, the direct and the indirect type. The indirect addressing type is further classified into three sub-types: single indirect addressing, double indirect addressing, and indirect addressing with a 16-bit base.



The ROM addressing modes are specified only in the operands of the ROM table reference instructions such as LC, LCB, CMPC, CMPCB.

The addressing modes are described below.

### 2.1 Direct addressing

|          |      |
|----------|------|
| [Symbol] | N°16 |
|----------|------|

The reference address is directly specified with 16-bit immediate addressing N°16.

Example:

|     |               |
|-----|---------------|
| LC  | A, 2000H      |
| LC  | A, DATA_TABLE |
| LCB | A, 3800H      |

### 2.2 Indirect addressing

Indirect addressing includes: single indirect addressing, in which the register and the contents of the RAM specifies the object address; double indirect addressing, in which the contents of the RAM addressed by the pointing register specifies the object address; and indirect addressing with a 16-bit base.

#### (1) Single Indirect addressing

- |          |                                                                                                                                                                                                                                  |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [Symbol] | 1. local register indirect ..... [er0], [er1], [er2], [er3]<br>2. pointing register indirect ..... [DP], [X1], [X2], [USP]<br>3. SSP indirect ..... [SSP]<br>4. LRB indirect ..... [LRB]<br>5. RAM indirect ..... [off Ng], [Na] |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## Chapter 2 Addressing Modes

### ROM Addressing Modes

---

For cases 1—4, the contents of each 16-bit register (er0—er3, DP, X1, X2, USP, SSP, LRB) is the address of the ROM to be accessed.



For case 5, the contents (16 bits) of the RAM which is specified by current or zero page addressing in word length is the address of the ROM to be accessed.



|                 |                     |                           |
|-----------------|---------------------|---------------------------|
| <b>Example:</b> | LC      A, [er0]    | LC      A, [DP]           |
|                 | LC      A, [SSP]    | LCB     A, [LRB]          |
|                 | LCB    A, [off 20H] | LC      A, [off DATA_TBL] |
|                 | LCB    A, [ACC]     |                           |

#### (2) Double Indirect addressing

The section below describes double indirect addressing, in which the RAM addressed indirectly by the pointing register specifies the ROM indirectly.

- |          |                                                            |                                                |
|----------|------------------------------------------------------------|------------------------------------------------|
| [Symbol] | 1. DP double indirect .....                                | [[DP]]                                         |
|          | 2. USP double indirect (with signed 8-bit displacement) .. | [±N <sub>8</sub> [USP]]                        |
|          | 3. Index register double indirect (with 16-bit base) ..... | [N <sub>16</sub> [X1]], [N <sub>16</sub> [X2]] |

## Chapter 2 Addressing Modes

### ROM Addressing Modes



**Example:**

|     |                   |
|-----|-------------------|
| LC  | A, [[DP]]         |
| LC  | A, [-10[USP]]     |
| LCB | A, [1000H[X1]]    |
| LC  | A, [OFFSET_1[X2]] |

#### (3) Indirect addressing with 16-bit base

|          |                                     |                                                                                           |
|----------|-------------------------------------|-------------------------------------------------------------------------------------------|
| [Symbol] | 1. pointing register indirect ..... | N <sup>16</sup> [DP], N <sup>16</sup> [X1]<br>N <sup>16</sup> [X2], N <sup>16</sup> [USP] |
|          | 2. RAM indirect .....               | N <sup>16</sup> [off N <sub>8</sub> ], N <sup>16</sup> [N <sub>8</sub> ]                  |

The sum of the immediate address (N<sup>16</sup>, the base), and the contents of the pointing register or the RAM (word long) is the address of the object.

#### Pointing Register Indirect



---

## Chapter 2 Addressing Modes

### ROM Addressing Modes

---

#### RAM Indirect



Example:

- LC A, 1000H[DP]
- LC A, EXT\_ROM\_BASE[X1]
- LC A, OFFSET\_1[off DISP]

## Chapter 2 Addressing Modes

### ROM Addressing Modes



**Example:**

|     |                   |
|-----|-------------------|
| LC  | A, [[DP]]         |
| LC  | A, [-10[USP]]     |
| LCB | A, [1000H[X1]]    |
| LC  | A, [OFFSET_1[X2]] |

### (3) Indirect addressing with 16-bit base

|          |                                    |                                                                                           |
|----------|------------------------------------|-------------------------------------------------------------------------------------------|
| [Symbol] | 1. pointing register indirect..... | N <sup>16</sup> [DP], N <sup>16</sup> [X1]<br>N <sup>16</sup> [X2], N <sup>16</sup> [USP] |
|          | 2. RAM indirect .....              | N <sup>16</sup> [off N <sub>8</sub> ], N <sup>16</sup> [N <sub>8</sub> ]                  |

The sum of the immediate address (N<sup>16</sup>, the base), and the contents of the pointing register or the RAM (word long) is the address of the object.

#### Pointing Register Indirect



---

## Chapter 2 Addressing Modes

### ROM Addressing Modes

---

#### RAM Indirect



Example:

- LC A, 1000H[DP]
- LC A, EXT\_ROM\_BASE[X1]
- LC A, OFFSET\_1[off DISP]

### **3. Bit Addressing Modes**

The addressing instructions of the MSM66201 includes those which permit accessing a specific bit desired. Examples of these are SBR and SB. The addressing of the desired bit is realized by combining the locations of byte and bit. The byte location is specified by RAM addressing. The bit location is specified either by the bits from 0 to 2 of the accumulator indirectly or by the operand directly. Note that usable RAM addresses are byte long in length.

#### **(1) Specifying a bit using the accumulator indirectly**

This mode appears in the SBR, TBR, and MBR instructions. Only the following RAM addressing modes are available to specify the byte location.

|                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------|
| <code>r0—r7, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]</code> |
|-------------------------------------------------------------------------------------------------------------------------------------|

|                 |     |           |     |         |
|-----------------|-----|-----------|-----|---------|
| <b>Example:</b> | SBR | r0        | RBR | PSWH    |
|                 | TBR | off FLAGS | MBR | C, [DP] |

#### **(2) Specifying the bit directly**

This mode appears in the SB, RB, and JRB instructions. Addressing is accomplished by specifying the object bit with the bit location (from 0 to 7) and byte location specified by the RAM addressing described in (1).

In the statement (shown below), the RAM addressing entry and the bit location entry are connected with a dot (.) .

|          |                                  |
|----------|----------------------------------|
| [Symbol] | RAM addressing code.Bit location |
|----------|----------------------------------|

|                 |     |                         |
|-----------------|-----|-------------------------|
| <b>Example:</b> | SB  | r0.2                    |
|                 | RB  | PSWH.BIT_POINT          |
|                 | JBR | off FLAGS.0, TIMER_LOOP |

## 4. Logical Bit Address Space

Bit addressing for the MSM66201 is performed by specifying the bit address with the byte location specified by RAM addressing, and the bit location within the byte thus specified.

There is no physical bit address space for the MSM66201; however, its use for the assembler statement is acknowledged. Because the bit addressing statement with a combination of byte and bit locations is permitted for assemblers of the MSM80C51 series, such bit address statements are also recognized by the MSM66201 assembler. Strictly speaking, the bit address space is a logical concept, and its realization at the assembler level is accomplished by combining byte and bit locations.

The logical bit addresses of the MSM66201 start at address 0 (that is, location 0 of the data memory) and they progress in ascending order: address 1, address 2, and so on.

| Logical Bit Address |       |       |       |       |       |       |       | Byte<br>location |      |
|---------------------|-------|-------|-------|-------|-------|-------|-------|------------------|------|
| D                   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0                |      |
| A                   | F     | E     | D     | C     | B     | A     | 9     | 8                | 0    |
| T                   | 17    | 16    | 15    | 14    | 13    | 12    | 11    | 10               | 1    |
| A                   | 1F    | 1E    | 1D    | 1C    | 1B    | 1A    | 19    | 18               | 2    |
|                     | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20               | 3    |
| M                   |       |       |       |       |       |       |       |                  | 4    |
| E                   |       |       |       |       |       |       |       |                  |      |
| M                   |       |       |       |       |       |       |       |                  |      |
| O                   |       |       |       |       |       |       |       |                  |      |
| R                   | 7FFF7 | 7FFF6 | 7FFF5 | 7FFF4 | 7FFF3 | 7FFF2 | 7FFF1 | 7FFF0            | FFFE |
| Y                   | 7FFF  | 7FFE  | 7FFFD | 7FFFC | 7FFFB | 7FFFA | 7FFF9 | 7FFF8            | FFFF |
| Bit<br>location     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0                |      |

## **Chapter 3. Details of Instructions**

---

|                                                |              |
|------------------------------------------------|--------------|
| <b>1. Classification of Instructions .....</b> | <b>3-1</b>   |
| <b>2. Instruction Set.....</b>                 | <b>3-5</b>   |
| <b>3. Summary List of Instructions.....</b>    | <b>3-180</b> |

## Chapter 3 Details of Instructions

### Classification of Instructions

The instructions of the MSM66201 may be classified in 16 groups as shown in the following table, "Classification of Instructions".

In the sets of instructions, the details of all instructions will be explained in alphabetical order.

Tables 3-1 through 3-35 at the end of this chapter are the summary list of the functions for all of the instructions.

#### Classification of Instructions

| Group                                | Mnemonic | Instruction name              |
|--------------------------------------|----------|-------------------------------|
| (1) Data Transfer Instructions       | L        | 16-bit Load                   |
|                                      | LB       | 8-bit Load                    |
|                                      | ST       | 16-bit Store                  |
|                                      | STB      | 8-bit Store                   |
|                                      | MOV      | 16-bit Move                   |
|                                      | MOVB     | 8-bit Move                    |
|                                      | CLR      | 16-bit Clear                  |
|                                      | CLRB     | 8-bit Clear                   |
|                                      | SWAP     | 16-bit Swap                   |
|                                      | SWAPB    | 8-bit Swap                    |
|                                      | XCHG     | 16-bit Exchange               |
|                                      | XCHGB    | 8-bit Exchange                |
|                                      | XNBL     | 8-bit Nibble Exchange         |
| (2) Stack Operation Instructions     | PUSHS    | 16-bit Push (System Stack)    |
|                                      | POPS     | 16-bit Pop (System Stack)     |
| (3) Rotate/Shift Instructions        | ROL      | 16-bit Left Rotate            |
|                                      | ROLB     | 8-bit Left Rotate             |
|                                      | ROR      | 16-bit Right Rotate           |
|                                      | RORB     | 8-bit Right Rotate            |
|                                      | SLL      | 16-bit Left Shift             |
|                                      | SLLB     | 8-bit Left Shift              |
|                                      | SRL      | 16-bit Right Shift            |
|                                      | SRLB     | 8-bit Right Shift             |
|                                      | SRA      | 16-bit Arithmetic Right Shift |
|                                      | SRAB     | 8-bit Arithmetic Right Shift  |
| (4) Increment/Decrement Instructions | INC      | 16-bit Increment              |
|                                      | INCB     | 8-bit Increment               |
|                                      | DEC      | 16-bit Decrement              |
|                                      | DECB     | 8-bit Decrement               |
| (5) ROM Table Reference Instructions | LC       | 16-bit ROM Reference          |
|                                      | LCB      | 8-bit ROM Reference           |
|                                      | CMPC     | 16-bit ROM Compare            |
|                                      | CMPCB    | 8-bit ROM Compare             |

**Chapter 3 Details of Instructions**  
**Classification of Instructions**

---

| Group                                 | Mnemonic | Instruction name                                |
|---------------------------------------|----------|-------------------------------------------------|
| (6) Arithmetic Operation Instructions | MUL      | 16-bit Multiply                                 |
|                                       | MULB     | 8-bit Multiply                                  |
|                                       | DIV      | 16-bit Divide                                   |
|                                       | DIVB     | 8-bit Divide                                    |
|                                       | ADD      | 16-bit Add                                      |
|                                       | ADDB     | 8-bit Add                                       |
|                                       | ADC      | 16-bit Add with Carry                           |
|                                       | ADCB     | 8-bit Add with Carry                            |
|                                       | SUB      | 16-bit Subtract                                 |
|                                       | SUBB     | 8-bit Subtract                                  |
|                                       | SBC      | 16-bit Subtract with Carry                      |
|                                       | SBCB     | 8-bit Subtract with Carry                       |
| (7) Logical Operation Instructions    | AND      | 16-bit Logical AND                              |
|                                       | ANDB     | 8-bit Logical AND                               |
|                                       | OR       | 16-bit Logical OR                               |
|                                       | ORB      | 8-bit Logical OR                                |
|                                       | XOR      | 16-bit Exclusive OR                             |
|                                       | XORB     | 8-bit Exclusive OR                              |
| (8) Compare Instructions              | CMP      | 16-bit Compare                                  |
|                                       | CMPB     | 8-bit Compare                                   |
| (9) Decimal Adjust Instructions       | DAA      | 8-bit Decimal Adjust (Add)                      |
|                                       | DAS      | 8-bit Decimal Adjust (Subtract)                 |
| (10) Code Extend Instruction          | EXTND    | Coded Byte to Word Extend                       |
| (11) Bit Operation Instructions       | SBR      | Set Bit (Register Indirect Bit Addressing)      |
|                                       | RBR      | Reset Bit (Register Indirect Bit Addressing)    |
|                                       | TBR      | Test Bit (Register Indirect Bit Addressing)     |
|                                       | MBR      | Transfer Bit (Register Indirect Bit Addressing) |
|                                       | SB       | Set Bit (Direct Bit Addressing)                 |
|                                       | RB       | Reset Bit (Direct Bit Addressing)               |
|                                       | MB       | Transfer Bit (Direct Bit Addressing)            |

**Chapter 3 Details of Instructions**  
**Classification of Instructions**

| Group                             | Mnemonic | Instruction name              |
|-----------------------------------|----------|-------------------------------|
| (12) Jump/Call Group Instructions | SJ       | Short Jump                    |
|                                   | J        | 16-bit (64K byte) Space Jump  |
|                                   | JC       | Conditional Jump              |
|                                   | JBR      | Bit Test and Jump             |
|                                   | JBS      | Bit Test and Jump             |
|                                   | JRNZ     | Loop                          |
|                                   | SCAL     | Short Call                    |
|                                   | CAL      | 16-bit (64K byte) Space Call  |
|                                   | VCAL     | Vector Call                   |
|                                   | RT       | Return from Normal Subroutine |
| (13) Other Instructions           | RTI      | Return from Interrupt Routine |
|                                   | SC       | Set Carry                     |
|                                   | RC       | Reset Carry                   |
|                                   | BRK      | Break (System Reset)          |
|                                   | NOP      | No Operation                  |

### Chapter 3 Details of Instructions Instruction Set

---

**ADC A, obj**

16-bit Add with Carry

**obj** #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function** A ← A + obj + C (word long)

**Description** This instruction adds together the contents of the accumulator, the addressing object, and the carry (C) in a word long operation.

*This instruction is influenced by the data descriptor (DD).*  
For the instruction to be executed correctly, it is necessary to set DD=1.

|              |                                                                                                                                                                                                     |                            |    |    |    |   |   |   |  |                                                                                                                                 |    |   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|----|----|---|---|---|--|---------------------------------------------------------------------------------------------------------------------------------|----|---|
| <b>Flags</b> | Flags affected by execution:                                                                                                                                                                        | Flags affecting execution: |    |    |    |   |   |   |  |                                                                                                                                 |    |   |
|              | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td>*</td> <td></td> </tr> </table> | ZF                         | CF | HC | DD | * | * | * |  | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td>1</td> </tr> </table> | DD | 1 |
| ZF           | CF                                                                                                                                                                                                  | HC                         | DD |    |    |   |   |   |  |                                                                                                                                 |    |   |
| *            | *                                                                                                                                                                                                   | *                          |    |    |    |   |   |   |  |                                                                                                                                 |    |   |
| DD           |                                                                                                                                                                                                     |                            |    |    |    |   |   |   |  |                                                                                                                                 |    |   |
| 1            |                                                                                                                                                                                                     |                            |    |    |    |   |   |   |  |                                                                                                                                 |    |   |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | 96   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 18+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | 92             |                |    |   |   | 4      | —   |
| X1                    | 90   | 92             |                |    |   |   | 4      | —   |
| X2                    | 91   | 92             |                |    |   |   | 4      | —   |
| USP                   | A1   | 92             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 92             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 92             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | 97   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 92             |    |   |   | 6      | —   |
| [DP]                  | B2   | 92             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 92             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 92 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 92 |   |   | 8      | 12  |

### Chapter 3 Details of Instructions Instruction Set

---

#### **ADC obj, off N<sub>8</sub>**

16-bit Add with Carry

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N'<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj + off N<sub>8</sub> + C (word long)

**Description**

This instruction adds together the contents of the addressing object, the data memory specified by current page addressing (off N<sub>8</sub>), and the carry (C) in a word long operation.

The resulting sum (16 bits) is stored in the addressing object, and the carry over from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                 |                |                |                |   | CYCLES |     |      |      |
|-----------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                       | BYTE |                 |                |                |                |   | INT    | INT | EX T | EX T |
|                       | 1    | 2               | 3              | 4              | 5              | 6 |        |     |      |      |
| A                     |      |                 |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>      |      |                 |                |                |                |   |        |     |      |      |
| erN                   | 44+N | 93              | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                    | 92   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                    | 90   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                    | 91   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                   | A1   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                   | A0   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                   | A4   | 93              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>    | B4   | N' <sub>8</sub> | 93             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N' <sub>8</sub>       | B5   | N' <sub>8</sub> | 93             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                  | B2   | 93              | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N <sub>8</sub> [USP] | B3   | N' <sub>8</sub> | 93             |                |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub>  | N <sub>H</sub> | 93             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub>  | N <sub>H</sub> | 93             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**ADC obj, #N<sub>16</sub>**

16-bit Add with Carry

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'16[X1], N'16[X2]

**Function**

obj ← obj + #N<sub>16</sub> + C (word long)

**Description**

This instruction adds together the contents of the addressing object (word long), the 16-bit immediate value (#N<sub>16</sub>), and the carry (C).

The resulting sum (16 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | 90              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | 90              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | 90              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | 90              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | 90             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | 90             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ADC<sub>B</sub> A, obj**

8-bit Add with Carry

**obj**

#N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A<sub>L</sub> ← A<sub>L</sub> + obj + C (byte long)

**Description**

This instruction adds together the contents of the lower byte of the accumulator (A<sub>L</sub>), the addressing object (byte long), and the carry (C). The resulting sum (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>), and the carry from the highest (most significant) bit is stored in the carry (C).

*This instruction is affected by the data descriptor (DD).*

For the instruction to be executed correctly, it is necessary to set DD=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | 96   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 18+N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2   | 92             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 92             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | 97   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 92             |    |   |   | 6      | —   |
| [DP]                  | C2   | 92             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 92             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 92 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 92 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**ADCB obj, A**

8-bit Add with Carry

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj + A<sub>L</sub> + C (byte long)

**Description**

This instruction adds together the contents of the lower byte of the accumulator (A<sub>L</sub>), the addressing object (byte long), and the carry (C).

The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| •  | •  | •  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 91             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | 91             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 91             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 91             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 91             |    |   |   | 7      | —   |
| [DP]                  | C2   | 91             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 91             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 91 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 91 |   |   | 9      | 13  |

### Chapter 3 Details of Instructions Instruction Set

#### **ADCB obj, off N<sub>8</sub>**

8-bit Add with Carry

|                     |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----------------------------|--|--|--|----|----|---|---|---|--|--|--|
| <b>obj</b>          |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
|                     | rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                         |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
| <b>Function</b>     |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
|                     | obj ← obj + off N <sub>8</sub> + C (byte long)                                                                                                                                                                                                                                                                                    |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
| <b>Description</b>  |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
|                     | <p>This instruction adds together the contents of the addressing object, the data memory specified by current page addressing (off N<sub>8</sub>), and the carry (C).</p> <p>The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).</p> |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
| <b>Flags</b>        |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |
|                     | Flags affected by execution:                                                                                                                                                                                                                                                                                                      |    |    | Flags affecting execution: |  |  |  |    |    |   |   |   |  |  |  |
|                     | <table border="1" style="margin-left: auto; margin-right: auto; border-collapse: collapse;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td>*</td><td>*</td><td></td></tr> </table>                                                                                                                    | ZF | CF |                            |  |  |  | HC | DD | * | * | * |  |  |  |
| ZF                  | CF                                                                                                                                                                                                                                                                                                                                | HC | DD |                            |  |  |  |    |    |   |   |   |  |  |  |
| *                   | *                                                                                                                                                                                                                                                                                                                                 | *  |    |                            |  |  |  |    |    |   |   |   |  |  |  |
| <b>Codes/Cycles</b> |                                                                                                                                                                                                                                                                                                                                   |    |    |                            |  |  |  |    |    |   |   |   |  |  |  |

| o b j                | CODE |                |                |                |                |   | CYCLES |     |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                    |      |                |                |                |                |   |        |     |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |      |      |
| rN                   | 20+N | 93             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   |
| PSWH                 | A2   | 93             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| PSWL                 | A3   | 93             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| off N'8              | C4   | N'8            | 93             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |
| N'8                  | C5   | N'8            | 93             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |
| [DP]                 | C2   | 93             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | 93             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | 93             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | 93             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ADCB obj, #N<sub>8</sub>**

8-bit Add with Carry

|                    |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|--|----|--|
| <b>obj</b>         | rN, PSWH, PSWL, off N's, N's, [DP], ±N's[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                      |    |    |    |    |   |   |   |  |    |  |
| <b>Function</b>    | obj ← obj + #N <sub>8</sub> + C (byte long)                                                                                                                                                                                                                                                                                                                                                    |    |    |    |    |   |   |   |  |    |  |
| <b>Description</b> | <p>This instruction adds together the contents (byte long) of the addressing object, the 8-bit immediate value (#N<sub>8</sub>), and the carry (C).</p> <p>The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).</p>                                                                                |    |    |    |    |   |   |   |  |    |  |
| <b>Flags</b>       | <p>Flags affected by execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td>*</td><td>*</td><td></td></tr> </table> <p>Flags affecting execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table> | ZF | CF | HC | DD | * | * | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                             | HC | DD |    |    |   |   |   |  |    |  |
| *                  | *                                                                                                                                                                                                                                                                                                                                                                                              | *  |    |    |    |   |   |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |

**Codes/Cycles**

---

| obj                  | CODE |                |                |                |                |   | CYCLES |     |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                      | BYTE |                |                |                |                |   | INT    | EXT |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                    |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |
| rN                   | 20+N | 90             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                 | A2   | 90             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                 | A3   | 90             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N's              | C4   | N's            | 90             | N <sub>8</sub> |                |   | 8      | 14  |
| N's                  | C5   | N's            | 90             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                 | C2   | 90             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N's[USP]            | C3   | N's            | 90             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | 90             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | 90             | N <sub>8</sub> |   | 10     | 15  |

### Chapter 3 Details of Instructions Instruction Set

#### **ADD A, obj**

16-bit Add (user stack)

**obj** #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ← A + obj (word long)

**Description**

This instruction adds the contents of the accumulator to the addressing object in a word long operation. The resulting sum (16 bits) is stored in the accumulator, and the carry from the highest (most significant) bit is stored in the carry (C).

*This instruction is affected by the data descriptor (DD). For this instruction to be executed correctly, it is necessary to set DD=1.*

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | 86   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 08+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | 82             |                |    |   |   | 4      | —   |
| X1                    | 90   | 82             |                |    |   |   | 4      | —   |
| X2                    | 91   | 82             |                |    |   |   | 4      | —   |
| USP                   | A1   | 82             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 82             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 82             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | 87   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 82             |    |   |   | 6      | —   |
| [DP]                  | B2   | 82             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 82             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 82 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 82 |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

#### ADD obj, off N<sub>8</sub>

16-bit Add

obj

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

obj ← obj + off N<sub>8</sub> (word long)

Description

This instruction adds the contents of the addressing object to the contents (off N<sub>8</sub>) of the data memory specified by current page addressing.

The resulting sum (16 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 1  |

Codes/Cycles

| obj                  | CODE |                 |                |                |                |   | CYCLES |     |      |      |
|----------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                      | BYTE |                 |                |                |                |   | INT    | INT | EX T | EX T |
|                      | 1    | 2               | 3              | 4              | 5              | 6 |        |     |      |      |
| A                    |      |                 |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>     |      |                 |                |                |                |   |        |     |      |      |
| erN                  | 44+N | 83              | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                   | 92   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                   | 90   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                   | 91   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                  | A1   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                  | A0   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                  | A4   | 83              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>   | B4   | N' <sub>8</sub> | 83             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N' <sub>8</sub>      | B5   | N' <sub>8</sub> | 83             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                 | B2   | 83              | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N'8[USP]            | B3   | N' <sub>8</sub> | 83             | N <sub>8</sub> |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1] | B0   | N <sub>L</sub>  | N <sub>H</sub> | 83             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2] | B1   | N <sub>L</sub>  | N <sub>H</sub> | 83             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ADD obj, #N<sub>16</sub>**

16-bit Add

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'16[X1], N'16[X2]

**Function**

obj ← obj + #N<sub>16</sub> (word long)

**Description**

This instruction adds the contents of the addressing object (word long) to the 16-bit immediate value (#N<sub>16</sub>).

The resulting sum (16 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | 80              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | 80              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | 80              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | 80              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | 80             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | 80             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

## Chapter 3 Details of Instructions

### Instruction Set

#### ADDB A, obj

8-bit Add

obj

#N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

A<sub>L</sub> ← A<sub>L</sub> + obj (byte long)

Description

This instruction adds the contents of the lower byte of the accumulator (A<sub>L</sub>) to the addressing object (byte long). The resulting sum (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>), and the carry over from the highest (most significant) bit is stored in the carry (C).

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=0.

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 0  |

Codes/Cycles

| obj                   | CODE   |                |                |    |   |   | CYCLES |     |
|-----------------------|--------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE   |                |                |    |   |   | INT    | EXT |
|                       | 1      | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |        |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | 86     | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 08 + N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2     | 82             |                |    |   |   | 4      | —   |
| PSWL                  | A3     | 82             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | 87     | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5     | N <sub>8</sub> | 82             |    |   |   | 6      | —   |
| [DP]                  | C2     | 82             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3     | N <sub>8</sub> | 82             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0     | N <sub>L</sub> | N <sub>H</sub> | 82 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1     | N <sub>L</sub> | N <sub>H</sub> | 82 |   |   | 8      | 10  |

### Chapter 3 Details of Instructions Instruction Set

#### **ADDB obj, A**

8-bit Add

**obj** \_\_\_\_\_

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function** \_\_\_\_\_

obj ← obj + A<sub>L</sub> (byte long)

**Description** \_\_\_\_\_

This instruction adds the contents of the lower byte of the accumulator (A<sub>L</sub>) to the addressing object (byte long).

The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags** \_\_\_\_\_

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles** \_\_\_\_\_

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 81             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | 81             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 81             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 81             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 81             |    |   |   | 7      | —   |
| [DP]                  | C2   | 81             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 81             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 81 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 81 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**ADDB obj, off N<sub>8</sub>**

8-bit Add

**obj**

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj + off N<sub>8</sub> (byte long)

**Description**

This instruction adds the contents of the addressing object to the data memory (off N<sub>8</sub>) specified by current page addressing.

The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                    |      |                |                |                |                |   |        |     |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |      |      |
| rN                   | 20+N | 83             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   |
| PSWH                 | A2   | 83             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| PSWL                 | A3   | 83             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| off N'8              | C4   | N'8            | 83             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |
| N'8                  | C5   | N'8            | 83             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |
| [DP]                 | C2   | 83             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | 83             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | 83             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | 83             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |

← obj  
 ← off N<sub>8</sub>

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ADDB obj, #N<sub>8</sub>**

8-bit Add

**obj**

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj + #N<sub>8</sub> (byte long)

**Description**

This instruction adds the contents (byte long) of the addressing object to the 8-bit immediate value (#N<sub>8</sub>).

The resulting sum (8 bits) is stored in the addressing object, and the carry from the highest (most significant) bit is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                      | BYTE |                |                |                |                |   | INT    | EXT |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                    |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |
| rN                   | 20+N | 80             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                 | A2   | 80             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                 | A3   | 80             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N'8              | C4   | N'8            | 80             | N <sub>8</sub> |                |   | 8      | 14  |
| N'8                  | C5   | N'8            | 80             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                 | C2   | 80             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N'8[USP]            | C3   | N'8            | 80             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | 80             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | 80             | N <sub>8</sub> |   | 10     | 15  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**AND A, obj**

16-bit logical AND

|                    |                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |    |   |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|--|--|--|----|---|
| <b>obj</b>         | #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                     |    |    |    |    |   |  |  |  |    |   |
| <b>Function</b>    | A ← A ∧ obj (word long)                                                                                                                                                                                                                                                                                                              |    |    |    |    |   |  |  |  |    |   |
| <b>Description</b> | This instruction performs the word long logical AND operation on the contents of the accumulator and the addressing object. The result (16 bits) is stored in the accumulator.<br><br><i>This instruction is affected by the data descriptor (DD).</i><br>For the instruction to be executed correctly, it is necessary to set DD=1. |    |    |    |    |   |  |  |  |    |   |
| <b>Flags</b>       | Flags affected by execution:<br><br><table border="1"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td></td><td></td><td></td></tr> </table> Flags affecting execution:<br><br><table border="1"> <tr> <td>DD</td></tr> <tr> <td>1</td></tr> </table>                                                      | ZF | CF | HC | DD | * |  |  |  | DD | 1 |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                   | HC | DD |    |    |   |  |  |  |    |   |
| *                  |                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |    |   |
| DD                 |                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |    |   |
| 1                  |                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |    |   |

---

| o b j                 | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   |        |     |
|                       | 1    | 2              | 3              | 4  | 5 | 6 | INT    | EXT |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | D8   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 58+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | D2             |                |    |   |   | 4      | —   |
| X1                    | 90   | D2             |                |    |   |   | 4      | —   |
| X2                    | 91   | D2             |                |    |   |   | 4      | —   |
| USP                   | A1   | D2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | D2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | D2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | D7   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | D2             |    |   |   | 6      | —   |
| [DP]                  | B2   | D2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | D2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | D2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | D2 |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

#### **AND obj, A**

16-bit logical AND

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∧ A (word long)

**Description**

This instruction performs the word long logical AND operation on the contents of the addressing object and the contents of the accumulator.

The result (16 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | D1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | D1             |                |    |   |   | 5      | —   |
| X1                    | 90   | D1             |                |    |   |   | 5      | —   |
| X2                    | 91   | D1             |                |    |   |   | 5      | —   |
| USP                   | A1   | D1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | D1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | D1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | D1             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | D1             |    |   |   | 7      | —   |
| [DP]                  | B2   | D1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | D1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | D1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | D1 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**AND obj, off N<sub>8</sub>**

16-bit logical AND

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∧ off N<sub>8</sub> (word long)

**Description**

This instruction performs the word long logical AND operation on the contents of the addressing object and the data memory (off N<sub>8</sub>) specified by current page addressing.

The result (16 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |      |      | ← obj |  |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|-------|--|
|                      | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |       |  |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |       |  |
| A                    |      |                |                |                |                |   |        |     |      |      |       |  |
| #N <sub>16</sub>     |      |                |                |                |                |   |        |     |      |      |       |  |
| erN                  | 44+N | D3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |       |  |
| DP                   | 92   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| X1                   | 90   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| X2                   | 91   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| USP                  | A1   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| SSP                  | A0   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| LRB                  | A4   | D3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |       |  |
| off N <sub>8</sub>   | B4   | N'8            | D3             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |       |  |
| N'8                  | B5   | N'8            | D3             | N <sub>8</sub> |                |   | 9      | 16  | —    | —    |       |  |
| [DP]                 | B2   | D3             | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |       |  |
| ±N'8[USP]            | B3   | N'8            | D3             | N <sub>8</sub> |                |   | 10     | 19  | 14   | 23   |       |  |
| N <sub>16</sub> [X1] | B0   | N <sub>L</sub> | N <sub>H</sub> | D3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |       |  |
| N <sub>16</sub> [X2] | B1   | N <sub>L</sub> | N <sub>H</sub> | D3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |       |  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**AND obj, #N<sub>16</sub>**

16-bit logical AND

|     |                                                                                                                       |
|-----|-----------------------------------------------------------------------------------------------------------------------|
| obj | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N'16[X1], N'16[X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------|

|          |                                          |
|----------|------------------------------------------|
| Function | obj ← obj ∧ #N <sub>16</sub> (word long) |
|----------|------------------------------------------|

|             |                                                                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction performs the logical AND operation on the contents of the addressing object (word long) and the 16-bit immediate value (#N <sub>16</sub> ).<br><br>The result (16 bits) is stored in the addressing object. |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                                                                                                                                                                                                           |    |    |    |    |   |  |  |  |                                                                                                                                      |    |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------|----|--|
| Flags | Flags affected by execution:<br><br><table border="1" style="margin-left: 20px;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td></td> <td></td> </tr> </table> | ZF | CF | HC | DD | * |  |  |  | Flags affecting execution:<br><br><table border="1" style="margin-left: 20px;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | DD |  |
| ZF    | CF                                                                                                                                                                                                        | HC | DD |    |    |   |  |  |  |                                                                                                                                      |    |  |
| *     |                                                                                                                                                                                                           |    |    |    |    |   |  |  |  |                                                                                                                                      |    |  |
| DD    |                                                                                                                                                                                                           |    |    |    |    |   |  |  |  |                                                                                                                                      |    |  |
|       |                                                                                                                                                                                                           |    |    |    |    |   |  |  |  |                                                                                                                                      |    |  |

| o b j                 | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | D0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | D0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | D0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | D0              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | D0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | D0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**[NDB A, obj]**

8-bit logical AND

**obj**

#N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A<sub>L</sub> ← A<sub>L</sub> ∧ obj (byte long)

**Description**

This instruction performs the logical AND operation on the contents of the lower byte of the accumulator (A<sub>L</sub>) and the addressing object (byte long). The result (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>).

*This instruction is affected by the data descriptor (DD).*  
 For this instruction to be executed correctly, it is necessary to set DD=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
| 0  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | D6   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 58+N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2   | D2             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | D2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | D7   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | D2             |    |   |   | 6      | —   |
| [DP]                  | C2   | D2             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | D2             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | D2 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | D2 |   |   | 8      | 10  |

**ANDB obj, A**

8-bit logical AND

| <b>obj</b>            | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                             |                |                |    |    |   |        |     |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----|----|---|--------|-----|
| <b>Function</b>       | $\text{obj} \leftarrow \text{obj} \wedge A_L$ (byte long)                                                                                                                                                                                 |                |                |    |    |   |        |     |
| <b>Description</b>    | This instruction performs the logical AND operation on the contents of the lower byte of the accumulator (A <sub>L</sub> ) and the contents (byte long) of the addressing object. The result (8 bits) is stored in the addressing object. |                |                |    |    |   |        |     |
| <b>Flags</b>          | Flags affected by execution: Flags affecting execution:                                                                                                                                                                                   |                |                |    |    |   |        |     |
|                       | ZF                                                                                                                                                                                                                                        | CF             | HC             | DD | DD |   |        |     |
|                       | *                                                                                                                                                                                                                                         |                |                |    |    |   |        |     |
| <b>Codes/Cycles</b>   |                                                                                                                                                                                                                                           |                |                |    |    |   |        |     |
| obj                   | CODE                                                                                                                                                                                                                                      |                |                |    |    |   | CYCLES |     |
|                       | BYTE                                                                                                                                                                                                                                      |                |                |    |    |   | INT    | EXT |
|                       | 1                                                                                                                                                                                                                                         | 2              | 3              | 4  | 5  | 6 |        |     |
| A                     |                                                                                                                                                                                                                                           |                |                |    |    |   |        |     |
| #N <sub>8</sub>       |                                                                                                                                                                                                                                           |                |                |    |    |   |        |     |
| rN                    | 20+N                                                                                                                                                                                                                                      | D1             |                |    |    |   | 5 9    |     |
| PSWH                  | A2                                                                                                                                                                                                                                        | D1             |                |    |    |   | 5 —    |     |
| PSWL                  | A3                                                                                                                                                                                                                                        | D1             |                |    |    |   | 5 —    |     |
| off N <sub>8</sub>    | C4                                                                                                                                                                                                                                        | N <sub>8</sub> | D1             |    |    |   | 7 12   |     |
| N <sub>8</sub>        | C5                                                                                                                                                                                                                                        | N <sub>8</sub> | D1             |    |    |   | 7 —    |     |
| [DP]                  | C2                                                                                                                                                                                                                                        | D1             |                |    |    |   | 7 11   |     |
| ±N <sub>8</sub> [USP] | C3                                                                                                                                                                                                                                        | N <sub>8</sub> | D1             |    |    |   | 8 12   |     |
| N <sub>16</sub> [X1]  | C0                                                                                                                                                                                                                                        | N <sub>L</sub> | N <sub>H</sub> | D1 |    |   | 9 13   |     |
| N <sub>16</sub> [X2]  | C1                                                                                                                                                                                                                                        | N <sub>L</sub> | N <sub>H</sub> | D1 |    |   | 9 13   |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ANDB obj, off N<sub>8</sub>**

8-bit logical AND

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∧ off N<sub>8</sub> (byte long)

**Description**

This instruction performs the logical AND operation on the contents (byte long) of the addressing object and the data memory (off N<sub>8</sub>) specified by current page addressing.

The result (8 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |                |   | CYCLES |     |      |      | ← obj                |  |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|----------------------|--|
|                       | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |                      |  |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |                      |  |
| A                     |      |                |                |                |                |   |        |     |      |      |                      |  |
| #N <sub>8</sub>       |      |                |                |                |                |   |        |     |      |      |                      |  |
| rN                    | 20+N | D3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   | ← off N <sub>8</sub> |  |
| PSWH                  | A2   | D3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |                      |  |
| PSWL                  | A3   | D3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |                      |  |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | D3             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |                      |  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | D3             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |                      |  |
| [DP]                  | C2   | D3             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |                      |  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | D3             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |                      |  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | D3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |                      |  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | D3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |                      |  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ANDB obj, #N<sub>8</sub>**

8-bit logical AND

**obj**

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∧ N<sub>8</sub> (byte long)

**Description**

This instruction performs the logical AND operation on the contents (byte long) of the addressing object and the 8-bit long immediate value (#N<sub>8</sub>).

The result (8 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                      | BYTE |                |                |                |                |   | INT    | EXT |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                    |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |
| rN                   | 20+N | D0             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                 | A2   | D0             | N <sub>8</sub> |                |                |   | 5      | —   |
| PSWL                 | A3   | D0             | N <sub>8</sub> |                |                |   | 5      | —   |
| off N'8              | C4   | N'8            | D0             | N <sub>8</sub> |                |   | 8      | 14  |
| N'8                  | C5   | N'8            | D0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                 | C2   | D0             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N'8[USP]            | C3   | N'8            | D0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | D0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | D0             | N <sub>8</sub> |   | 10     | 15  |

## Chapter 3 Details of Instructions

### Instruction Set

#### BRK

Break (system reset)

obj

#### Function

SYSTEM RESET  
PC ← (Vector Table 0002H)

#### Description

The CPU, upon decoding this instruction, executes the system reset process whose specific details are given in the user's manual of the MSM66301.

Following the completion of the system reset, the contents of addresses 2 and 3 of the vector-table are transferred to the PC.

#### Flags

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

#### Codes/Cycles

| obj | CODE |   |   |   |   |   | CYCLES |  |
|-----|------|---|---|---|---|---|--------|--|
|     | BYTE |   |   |   |   |   |        |  |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |  |
|     | FF   |   |   |   |   |   | 13     |  |

### Chapter 3 Details of Instructions Instruction Set

#### CAL address

16-bit Space (64K bytes) Direct Call

**obj**

#### Function

(SSP)  $\leftarrow$  PC + 3  
SSP  $\leftarrow$  SSP - 2  
SF  $\leftarrow$  0  
PC  $\leftarrow$  address (16 bits)

#### Description

This is the direct call instruction for accessing the 64K byte program space. The address (in the instruction) is evaluated as a 16-bit address value (0000<sub>H</sub> through FFFF<sub>H</sub>) and becomes the address to be accessed by the CAL instruction.

#### Flags

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

#### Codes/Cycles

| obj | CODE |                  |                  |   |   |   | CYCLES |     |
|-----|------|------------------|------------------|---|---|---|--------|-----|
|     | BYTE |                  |                  |   |   |   | INT    | EXT |
|     | 1    | 2                | 3                | 4 | 5 | 6 |        |     |
|     | 32   | adr <sub>L</sub> | adr <sub>H</sub> |   |   |   | 9      | 13  |

[NOTE] adr<sub>L</sub> and adr<sub>H</sub> indicate the lower 8 and upper 8 bits respectively.

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CAL obj**

16-bit Space (64K byte) Indirect Call

**obj**

[erN], [DP], [X1], [X2], [USP], [SSP], [LRB], [off N<sub>H</sub>], [N<sub>L</sub>], [[DP]], [ $\pm$ N<sub>H</sub>[USP]], [N<sub>16</sub>[X1]], [N<sub>16</sub>[X2]]

**Function**

(SSP)  $\leftarrow$  PC + n  
 SSP  $\leftarrow$  SSP - 2  
 SF  $\leftarrow$  0  
 PC  $\leftarrow$  obj (16 bits)

[NOTE] "n" indicates the number of the bytes for this instruction and it is affected by the addressing object. For the number of the bytes, n, refer to the section "CODES".

**Description**

This is the 16-bit (64K byte) space indirect call instruction, where the contents of the addressing object determine the destination address. The obj term in the function is generally enclosed in square brackets ([ ]) as shown in the obj section. The value inside the square brackets is the word long contents of the RAM that is addressed. The same contents of the RAM become the final address called.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                           | CODE |                |                |    |   |   | CYCLES |     |     |     |
|-------------------------------|------|----------------|----------------|----|---|---|--------|-----|-----|-----|
|                               | BYTE |                |                |    |   |   | INT    | EXT | INT | EXT |
|                               | 1    | 2              | 3              | 4  | 5 | 6 |        |     |     |     |
| A                             |      |                |                |    |   |   |        |     |     |     |
| #N <sub>16</sub>              |      |                |                |    |   |   |        |     |     |     |
| [erN]                         | 44+N | 23             |                |    |   |   | 8      | 12  | 12  | 16  |
| [DP]                          | 92   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [X1]                          | 90   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [X2]                          | 91   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [USP]                         | A1   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [SSP]                         | A0   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [LRB]                         | A4   | 23             |                |    |   |   | 8      | 12  | —   | —   |
| [off N <sub>H</sub> ]         | B4   | N <sub>H</sub> | 23             |    |   |   | 10     | 14  | 15  | 19  |
| [N <sub>L</sub> ]             | B5   | N <sub>L</sub> | 23             |    |   |   | 10     | 14  | —   | —   |
| [DPI]                         | B2   | 23             | N <sub>H</sub> |    |   |   | 10     | 14  | 14  | 18  |
| [ $\pm$ N <sub>H</sub> [USP]] | B3   | N <sub>L</sub> | 23             |    |   |   | 11     | 15  | 15  | 19  |
| [N <sub>16</sub> [X1]]        | B0   | N <sub>L</sub> | N <sub>H</sub> | 23 |   |   | 12     | 16  | 16  | 20  |
| [N <sub>16</sub> [X2]]        | B1   | N <sub>L</sub> | N <sub>H</sub> | 23 |   |   | 12     | 16  | 16  | 20  |

$\leftarrow$  obj

$\leftarrow$  (SSP)

## Chapter 3 Details of Instructions Instruction Set

### CLR A

16-bit Clear

**obj**

**Function**

$A \leftarrow 0$  (word long)  
 $DD \leftarrow 1$

**Description**

This word long instruction clears the accumulator.

*This instruction sets the data descriptor (DD), making DD=1.*

This instruction functions identically to the instruction [L A, #0], including the effects on the flags. However, this instruction incurs comparatively fewer numbers of bytes and cycles.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| 1  |    |    | 1  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A   | F9   |   |   |   |   |   | 2      | —   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CLR obj**

16-bit Clear

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← 0 (word long)

**Description**

This word long instruction clears the addressing object.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 15             |                |    |   |   | 4      | 12  |
| DP                    | 92   | 15             |                |    |   |   | 4      | —   |
| X1                    | 90   | 15             |                |    |   |   | 4      | —   |
| X2                    | 91   | 15             |                |    |   |   | 4      | —   |
| USP                   | A1   | 15             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 15             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 15             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 15             |    |   |   | 6      | 15  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 15             |    |   |   | 6      | —   |
| [DP]                  | B2   | 15             |                |    |   |   | 6      | 14  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 15             |    |   |   | 7      | 15  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 15 |   |   | 8      | 16  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 15 |   |   | 8      | 16  |

## Chapter 3 Details of Instructions Instruction Set

### CLRB A

8-bit Clear

**obj**

**Function**

$A_L \leftarrow 0$  (byte long)

**Description**

This instruction clears the lower byte of the accumulator ( $A_L$ ), setting all 8 bits equal to 0.

*This instruction resets the data descriptor, making DD=0.*

This instruction functions identically to the instruction [LB A, #0] including the effects on the flags. However, this instruction incurs comparatively fewer numbers of bytes and cycles.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| 1  |    |    | 0  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A   | FA   |   |   |   |   |   | 2      | —   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CLRB obj**

8-bit Clear

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← 0 (byte long)

**Description**

This byte long instruction clears the addressing object, making all bits equal to 0.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 15             |                |    |   |   | 4      | 8   |
| PSWH                  | A2   | 15             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 15             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 15             |    |   |   | 6      | 11  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 15             |    |   |   | 6      | —   |
| [DP]                  | C2   | 15             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 15             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 15 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 15 |   |   | 8      | 12  |

### Chapter 3 Details of Instructions Instruction Set

#### **CMP A, obj**

16-bit Compare

|                                                                  |                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |
|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|--|--|
| <b>obj</b>                                                       | #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                        |    |    |    |    |   |   |  |  |
| <b>Function</b>                                                  | A - obj (word long)                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |    |   |   |  |  |
| <b>Description</b>                                               | This instruction compares the contents of the accumulator to the addressing object in a word long operation. In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator, and the result of this subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the accumulator are unchanged. |    |    |    |    |   |   |  |  |
| <i>This instruction is affected by the data descriptor (DD).</i> |                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |
|                                                                  | For the instruction to be executed correctly, it is necessary to set DD=1.                                                                                                                                                                                                                                                                                                              |    |    |    |    |   |   |  |  |
| <b>Flags</b>                                                     | Flags affected by execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td>*</td><td>*</td><td></td><td></td></tr></table>                                                                                                                                                               | ZF | CF | HC | DD | * | * |  |  |
| ZF                                                               | CF                                                                                                                                                                                                                                                                                                                                                                                      | HC | DD |    |    |   |   |  |  |
| *                                                                | *                                                                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |   |   |  |  |
|                                                                  | Flags affecting execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>DD</td></tr><tr><td>1</td></tr></table>                                                                                                                                                                                                                              | DD | 1  |    |    |   |   |  |  |
| DD                                                               |                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |
| 1                                                                |                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |

#### **Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | C6   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 48+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | C2             |                |    |   |   | 4      | —   |
| X1                    | 90   | C2             |                |    |   |   | 4      | —   |
| X2                    | 91   | C2             |                |    |   |   | 4      | —   |
| USP                   | A1   | C2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | C2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | C2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C7   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | C2             |    |   |   | 6      | —   |
| [DP]                  | B2   | C2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | C2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | C2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | C2 |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMP obj, A**

16-bit Compare

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj - A (word long)

**Description**

This instruction compares the contents of the addressing object to the accumulator in a word long operation.

In the actual operation, the contents of the accumulator are subtracted from the contents of the addressing object and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | C1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | C1             |                |    |   |   | 5      | —   |
| X1                    | 90   | C1             |                |    |   |   | 5      | —   |
| X2                    | 91   | C1             |                |    |   |   | 5      | —   |
| USP                   | A1   | C1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | C1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | C1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | C1             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | C1             |    |   |   | 7      | —   |
| [DP]                  | B2   | C1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | C1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | C1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | C1 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**CMP obj, off N<sub>8</sub>**

16-bit Compare

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |  |    |    |    |    |   |   |  |  |    |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|--|----|----|----|----|---|---|--|--|----|--|
| <b>obj</b>         | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N' <sub>8</sub> , [DP], ±N' <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                                                                             |    |    |  |    |    |    |    |   |   |  |  |    |  |
| <b>Function</b>    | obj - off N <sub>8</sub> (word long)                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |  |    |    |    |    |   |   |  |  |    |  |
| <b>Description</b> | <p>This instruction compares the contents of the addressing object to the data memory specified by current page addressing (off N<sub>8</sub>) in a word long operation.</p> <p>In the actual operation, the contents of the data memory specified by the current page addressing are subtracted from the contents of the addressing object and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the addressing object are unchanged.</p> |    |    |  |    |    |    |    |   |   |  |  |    |  |
| <b>Flags</b>       | <p>Flags affected by execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td>*</td><td></td><td></td></tr> </table> <p>Flags affecting execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table>                                                                                                               |    |    |  | ZF | CF | HC | DD | * | * |  |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | HC | DD |  |    |    |    |    |   |   |  |  |    |  |
| *                  | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |  |    |    |    |    |   |   |  |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |  |    |    |    |    |   |   |  |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |  |    |    |    |    |   |   |  |  |    |  |

**Codes/Cycles**

| obj                    | CODE |                 |                |                |                |   | CYCLES |      |      |      |
|------------------------|------|-----------------|----------------|----------------|----------------|---|--------|------|------|------|
|                        | BYTE |                 |                |                |                |   | INT    | INT  | EX T | EX T |
|                        | 1    | 2               | 3              | 4              | 5              | 6 | INT    | EX T | INT  | EX T |
| A                      |      |                 |                |                |                |   |        |      |      |      |
| #N <sub>16</sub>       |      |                 |                |                |                |   |        |      |      |      |
| erN                    | 44+N | C3              | N <sub>8</sub> |                |                |   | 7      | —    | —    | 20   |
| DP                     | 92   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| X1                     | 90   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| X2                     | 91   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| USP                    | A1   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| SSP                    | A0   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| LRB                    | A4   | C3              | N <sub>8</sub> |                |                |   | 7      | 16   | —    | —    |
| off N <sub>8</sub>     | B4   | N' <sub>8</sub> | C3             | N <sub>8</sub> |                |   | 9      | —    | —    | 23   |
| N' <sub>8</sub>        | B5   | N' <sub>8</sub> | C3             | N <sub>8</sub> |                |   | 9      | 18   | —    | —    |
| [DP]                   | B2   | C3              | N <sub>8</sub> |                |                |   | 9      | 18   | 13   | 22   |
| ±N' <sub>8</sub> [USP] | B3   | N' <sub>8</sub> | C3             | N <sub>8</sub> |                |   | 10     | 19   | 14   | 23   |
| N <sub>16</sub> [X1]   | B0   | N <sub>L</sub>  | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 20   | 15   | 24   |
| N <sub>16</sub> [X2]   | B1   | N <sub>L</sub>  | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 20   | 15   | 24   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMP obj, #N<sub>16</sub>**

16-bit Compare

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'<sub>16</sub>[X1], N'<sub>16</sub>[X2]

**Function**

obj - #N<sub>16</sub> (word long)

**Description**

This instruction compares the contents of the addressing object (word long) to the 16-bit immediate value (#N<sub>16</sub>).

In the actual operation, the 16 bit immediate value is subtracted from the contents of the addressing object, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the addressing object are unchanged.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | C0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | C0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | C0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | C0              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N' <sub>16</sub> [X1] | B0   | N' <sub>L</sub> | N' <sub>H</sub> | C0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N' <sub>16</sub> [X2] | B1   | N' <sub>L</sub> | N' <sub>H</sub> | C0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

### Chapter 3 Details of Instructions Instruction Set

---

**CMPB A, obj**

8-bit Compare

**obj**

 #N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

 A<sub>L</sub> - obj (byte long)

**Description**

This instruction compares the contents of the lower byte of the accumulator (A<sub>L</sub>) to the addressing object (byte long).

In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator lower byte. The result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the accumulator are unchanged.

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | C6   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 48+N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2   | C2             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | C2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C7   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | C2             |    |   |   | 6      | —   |
| [DP]                  | C2   | C2             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | C2             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | C2 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | C2 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMPB obj, A**

8-bit Compare

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |   |   |  |  |    |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|--|--|----|--|
| <b>obj</b>         | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |   |   |  |  |    |  |
| <b>Function</b>    | obj - A <sub>L</sub> (byte long)                                                                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |   |   |  |  |    |  |
| <b>Description</b> | <p>This instruction compares the contents (byte long) of the addressing object to the lower byte of the accumulator (A<sub>L</sub>).</p> <p>In the actual operation, the contents of the lower byte of the accumulator are subtracted from the contents of the addressing object, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the addressing object are unchanged.</p> |    |    |    |    |    |   |   |  |  |    |  |
| <b>Flags</b>       | <p>Flags affected by execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td></td> <td></td> </tr> </table> <p>Flags affecting execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table>                                           |    | ZF | CF | HC | DD | * | * |  |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                                                                                | HC | DD |    |    |    |   |   |  |  |    |  |
| *                  | *                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |   |  |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |   |   |  |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |   |   |  |  |    |  |

---

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | C1             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | C1             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | C1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | C1             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | C1             |    |   |   | 7      | —   |
| [DP]                  | C2   | C1             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | C1             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | C1 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | C1 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMPB obj, off N<sub>8</sub>**

8-bit Compare

|     |                                                                                           |
|-----|-------------------------------------------------------------------------------------------|
| obj | rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-------------------------------------------------------------------------------------------|

|          |                                      |
|----------|--------------------------------------|
| Function | obj - off N <sub>8</sub> (byte long) |
|----------|--------------------------------------|

|             |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction compares the contents of the addressing object to the data memory specified by the current page addressing (off N <sub>8</sub> ).<br><br>In the actual operation, the contents of the data memory specified by current page addressing are subtracted from the contents of the addressing object, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|
| Flags | Flags affected by execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td>*</td><td>*</td><td></td><td></td></tr></table> | ZF | CF | HC | DD | * | * |  |  | Flags affecting execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>DD</td></tr><tr><td></td></tr></table> | DD |  |
| ZF    | CF                                                                                                                                                                                                                        | HC | DD |    |    |   |   |  |  |                                                                                                                                                           |    |  |
| *     | *                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
| DD    |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
|       |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |

| o b j                | CODE |                |                |                |                |   | CYCLES |      |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|------|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT  | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 | INT    | EX T | INT  | EX T |
| A                    |      |                |                |                |                |   |        |      |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |      |      |      |
| rN                   | 20+N | C3             | N <sub>8</sub> |                |                |   | 7      | —    | —    | 14   |
| PSWH                 | A2   | C3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| PSWL                 | A3   | C3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| off N'8              | C4   | N'8            | C3             | N <sub>8</sub> |                |   | 9      | —    | —    | 17   |
| N'8                  | C5   | N'8            | C3             | N <sub>8</sub> |                |   | 9      | 14   | —    | —    |
| [DP]                 | C2   | C3             | N <sub>8</sub> |                |                |   | 9      | 14   | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | C3             | N <sub>8</sub> |                |   | 10     | 15   | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |

← obj  
← off N<sub>8</sub>

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMPB obj, off N<sub>8</sub>**

8-bit Compare

|     |                                                                                           |
|-----|-------------------------------------------------------------------------------------------|
| obj | rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-------------------------------------------------------------------------------------------|

|          |                                      |
|----------|--------------------------------------|
| Function | obj - off N <sub>8</sub> (byte long) |
|----------|--------------------------------------|

|             |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction compares the contents of the addressing object to the data memory specified by the current page addressing (off N <sub>8</sub> ).<br><br>In the actual operation, the contents of the data memory specified by current page addressing are subtracted from the contents of the addressing object, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|
| Flags | Flags affected by execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td>*</td><td>*</td><td></td><td></td></tr></table> | ZF | CF | HC | DD | * | * |  |  | Flags affecting execution:<br><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>DD</td></tr><tr><td></td></tr></table> | DD |  |
| ZF    | CF                                                                                                                                                                                                                        | HC | DD |    |    |   |   |  |  |                                                                                                                                                           |    |  |
| *     | *                                                                                                                                                                                                                         |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
| DD    |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |
|       |                                                                                                                                                                                                                           |    |    |    |    |   |   |  |  |                                                                                                                                                           |    |  |

| o b j                | CODE |                |                |                |                |   | CYCLES |      |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|------|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT  | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 | INT    | EX T | INT  | EX T |
| A                    |      |                |                |                |                |   |        |      |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |      |      |      |
| rN                   | 20+N | C3             | N <sub>8</sub> |                |                |   | 7      | —    | —    | 14   |
| PSWH                 | A2   | C3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| PSWL                 | A3   | C3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| off N'8              | C4   | N'8            | C3             | N <sub>8</sub> |                |   | 9      | —    | —    | 17   |
| N'8                  | C5   | N'8            | C3             | N <sub>8</sub> |                |   | 9      | 14   | —    | —    |
| [DP]                 | C2   | C3             | N <sub>8</sub> |                |                |   | 9      | 14   | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | C3             | N <sub>8</sub> |                |   | 10     | 15   | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | C3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |

← obj  
← off N<sub>8</sub>

**Chapter 3 Details of Instructions**  
**Instruction Set**

**CMPB obj, #N<sub>8</sub>**

8-bit Compare

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj - #N<sub>8</sub> (byte long)

**Description**

This instruction compares the contents of the addressing object (byte long) to the 8-bit immediate value (#N<sub>8</sub>).

In the actual operation, the 8-bit immediate value is subtracted from the contents of the addressing object, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the addressing object are unchanged.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |                |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                       | BYTE |                |                |                |                |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                     |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>       |      |                |                |                |                |   |        |     |
| rN                    | 20+N | C0             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                  | A2   | C0             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                  | A3   | C0             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | C0             | N <sub>8</sub> |                |   | 8      | 14  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | C0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                  | C2   | C0             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | C0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | C0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | C0             | N <sub>8</sub> |   | 10     | 15  |

### Chapter 3 Details of Instructions Instruction Set

---

**CMPC A, N<sup>16</sup>**

16-bit ROM Compare (direct)

**obj**
**Function**

 A - N<sup>16</sup> (word long)

**Description**

This instruction compares the contents (N<sup>16</sup>) of the ROM<sup>1</sup> specified by direct addressing to the accumulator in a word long operation.

In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator, and the result of the subtraction determines the status of the zero flag (ZF) and the carry flag (CF). The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |    |                |                |   |   | CYCLES |     |
|-----|------|----|----------------|----------------|---|---|--------|-----|
|     | BYTE |    |                |                |   |   | INT    | EXT |
|     | 1    | 2  | 3              | 4              | 5 | 6 |        |     |
|     | 90   | 9E | N <sup>L</sup> | N <sup>H</sup> |   |   | 15     | 15  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMPC A, obj**

16-bit ROM Compare (indirect)

**obj**

[erN], [DP], [X1], [X2], [USP], [SSP], [LRB], [off N<sub>B</sub>], [N<sub>B</sub>], [[DP]], [ $\pm$ N<sub>B</sub>[USP]], [N<sub>16</sub>[X1]], [N<sub>16</sub>[X2]]

**Function**

A - obj (word long)

**Description**

This instruction compares the contents of the addressing object (word long) in the ROM<sup>1</sup> space to the accumulator.

In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator, and the result of the subtraction sets the Zero (ZF) and Carry (CF) flags at 0 or 1. The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                           | CODE |                |                |    |   |   | CYCLES |     |      |      |
|-------------------------------|------|----------------|----------------|----|---|---|--------|-----|------|------|
|                               | BYTE |                |                |    |   |   | INT    | INT | EX T | EX T |
|                               | 1    | 2              | 3              | 4  | 5 | 6 |        |     |      |      |
| [erN]                         | 44+N | AC             |                |    |   |   | 11     | 15  | 11   | 15   |
| [DP]                          | 92   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [X1]                          | 90   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [X2]                          | 91   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [USP]                         | A1   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [SSP]                         | A0   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [LRB]                         | A4   | AC             |                |    |   |   | 11     | —   | 11   | —    |
| [off N <sub>B</sub> ]         | B4   | N <sub>B</sub> | AC             |    |   |   | 13     | 18  | 11   | 18   |
| [N <sub>B</sub> ]             | B5   | N <sub>B</sub> | AC             |    |   |   | 13     | —   | 13   | —    |
| [[DP]]                        | B2   | AC             |                |    |   |   | 13     | 17  | 13   | 17   |
| [ $\pm$ N <sub>B</sub> [USP]] | B3   | N <sub>B</sub> | AC             |    |   |   | 14     | 18  | 14   | 18   |
| [N <sub>16</sub> [X1]]        | B0   | N <sub>L</sub> | N <sub>H</sub> | AC |   |   | 15     | 19  | 15   | 19   |
| [N <sub>16</sub> [X2]]        | B1   | N <sub>L</sub> | N <sub>H</sub> | AC |   |   | 15     | 19  | 15   | 19   |

← ROM

← RAM

### Chapter 3 Details of Instructions Instruction Set

---

**CMPC A, obj**

16-bit ROM Compare (indirect with 16-bit base)

|            |  |
|------------|--|
| <b>obj</b> |  |
|------------|--|

 N<sup>16</sup>[DP], N<sup>16</sup>[X1], N<sup>16</sup>[X2], N<sup>16</sup>[USP], N<sup>16</sup>[off N<sub>8</sub>], N<sup>16</sup>[N<sub>8</sub>]

|                 |  |
|-----------------|--|
| <b>Function</b> |  |
|-----------------|--|

A - obj (word long)

|                    |  |
|--------------------|--|
| <b>Description</b> |  |
|--------------------|--|

This instruction compares the contents of the addressing object in the ROM<sup>1</sup> space (word long) to the accumulator.

In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator, and the result of the subtraction sets the zero flag (ZF) and the carry flag (CF) at 0 or 1. The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

|              |  |
|--------------|--|
| <b>Flags</b> |  |
|--------------|--|

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

|                     |  |
|---------------------|--|
| <b>Codes/Cycles</b> |  |
|---------------------|--|

| obj                                   | CODE |                |                     |                     |                     |   | CYCLES |     |      |      | ← ROM |  |
|---------------------------------------|------|----------------|---------------------|---------------------|---------------------|---|--------|-----|------|------|-------|--|
|                                       | BYTE |                |                     |                     |                     |   | INT    | INT | EX T | EX T |       |  |
|                                       | 1    | 2              | 3                   | 4                   | 5                   | 6 |        |     |      |      |       |  |
| N <sup>16</sup> [DP]                  | 92   | AD             | N <sup>16</sup> [L] | N <sup>16</sup> [H] |                     |   | 15     | —   | 15   | —    | ← RAM |  |
| N <sup>16</sup> [X1]                  | 90   | AD             | N <sup>16</sup> [L] | N <sup>16</sup> [H] |                     |   | 15     | —   | 15   | —    |       |  |
| N <sup>16</sup> [X2]                  | 91   | AD             | N <sup>16</sup> [L] | N <sup>16</sup> [H] |                     |   | 15     | —   | 15   | —    |       |  |
| N <sup>16</sup> [USP]                 | A1   | AD             | N <sup>16</sup> [L] | N <sup>16</sup> [H] |                     |   | 15     | —   | 15   | —    |       |  |
| N <sup>16</sup> [off N <sub>8</sub> ] | B4   | N <sub>8</sub> | AD                  | N <sup>16</sup> [L] | N <sup>16</sup> [H] |   | 17     | 22  | 17   | 22   |       |  |
| N <sup>16</sup> [N <sub>8</sub> ]     | B5   | N <sub>8</sub> | AD                  | N <sup>16</sup> [L] | N <sup>16</sup> [H] |   | 17     | —   | 17   | —    |       |  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**CMPCB A, N<sup>\*16</sup>**

8-bit ROM Compare (direct)

**obj**

**Function**

A<sub>L</sub> - N<sup>\*16</sup> (byte long)

**Description**

This instruction compares the contents (N<sup>\*16</sup>) of the ROM<sup>1</sup> specified by direct addressing to the lower byte of the accumulator (A<sub>L</sub>) in a byte long operation.

In the actual operation, the contents of the addressing object are subtracted from the contents of the accumulator, and the result of the subtraction sets the zero flag (ZF) and the carry flag (CF) at 0 or 1. The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |    |                 |                 |   |   | CYCLES |     |
|-----|------|----|-----------------|-----------------|---|---|--------|-----|
|     | BYTE |    |                 |                 |   |   | INT    | EXT |
|     | 1    | 2  | 3               | 4               | 5 | 6 |        |     |
|     | 90   | 9F | N <sup>*L</sup> | N <sup>*H</sup> |   |   | 13     | 13  |

### Chapter 3 Details of Instructions Instruction Set

---

**CMPCB A, obj**

8-bit ROM Compare (indirect)

|            |                                                                                                                                                                                |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> | [erN], [DP], [X1], [X2], [USP], [SSP], [LRB], [off N <sub>B</sub> ], [N <sub>E</sub> ], [[DP]], [ $\pm$ N <sub>B</sub> [USP]], [N <sub>16</sub> [X1]], [N <sub>16</sub> [X2]]] |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|                 |                                  |
|-----------------|----------------------------------|
| <b>Function</b> | A <sub>L</sub> - obj (byte long) |
|-----------------|----------------------------------|

|                    |                                                                                                                                                                   |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction compares the contents of the addressing object in the ROM <sup>1</sup> space (byte long) to the lower byte of the accumulator (A <sub>L</sub> ). |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|

In the actual operation, the contents of the addressing object are subtracted, in a byte long operation, from the contents of the accumulator, and the result of the subtraction sets the zero flag (ZF) and the carry flag (CF) at 0 or 1. The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

|              |                              |                            |
|--------------|------------------------------|----------------------------|
| <b>Flags</b> | Flags affected by execution: | Flags affecting execution: |
|              | ZF CF HC DD<br>• •           | DD<br>                     |

| obj                           | CODE |                |                |    |   |   | CYCLES |      |      |      | ← ROM |
|-------------------------------|------|----------------|----------------|----|---|---|--------|------|------|------|-------|
|                               | BYTE |                |                |    |   |   | INT    | INT  | EX T | EX T |       |
|                               | 1    | 2              | 3              | 4  | 5 | 6 | INT    | EX T | INT  | EX T |       |
| [erN]                         | 44+N | AE             |                |    |   |   | 9      | 11   | 9    | 11   | ← ROM |
| [DP]                          | 92   | AE             |                |    |   |   | 9      | —    | 9    | —    | ← RAM |
| [X1]                          | 90   | AE             |                |    |   |   | 9      | —    | 9    | —    |       |
| [X2]                          | 91   | AE             |                |    |   |   | 9      | —    | 9    | —    |       |
| [USP]                         | A1   | AE             |                |    |   |   | 9      | —    | 9    | —    |       |
| [SSP]                         | A0   | AE             |                |    |   |   | 9      | —    | 9    | —    |       |
| [LRB]                         | A4   | AE             |                |    |   |   | 9      | —    | 9    | —    |       |
| [off N <sub>B</sub> ]         | B4   | N <sub>B</sub> | AE             |    |   |   | 11     | 16   | 11   | 16   |       |
| [N <sub>E</sub> ]             | B5   | N <sub>B</sub> | AE             |    |   |   | 11     | —    | 11   | —    |       |
| [[DP]]                        | B2   | AE             |                |    |   |   | 11     | 15   | 11   | 15   |       |
| [ $\pm$ N <sub>B</sub> [USP]] | B3   | N <sub>B</sub> | AE             |    |   |   | 12     | 16   | 12   | 16   |       |
| [N <sub>16</sub> [X1]]        | B0   | N <sub>L</sub> | N <sub>H</sub> | AE |   |   | 13     | 17   | 13   | 17   |       |
| [N <sub>16</sub> [X2]]        | B1   | N <sub>L</sub> | N <sub>H</sub> | AE |   |   | 13     | 17   | 13   | 17   |       |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### CMPCB A, obj

8-bit ROM Compare (indirect with 16-bit base)

**obj**

N<sup>16</sup>[DP], N<sup>16</sup>[X1], N<sup>16</sup>[X2], N<sup>16</sup>[USP], N<sup>16</sup>[off N<sub>8</sub>], N<sup>16</sup>[N<sub>8</sub>]

**Function**

A<sub>L</sub> - obj (byte long)

**Description**

This instruction compares the contents (byte long) of the addressing object in the ROM<sup>1</sup> space and the contents of the lower byte of the accumulator (A<sub>L</sub>).

In the actual operation, the contents of the addressing object are subtracted, in a byte long operation, from the contents of the lower byte of the accumulator, and the result of the subtraction sets the zero flag (ZF) and the carry flag (CF) at 0 or 1. The contents of the accumulator are unchanged.

[NOTE] <sup>1</sup> The ROM used means the program memory in the program space. The on-chip memory is always the ROM; however, the external memory, if used, may possibly include ROM, RAM, and the I/O units allocated to the program space.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                                   | CODE |                |                  |                  |                  |   | CYCLES |     |      |      |
|---------------------------------------|------|----------------|------------------|------------------|------------------|---|--------|-----|------|------|
|                                       | BYTE |                |                  |                  |                  |   | INT    | INT | EX T | EX T |
|                                       | 1    | 2              | 3                | 4                | 5                | 6 |        |     |      |      |
| N <sup>16</sup> [DP]                  | 92   | AF             | N <sup>8</sup> L | N <sup>8</sup> H |                  |   | 13     | —   | 13   | —    |
| N <sup>16</sup> [X1]                  | 90   | AF             | N <sup>8</sup> L | N <sup>8</sup> H |                  |   | 13     | —   | 13   | —    |
| N <sup>16</sup> [X2]                  | 91   | AF             | N <sup>8</sup> L | N <sup>8</sup> H |                  |   | 13     | —   | 13   | —    |
| N <sup>16</sup> [USP]                 | A1   | AF             | N <sup>8</sup> L | N <sup>8</sup> H |                  |   | 13     | —   | 13   | —    |
| N <sup>16</sup> [off N <sub>8</sub> ] | B4   | N <sub>8</sub> | AF               | N <sup>8</sup> L | N <sup>8</sup> H |   | 17     | 22  | 17   | 22   |
| N <sup>16</sup> [N <sub>8</sub> ]     | B5   | N <sub>8</sub> | AF               | N <sup>8</sup> L | N <sup>8</sup> H |   | 17     | —   | 17   | —    |

← ROM

← RAM

### Chapter 3 Details of Instructions Instruction Set

#### DAA

8-bit Decimal Adjustment for Addition

obj

#### Function

IF  $(A_{L3-0} \geq 10)$  OR  $(HC = 1)$  THEN  $A_L \leftarrow A_L + 6$   
IF  $(A_{L7-4} \geq 10)$  OR  $(C=1)$  THEN  $A_{L7-4} \leftarrow A_{L7-4} + 6$

#### Description

This instruction adjusts the 8-bit value in the lower byte of the accumulator ( $A_L$ ) resulting from an earlier binary addition of 2-byte long BCD codes, producing packed BCD codes. Following the execution of the adjusting instruction, when a carry from the lower nibble to the upper nibble occurs, the half carry (HC) is set to 1. Furthermore, when a carry occurs from a digit to the adjacent higher digit, the carry (C) is set to 1; such carries come from the upper nibble during the decimal adjusting manipulation or from the execution of the add instruction prior to the decimal adjustment.

It should be noted that this instruction is based on the following three premises. Two (byte long) BCD codes are added by using one of the byte long add instructions (ADDB, ADCB). The result of the addition is stored in the lower byte of the accumulator. The contents of the half carry and the carry maintain the status which existed at the end of the adding operation until the following adjustment operation revises the status. Below the actual process encountered in this (adjustment) instruction is described.

1. At first, the lower nibble ( $A_{L3-0}$ ) of the accumulator is adjusted by adding 6 if either the lower nibble of the accumulator is more than 9 ( $0A_{H}$ — $0F_{H}$ ), or the half carry (HC) is equal to 1. This adding operation is a byte long operation, and when the addition causes an overflow from bit 3 to bit 4 of the accumulator, the half carry is set to 1 while the overflow from bit 7 sets the carry to 1.

When the lower nibble of the accumulator does not exceed 9 and also the half carry (HC), prior to the execution of the adjust instruction, is 0, then no adjustment operation is applied to the lower nibble.

2. Secondly, the adjustment of the upper nibble ( $A_{L7-4}$ ) of the accumulator begins by adding 6 to the upper nibble if either the upper nibble of the accumulator is more than 9 ( $0A_{H}$  through  $0F_{H}$ ), or the carry is 1, which may have existed either before or after the adding operation of step 1. The status of the half carry at this moment remains unaltered from the status which existed during the process of step 1. The overflow from bit 7, if it exists, sets the carry to 1.

When the upper nibble of the accumulator does not exceed 9 and also the carry is 0 before and after the operation of step 1, then no adjustment operation is applied to the upper nibble.

#### Flags

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    | *  | *  |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### Codes/Cycles

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 93   |   |   |   |   |   | 6      | —   |

#### Examples

The execution process for this instruction is described below, where  $A_L$  and  $r0$  are the BCD codes.

ADDB A, r0  
DAA

[Example 1] 87 + 95



ADDB A, r0

The BCD codes for decimal numbers 87 and 95 are respectively  $A_L$  and  $r0$ , and they are added using ADDB A, r0.

The results of the addition are that  $1C_H$  is stored in  $A_L$ , and C is set to 1 because of the overflow from the bit 7. There is no overflow from bit 3 and H is set to 0.



DAA

Decimal adjustment is performed by the DAA instruction. At first, the lower nibble of  $A_L$  is more than 9, and therefore 6 is added to the lower nibble. As a result,  $A_L$  becomes  $22_H$ , and the carry from bit 3 sets H to 1. C is 1 prior to the execution of the instruction; therefore, 6 is added to the upper nibble and  $A_L$  becomes  $82_H$ , and C remains at 1 (as it was at the beginning) following the execution of the instruction. Finally, the BCD code for the decimal number 82 remains in  $A_L$ , and the carry to the next higher digit is set in C.



## Chapter 3 Details of Instructions Instruction Set

---

[Example 2]  $69 + 38$



A<sub>L</sub> and r0 represent the BCD codes for decimal numbers 69 and 38 respectively which are added by the ADDB A, r0 instruction.

**ADDB A, r0**

As a result of the addition, A1<sub>H</sub> is stored in A<sub>L</sub>, and C is set to 0 because of no overflow from the bit 7. The carry from bit 3 sets the H to 0.



**DAA**

Decimal adjustment is performed by the DAA instruction.

At first, 6 is added to A<sub>L</sub> because H=1. A<sub>L</sub> becomes A7<sub>H</sub> and there is no carry from bit 3, hence H is set to 0.

The upper nibble of A<sub>L</sub> is more than 9, therefore 6 is added to the upper nibble of A<sub>L</sub> making A<sub>L</sub> 07<sub>H</sub>. C is set to 1 because of the overflow from the upper nibble adjustment. Finally, the contents of A<sub>L</sub> show the BCD code for the decimal number 07 and the carry to the next higher digit is indicated by C=1.



## Chapter 3 Details of Instructions

### Instruction Set

---

#### DAS

8-bit Decimal Adjustment for Subtraction

**obj**

**Function**

```
IF (AL3-0 ≥ 10) OR (HC = 1) THEN AL ← AL
-6
IF (AL7-4 ≥ 10) OR (C=1) THEN AL7-4 ← AL7-4 - 6
HC ← 0
```

**Description**

This instruction adjusts the 8-bit value in the lower byte of the accumulator (AL) resulting from the earlier binary subtraction of 2-byte long BCD codes, producing packed BCD codes.

It should be noted that this instruction is based on the following three premises. Two (byte long) BCD code are subtracted by using one of the byte long subtract instruction (SUBB, SUCB). The result of the subtraction is stored in the lower byte of the accumulator. The contents of the half carry and the carry maintains the status which existed at the end of the subtracting operation until the following adjustment operation revises the status.

The following is the actual process encountered in this (adjustment) instruction.

1. At first, the lower nibble (AL3-0) of the accumulator is augmented by subtracting 6 from the lower nibble of the accumulator if the half carry (HC) is equal to 1. When the half carry (HC), prior to the execution of the augment instruction, is 0, then no adjustment operation is applied to the lower nibble.
2. Secondly, the adjustment of the upper nibble (AL7-4) of the accumulator begins by subtracting 6 from the upper nibble of the accumulator if the carry (C) is 1. When the carry (C) is 0, then no adjustment operation is applied to the lower nibble.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 94   |   |   |   |   |   | 6      | —   |

## Chapter 3 Details of Instructions Instruction Set

### Examples

The execution process of this instruction is shown using the following case in which  $A_L$  and  $r0$  are the BCD codes.

SUBB A, r0 (or SBCB A, r0)  
DAS

[Example 1] 87 - 95



The BCD codes for decimal numbers 87 and 95 are respectively  $A_L$  and  $r0$  and they are subtracted using SUBB A, r0.



As a result of the subtraction, F2 is stored in  $A_L$  and C is set to 1 because of the borrow from bit 7.  
There is no borrow from bit 3 and H is set to 0.



Decimal adjustment is performed by the DAS instruction. Initially, since H=0, the lower nibble is not adjusted. Since C=1, 6 is subtracted from the upper nibble of  $A_L$ , and  $A_L$  becomes 92H.  
C maintains the status that exists prior to the execution of the augment instruction, namely C=1.  
Finally, the BCD code for the decimal number 92 stays in  $A_L$  and the borrow from the next higher digit is indicated by C=1.

## Chapter 3 Details of Instructions

### Instruction Set

[Example 2] 99 - 99 with the borrow from the preceding step.



SUBB A, r0



DAS

Both AL and r0 are the BCD code for the decimal number 99 and the C is set to 1 indicating a borrow has occurred in the preceding step. Now the subtract instruction, SBCB A, r0, is executed.

The result of the subtraction, FF<sub>H</sub> is stored in AL. C is set to 1 because of the borrow from the bit 7. H is set to 1 because of the borrow from the bit 3.

The decimal adjustment is performed by the DAS instruction.

At first, since H=1, 6 is subtracted from the lower nibble of AL.

Since C=1, 6 is subtracted from the upper nibble of AL and AL becomes 99H.

The C has been 1 prior to the execution of the adjustment instruction, and remains 1. Finally, the BCD code for the decimal number 99 stays in AL and the borrow from the next higher digit is indicated by C=1.



**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**DEC obj**

16-bit Decrement

**obj**      erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**      obj ← obj + 1 (word long)

**Description**      This instruction subtracts 1 from the contents of the addressing object (word long).

**Flags**      Flags affected by execution:      Flags affecting execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    | *  |    |

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 17             |                |    |   |   | 5      | 13  |
| DP                    | 82   |                |                |    |   |   | 3      | —   |
| X1                    | 80   |                |                |    |   |   | 3      | —   |
| X2                    | 81   |                |                |    |   |   | 3      | —   |
| USP                   | A1   | 17             |                |    |   |   | 5      | —   |
| SSP                   | A0   | 17             |                |    |   |   | 5      | —   |
| LRB                   | FE   |                |                |    |   |   | 3      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 17             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 17             |    |   |   | 7      | —   |
| [DP]                  | B2   | 17             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 17             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 17 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 17 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**DECB obj**

8-bit Decrement

|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |   |  |   |  |    |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|--|---|--|----|--|
| <b>obj</b>         | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                   |    |    |    |    |   |  |   |  |    |  |
| <b>Function</b>    | obj ← obj + 1 (byte long)                                                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |   |  |   |  |    |  |
| <b>Description</b> | This instruction subtracts 1 from the contents of the addressing object (byte long).                                                                                                                                                                                                                                                                                                            |    |    |    |    |   |  |   |  |    |  |
| <b>Flags</b>       | Flags affected by execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td>*</td> <td></td> </tr> </table> Flags affecting execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | ZF | CF | HC | DD | * |  | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                              | HC | DD |    |    |   |  |   |  |    |  |
| *                  |                                                                                                                                                                                                                                                                                                                                                                                                 | *  |    |    |    |   |  |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |   |  |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |   |  |   |  |    |  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | B8+N |                |                |    |   |   | 3      | 7   |
| PSWH                  | A2   | 17             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 17             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 17             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 17             |    |   |   | 7      | —   |
| [DP]                  | C2   | 17             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 17             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 17 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 17 |   |   | 9      | 13  |

## Chapter 3 Details of Instructions

### Instruction Set

#### DIV

16-bit Divide

**obj** \_\_\_\_\_

**Function** \_\_\_\_\_

$(er0, A) \leftarrow (er0, A) + er2$   
 $er1 \leftarrow (er0, A) \text{ MOD } er2$

**Description** \_\_\_\_\_

32 bits divided by 16 bits → 32 bits divide instruction

The 32-bit value (dividend), whose upper and lower 16 bits are given by the extended local register 0 (er0) and the accumulator respectively, is divided by the contents of the extended local register 2 (er2).

The results of the division are stored in three different locations. The upper 16 bits of the quotient is stored in the extended local register 0 (er0), the lower 16 bits of the quotient is stored in the accumulator, and the remainder (16bits) is stored in the extended local register 1 (er1).

[NOTE] When division by 0 is executed (i.e., er2 = 0), the quotient and the remainder become undetermined, and the carry flag is set to 1. In all other cases, the carry flag is set to 0.

#### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

#### Codes/Cycles

| obj | CODE |    |   |   |   |   | CYCLES |     |
|-----|------|----|---|---|---|---|--------|-----|
|     | BYTE |    |   |   |   |   | INT    | EXT |
|     | 1    | 2  | 3 | 4 | 5 | 6 |        |     |
| A   | 90   | 37 |   |   |   |   | 47     | 63  |

### Chapter 3 Details of Instructions

#### Instruction Set

---

##### DIVB

8-bit Divide

obj

Function

A  $\leftarrow$  A + r0  
r1  $\leftarrow$  A MOD r0

Description

16 bits divided by 8 bits  $\rightarrow$  16 bits Divide Instruction

The contents (16 bits) of the accumulator are divided by the contents (8 bits) of the local register 0 (r0), when this instruction is executed.

The result of the division are stored in two locations. The quotient (16 bits) is stored in the accumulator and the remainder (8 bits) is stored in the local register 1 (r1).

[NOTE] When the division by 0 is executed (i.e., er2 = 0), the quotient and the remainder become undetermined, and the carry flag is set to 1. In all other cases, the carry flag is set to 0.

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj | CODE |    |   |   |   |   | CYCLES |     |
|-----|------|----|---|---|---|---|--------|-----|
|     | BYTE |    |   |   |   |   | INT    | EXT |
|     | 1    | 2  | 3 | 4 | 5 | 6 |        |     |
| A   | A2   | 36 |   |   |   |   | 29     | 33  |

### Chapter 3 Details of Instructions

---

#### Instruction Set

---

**EXTND**

Signed Byte to Word Extend



 A<sub>15-8</sub> ← A<sub>7</sub>  
 DD ← 1

 Case where A<sub>7</sub> = 0

 Case where A<sub>7</sub> = 1

This instruction extends signed byte type data to signed word type data. The upper byte of the accumulator is filled with the highest bit (A<sub>7</sub>), which is the sign bit of the byte type data. At the same time, the data descriptor is set to 1 to indicate a word long operation.

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    | 1  |

Flags affecting execution:

| DD |
|----|
|    |

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | F8   |   |   |   |   |   | 2      | —   |

### Chapter 3 Details of Instructions

#### Instruction Set

---

##### INC obj]

16-bit Increment

|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|--|---|--|----|--|
| <b>obj</b>         | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                   |    |    |    |    |    |   |  |   |  |    |  |
| <b>Function</b>    | $\text{obj} \leftarrow \text{obj} + 1$ (word long)                                                                                                                                                                                                                                                                                                                                              |    |    |    |    |    |   |  |   |  |    |  |
| <b>Description</b> | This instruction adds 1 to the contents of the addressing object (word long). If LRB is the addressing object in any addressing mode, ZF will not be affected.                                                                                                                                                                                                                                  |    |    |    |    |    |   |  |   |  |    |  |
| <b>Flags</b>       | Flags affected by execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td>*</td> <td></td> </tr> </table> Flags affecting execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> |    | ZF | CF | HC | DD | * |  | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                              | HC | DD |    |    |    |   |  |   |  |    |  |
| *                  |                                                                                                                                                                                                                                                                                                                                                                                                 | *  |    |    |    |    |   |  |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 16             |                |    |   |   | 5      | 13  |
| DP                    | 72   |                |                |    |   |   | 3      | —   |
| X1                    | 70   |                |                |    |   |   | 3      | —   |
| X2                    | 71   |                |                |    |   |   | 3      | —   |
| USP                   | A1   | 16             |                |    |   |   | 5      | —   |
| SSP                   | A0   | 16             |                |    |   |   | 5      | —   |
| LRB                   | FD   |                |                |    |   |   | 3      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 16             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 16             |    |   |   | 7      | —   |
| [DP]                  | B2   | 16             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 16             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 17  |

### Chapter 3 Details of Instructions

#### Instruction Set

---

##### INC obj]

16-bit Increment

|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|--|---|--|----|--|
| <b>obj</b>         | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                   |    |    |    |    |    |   |  |   |  |    |  |
| <b>Function</b>    | $\text{obj} \leftarrow \text{obj} + 1$ (word long)                                                                                                                                                                                                                                                                                                                                              |    |    |    |    |    |   |  |   |  |    |  |
| <b>Description</b> | This instruction adds 1 to the contents of the addressing object (word long). If LRB is the addressing object in any addressing mode, ZF will not be affected.                                                                                                                                                                                                                                  |    |    |    |    |    |   |  |   |  |    |  |
| <b>Flags</b>       | Flags affected by execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td>*</td> <td></td> </tr> </table> Flags affecting execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> |    | ZF | CF | HC | DD | * |  | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                              | HC | DD |    |    |    |   |  |   |  |    |  |
| *                  |                                                                                                                                                                                                                                                                                                                                                                                                 | *  |    |    |    |    |   |  |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |   |  |   |  |    |  |

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 16             |                |    |   |   | 5      | 13  |
| DP                    | 72   |                |                |    |   |   | 3      | —   |
| X1                    | 70   |                |                |    |   |   | 3      | —   |
| X2                    | 71   |                |                |    |   |   | 3      | —   |
| USP                   | A1   | 16             |                |    |   |   | 5      | —   |
| SSP                   | A0   | 16             |                |    |   |   | 5      | —   |
| LRB                   | FD   |                |                |    |   |   | 3      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 16             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 16             |    |   |   | 7      | —   |
| [DP]                  | B2   | 16             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 16             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**[INC obj]**

8-bit Increment

|     |                                                                                                                               |
|-----|-------------------------------------------------------------------------------------------------------------------------------|
| obj | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-------------------------------------------------------------------------------------------------------------------------------|

|          |                           |
|----------|---------------------------|
| Function | obj ← obj + 1 (byte long) |
|----------|---------------------------|

|             |                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction adds 1 to the contents of the addressing object (byte long). If LRB's upper bits are the addressing object in any addressing mode, ZF will not be affected. |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                                             |                                  |
|-------|---------------------------------------------|----------------------------------|
| Flags | Flags affected by execution:<br>ZF CF HC DD | Flags affecting execution:<br>DD |
|-------|---------------------------------------------|----------------------------------|

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | A8+N |                |                |    |   |   | 3      | 7   |
| PSWH                  | A2   | 16             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 16             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 16             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 16             |    |   |   | 7      | —   |
| [DP]                  | C2   | 16             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 16             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 16 |   |   | 9      | 13  |

## **Chapter 3 Details of Instructions**

### **Instruction Set**

**J address** 16-bit Space (64K byte) Direct Jump

obj

## **Function**

**PC**  $\leftarrow$  address (16 bits)

**Description**

This instruction performs a direct jump to the program (memory) space of 64K bytes. The address is specified by the 16 bit address value (0000<sub>H</sub> through FFFF<sub>H</sub>) that is the destination address of the jump.

## Flags

#### **Flags affected by execution:**

### **Flags affecting execution:**

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

DD

### **Codes/Cycles**

| obj | CODE |                  |                  |   |   |   | CYCLES |     |
|-----|------|------------------|------------------|---|---|---|--------|-----|
|     | BYTE |                  |                  |   |   |   | INT    | EXT |
|     | 1    | 2                | 3                | 4 | 5 | 6 |        |     |
|     | 03   | adr <sub>L</sub> | adr <sub>H</sub> |   |   |   | 7      | —   |

[NOTE]  $\text{adr}_L$  and  $\text{adr}_H$  are respectively the lower 8 bits and the upper 8 bits of the address.

### Chapter 3 Details of Instructions Instruction Set

---

**J obj**

16-bit Space (64K byte) Direct Jump

**obj**

[erN], [DP], [X1], [X2], [USP], [SSP], [LRB], [off N<sub>B</sub>], [N<sub>A</sub>], [[DP]], [ $\pm$ N<sub>B</sub>[USP]], [N<sub>16</sub>[X1]], [N<sub>16</sub>[X2]]

**Function**

PC  $\leftarrow$  obj (16 bits)

**Description**

This instruction performs an indirect jump to the 16 bit (64K byte) space where the destination is specified by the contents of the addressing object.

It should be noted that the obj in the preceding "Function" is expressed by enclosing the contents of the RAM addressing expression (word long) with brackets ([ ]), and the value is the 16-bit contents of the RAM which is the object of the addressing. In other words, the destination address of the jump is given by the 16-bit contents of the RAM which is addressed in the instruction.

[NOTE] This instruction may be easier to understand if it is thought of as a "MOV PC, obj" instruction with the brackets ([ ]) of the obj removed.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                           | CODE |                |                |    |   |   | CYCLES |     |
|-------------------------------|------|----------------|----------------|----|---|---|--------|-----|
|                               | BYTE |                |                |    |   |   | INT    | EXT |
|                               | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                             |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>              |      |                |                |    |   |   |        |     |
| [erN]                         | 44+N | 22             |                |    |   |   | 6      | 10  |
| [DP]                          | 92   | 22             |                |    |   |   | 6      | —   |
| [X1]                          | 90   | 22             |                |    |   |   | 6      | —   |
| [X2]                          | 91   | 22             |                |    |   |   | 6      | —   |
| [USP]                         | A1   | 22             |                |    |   |   | 6      | —   |
| [SSP]                         | A0   | 22             |                |    |   |   | 6      | —   |
| [LRB]                         | A4   | 22             |                |    |   |   | 6      | —   |
| [off N <sub>A</sub> ]         | B4   | N <sub>B</sub> | 22             |    |   |   | 8      | 13  |
| [N <sub>B</sub> ]             | B5   | N <sub>B</sub> | 22             |    |   |   | 8      | —   |
| [[DP]]                        | B2   | 22             |                |    |   |   | 8      | 12  |
| [ $\pm$ N <sub>B</sub> [USP]] | B3   | N <sub>B</sub> | 22             |    |   |   | 9      | 13  |
| [N <sub>16</sub> [X1]]        | B0   | N <sub>L</sub> | N <sub>H</sub> | 22 |   |   | 10     | 14  |
| [N <sub>16</sub> [X2]]        | B1   | N <sub>L</sub> | N <sub>H</sub> | 22 |   |   | 10     | 14  |

## Chapter 3 Details of Instructions

### Instruction Set

#### JBR off N<sub>8</sub>.bit, address

Jump if Bit Reset

**obj**

**Function**

IF (off N<sub>8</sub>.bit = 0) THEN PC ← address

where PC\* - 128 ≤ address ≤ PC\* + 127

PC\* = starting address of the instruction following the JBR instruction  
= (address of the first byte of the JBR instruction) + 3

**Description**

This instruction causes a jump if a specified bit of the data memory (off N<sub>8</sub>) that is the object of direct page addressing has a value of 0.

The location of the specified bit is given by the "bit" (0 through 7) in the instruction. The destination address of the jump is given by the "address" in the instruction. The range of the jump is from -128 to +127 with the address of the instruction that follows next serving as the origin.

[NOTE] This jump instruction manipulates the PC based on the displacement. However, in the source program of the assembler (RAS6K), the destination address of the jump specified as a label and not as a displacement, is entered as the operand of the instruction. The assembler figures out the amount of the displacement, which, if it stays within the allowable range, is used to generate the machine codes. If the amount of the displacement is outside of the allowable range, the assembler issues an error warning.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |                |     |   |   |   | CYCLES |     |     |     |
|-----|------|----------------|-----|---|---|---|--------|-----|-----|-----|
|     | BYTE |                |     |   |   |   | INT    | INT | EXT | EXT |
|     | 1    | 2              | 3   | 4 | 5 | 6 | INT    | EXT | INT | EXT |
|     | D8+n | N <sub>8</sub> | N's |   |   |   | 10     | 6   | 13  | 9   |

← obj  
← off N<sub>8</sub>

[NOTE] 1. N<sub>8</sub>'s is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as 2's complement.

[EXAMPLE]

| Displacement | N <sub>8</sub> 's     |
|--------------|-----------------------|
| 0            | 00000000 <sub>8</sub> |
| +1           | 00000001 <sub>8</sub> |
| +127         | 01111111 <sub>8</sub> |
| -1           | 11111111 <sub>8</sub> |
| -127         | 10000001 <sub>8</sub> |
| -128         | 10000000 <sub>8</sub> |

2. n is determined from the value of the "bit", and ranges from 0 to 7.

## Chapter 3 Details of Instructions

### Instruction Set

---

#### JBS off N<sub>8</sub>.bit, address

Jump if Bit Set

|     |  |
|-----|--|
| obj |  |
|-----|--|

|          |  |
|----------|--|
| Function |  |
|----------|--|

IF (off N<sub>8</sub>.bit = 1) THEN PC ← address

where PC\* - 128 ≤ address ≤ PC\* + 127

PC\* = starting address of the instruction following the JBS instruction  
= (address of the first byte of the JBS instruction) + 3

|             |  |
|-------------|--|
| Description |  |
|-------------|--|

This instruction causes a jump if a specified bit of the data memory (off N<sub>8</sub>) that is the object of direct page addressing has a value of 1.

The location of the specified bit is given by the "bit" (0 through 7) in the instruction. The destination address of the jump is given by the "address" in the instruction. The range of the jump is from -128 to +127 with the address of the instruction that follows next serving as the origin.

[NOTE] This jump instruction manipulates the PC based on the displacement. However, in the source program of the assembler (RAS66K), the destination address of the jump specified as a label and not as a displacement, is entered as the operand of the instruction. The assembler figures out the amount of the displacement, which, if it stays within the allowable range, is used to generate the machine codes. If the amount of the displacement is outside of the allowable range, the assembler issues an error warning.

|       |  |
|-------|--|
| Flags |  |
|-------|--|

Flags affected by execution:

| ZF | CF | Hc | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj | CODE |                |                 |   |   |   | CYCLES |     |     |     |
|-----|------|----------------|-----------------|---|---|---|--------|-----|-----|-----|
|     | BYTE |                |                 |   |   |   | INT    | INT | EXT | EXT |
|     | 1    | 2              | 3               | 4 | 5 | 6 | INT    | EXT | INT | EXT |
|     | E8+n | N <sub>8</sub> | N' <sub>8</sub> |   |   |   | 10     | 6   | 13  | 9   |

← off N<sub>8</sub>  
← off N'<sub>8</sub>.bit

[NOTE] 1. N'<sub>8</sub> is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as 2's complement.

[EXAMPLE]

| Displacement | N' <sub>8</sub> |
|--------------|-----------------|
| 0            | 00000000B       |
| +1           | 00000001B       |
| +127         | 01111111B       |
| -1           | 11111111B       |
| -127         | 10000001B       |
| -128         | 10000000B       |

2. n is determined from the value of the "bit", and ranges from 0 to 7.

**Chapter 3 DIRECTIVES OR INSTRUCTIONS**  
**Instruction Set**

**JC condition, address**

Conditional Jump

**obj**

**Function**

IF condition is true THEN PC ← address

where  $PC^* - 128 \leq \text{address} \leq PC^* + 127$

$PC^*$  = starting address of the instruction following the JC instruction  
= (address of the first byte of the JC instruction) + 2

**Description**

This instruction causes a jump to the address specified by the second operand "address" in the instruction, if the first operand condition\* is true.

The range of the jump is from -128 to +127 with the origin at the address of the instruction that follows next.

The truth of the conditions is defined by the zero flag (ZF) and/or the carry flag (CF) as described in the following table, which also lists the symbols for the conditions. The conditions and the terms that must be fulfilled for the conditions to be true are shown in the following table.

| Symbols for Conditions | Terms to be fulfilled for condition to be true |   |                  |
|------------------------|------------------------------------------------|---|------------------|
|                        | Flag                                           |   | Logical meaning  |
| EQ                     | Z = 1                                          | = | Equal            |
| NE                     | Z = 0                                          | ≠ | Not Equal        |
| LT                     | C = 1                                          | < | Less Than        |
| LE                     | Z = 1 or C = 1                                 | ≤ | Less or Equal    |
| GT                     | Z = 0 or C = 0                                 | > | Greater Than     |
| GE                     | C = 0                                          | ≥ | Greater or Equal |

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HG | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| CONDITION | CODE |    |   |   |   |   | CYCLES |       |
|-----------|------|----|---|---|---|---|--------|-------|
|           | BYTE |    |   |   |   |   | TRUE   | FALSE |
|           | 1    | 2  | 3 | 4 | 5 | 6 |        |       |
| EQ        | C9   | N8 |   |   |   |   | 8      | 4     |
| NE        | CE   | N8 |   |   |   |   | 8      | 4     |
| LT        | CA   | N8 |   |   |   |   | 8      | 4     |
| LE        | CF   | N8 |   |   |   |   | 8      | 4     |
| GT        | C8   | N8 |   |   |   |   | 8      | 4     |
| GE        | CD   | N8 |   |   |   |   | 8      | 4     |

[NOTE] N8 is the code for the displacement. See the following section, "Displacement."

## Chapter 3 Details of Instructions Instruction Set

### Displacement

$N_8$

In the above table,  $N_8$  is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as 2's complement.

| [EXAMPLE] | Displacement | $N_8$                 |
|-----------|--------------|-----------------------|
| 0         | 00000000     | 00000000 <sub>8</sub> |
| +1        | 00000001     | 00000001 <sub>8</sub> |
| +127      | 01111111     | 01111111 <sub>8</sub> |
| -1        | 11111111     | 11111111 <sub>8</sub> |
| -127      | 10000001     | 10000001 <sub>8</sub> |
| -128      | 10000000     | 10000000 <sub>8</sub> |

### Caution for entering address

This jump instruction manipulates the PC based on the displacement; however, in the source program of the assembler (RAS66K), the destination address of the jump specified as a label and not as a displacement, is entered as the operand of the instruction. The assembler figures out the amount of the displacement, which, if it stays within the allowable range, is used to generate the machine codes. If the amount of the displacement is outside of the range, the assembler issues an error warning.

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**JRNZ DP, address**

Loop

**obj**

**Function**

$DPL \leftarrow DPL - 1$   
IF  $DPL \neq 0$  THEN  $PC \leftarrow \text{address}$

where  $PC^* - 128 \leq \text{address} \leq PC^* + 127$   
 $PC^*$  = starting address of the instruction following the JRNZ instruction  
= (address of the first byte of the JRNZ instruction) + 2

**Description**

This instruction performs a jump to the address specified by the second operand "address" in the instruction if the content of the lower byte of the data pointer ( $DPL$ ) decremented by 1 is not 0. This instruction permits implementing a simple loop process for counting the lower byte of the data pointer. The range of the jump is from -128 to +127 with the address of the instruction that follows next serving as the origin.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |       |   |   |   |   | CYCLES       |           |
|-----|------|-------|---|---|---|---|--------------|-----------|
|     | BYTE |       |   |   |   |   | $DPL \neq 0$ | $DPL = 0$ |
|     | 1    | 2     | 3 | 4 | 5 | 6 | (jump)       | (no jump) |
|     | 30   | $N_g$ |   |   |   |   | 11           | 7         |

[NOTE]  $N_g$  is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as 2's complement.

[EXAMPLE]

| Displacement | $N_g$                 |
|--------------|-----------------------|
| 0            | 00000000 <sub>8</sub> |
| +1           | 00000001 <sub>8</sub> |
| +127         | 01111111 <sub>8</sub> |
| -1           | 11111111 <sub>8</sub> |
| -127         | 10000001 <sub>8</sub> |
| -128         | 10000000 <sub>8</sub> |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**L A, obj]**

16-bit Load

**obj**

#N<sub>16</sub>, erN, DP, X1, X2, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ← obj (word long)  
DD ← 1

**Description**

This instruction transfers the contents of the addressing object (word long) to the accumulator.

*This instruction sets the data descriptor to 1.*

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    | 1  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |   |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|---|---|---|--------|-----|
|                       | BYTE |                |                |   |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4 | 5 | 6 |        |     |
| A                     |      |                |                |   |   |   |        |     |
| #N <sub>16</sub>      | 67   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | —   |
| erN                   | 34+N |                |                |   |   |   | 2      | 6   |
| DP                    | 42   |                |                |   |   |   | 2      | —   |
| X1                    | 40   |                |                |   |   |   | 2      | —   |
| X2                    | 41   |                |                |   |   |   | 2      | —   |
| USP                   |      |                |                |   |   |   |        |     |
| SSP                   |      |                |                |   |   |   |        |     |
| LRB                   |      |                |                |   |   |   |        |     |
| off N <sub>8</sub>    | E4   | N <sub>8</sub> |                |   |   |   | 4      | 9   |
| N <sub>8</sub>        | E5   | N <sub>8</sub> |                |   |   |   | 4      | —   |
| [DP]                  | E2   |                |                |   |   |   | 4      | 8   |
| ±N <sub>8</sub> [USP] | E3   | N <sub>8</sub> |                |   |   |   | 5      | 9   |
| N <sub>16</sub> [X1]  | E0   | N <sub>L</sub> |                |   |   |   | 6      | 10  |
| N <sub>16</sub> [X2]  | E1   | N <sub>L</sub> |                |   |   |   | 6      | 10  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### LB A, obj

8-bit Load

**obj**

#N<sub>8</sub>, rN, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A<sub>L</sub> ← obj (byte long)  
DD ← 0

**Description**

This instruction transfers the contents of the addressing object (byte long) to the lower byte (A<sub>L</sub>) of the accumulator.

*This instruction sets the data descriptor (DD) to 0.*

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    | 0  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |   |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|---|---|---|--------|-----|
|                       | BYTE |                |                |   |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4 | 5 | 6 |        |     |
| A                     |      |                |                |   |   |   |        |     |
| #N <sub>8</sub>       | 77   | N <sub>8</sub> |                |   |   |   | 4      | —   |
| rN                    | 78+N |                |                |   |   |   | 2      | 4   |
| PSWH                  |      |                |                |   |   |   |        |     |
| PSWL                  |      |                |                |   |   |   |        |     |
| off N <sub>8</sub>    | F4   | N <sub>8</sub> |                |   |   |   | 4      | 7   |
| N <sub>8</sub>        | F5   | N <sub>8</sub> |                |   |   |   | 4      | —   |
| [DP]                  | F2   |                |                |   |   |   | 4      | 6   |
| ±N <sub>8</sub> [USP] | F3   | N <sub>8</sub> |                |   |   |   | 5      | 7   |
| N <sub>16</sub> [X1]  | F0   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 8   |
| N <sub>16</sub> [X2]  | F1   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 8   |

### Chapter 3 Details of Instructions Instruction Set

#### LC A, N<sup>\*16</sup>

16-bit Load ROM Reference (direct)

**obj** \_\_\_\_\_

**Function** \_\_\_\_\_

A ← N<sup>\*16</sup> (word long)

**Description** \_\_\_\_\_

This instruction transfers the contents (N<sup>\*16</sup>) of the ROM<sup>1</sup> specified by direct addressing to the accumulator in word long operation.

[NOTE]<sup>1</sup> ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

**Flags** \_\_\_\_\_

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles** \_\_\_\_\_

| obj | CODE |    |                 |                 |   |   | CYCLES |     |
|-----|------|----|-----------------|-----------------|---|---|--------|-----|
|     | BYTE |    |                 |                 |   |   | INT    | EXT |
|     | 1    | 2  | 3               | 4               | 5 | 6 |        |     |
|     | 90   | 9C | N <sup>*L</sup> | N <sup>*H</sup> |   |   | 15     | 15  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### LC A, obj

16-bit Load ROM Reference (indirect)

##### obj

[erN], [DP], [X1], [X2], [USP], [SSP], [LRB], [off N<sub>8</sub>], [N<sub>8</sub>], [[DP]], [ $\pm$ N<sub>8</sub>[USP]], [N<sub>16</sub>[X1]], [N<sub>16</sub>[X2]]

##### Function

A  $\leftarrow$  obj (word long)

##### Description

This instruction transfers the contents of the addressing object (word long) in the ROM<sup>1</sup> space to the accumulator.

[NOTE]<sup>1</sup> ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

##### Codes/Cycles

| obj                           | CODE |                |                |    |   |   | CYCLES |     |     |     |
|-------------------------------|------|----------------|----------------|----|---|---|--------|-----|-----|-----|
|                               | BYTE |                |                |    |   |   | INT    | INT | EXT | EXT |
|                               | 1    | 2              | 3              | 4  | 5 | 6 | INT    | EXT | INT | EXT |
| [erN]                         | 44+N | A8             |                |    |   |   | 11     | 15  | 11  | 15  |
| [DP]                          | 92   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [X1]                          | 90   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [X2]                          | 91   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [USP]                         | A1   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [SSP]                         | A0   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [LRB]                         | A4   | A8             |                |    |   |   | 11     | —   | 11  | —   |
| [off N <sub>8</sub> ]         | B4   | N <sub>8</sub> | A8             |    |   |   | 13     | 18  | 13  | 18  |
| [N <sub>8</sub> ]             | B5   | N <sub>8</sub> | A8             |    |   |   | 13     | —   | 13  | —   |
| [[DP]]                        | B2   | A8             |                |    |   |   | 13     | 17  | 13  | 17  |
| [ $\pm$ N <sub>8</sub> [USP]] | B3   | N <sub>8</sub> | A8             |    |   |   | 14     | 18  | 14  | 18  |
| [N <sub>16</sub> [X1]]        | B0   | N <sub>L</sub> | N <sub>H</sub> | A8 |   |   | 15     | 19  | 15  | 19  |
| [N <sub>16</sub> [X2]]        | B1   | N <sub>L</sub> | N <sub>H</sub> | A8 |   |   | 15     | 19  | 15  | 19  |

← ROM  
← RAM

## Chapter 3 Details of Instructions Instruction Set

---

**LC A, obj**

16-bit Load ROM Reference (indirect with 16-bit base)

|            |                                                                                           |
|------------|-------------------------------------------------------------------------------------------|
| <b>obj</b> | N°16[DP], N°16[X1], N°16[X2], N°16[USP], N°16[off N <sub>8</sub> ], N°16[N <sub>8</sub> ] |
|------------|-------------------------------------------------------------------------------------------|

|                 |                     |
|-----------------|---------------------|
| <b>Function</b> | A ← obj (word long) |
|-----------------|---------------------|

|                    |                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction transfers the contents of the addressing object (word long) in the ROM <sup>1</sup> space to the accumulator. |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------|

**[NOTE]<sup>1</sup>** ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

|              |                              |                            |
|--------------|------------------------------|----------------------------|
| <b>Flags</b> | Flags affected by execution: | Flags affecting execution: |
|--------------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

| DD |
|----|
|    |

|                     |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Codes/Cycles</b> |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|

| obj                       | CODE |                |     |     |     |   | CYCLES |     |     |     | ← ROM |
|---------------------------|------|----------------|-----|-----|-----|---|--------|-----|-----|-----|-------|
|                           | BYTE |                |     |     |     |   | INT    | INT | EXT | EXT |       |
|                           | 1    | 2              | 3   | 4   | 5   | 6 | INT    | EXT | INT | EXT |       |
| N°16[DP]                  | 92   | A9             | N°L | N°H |     |   | 15     | —   | 15  | —   | ← ROM |
| N°16[X1]                  | 90   | A9             | N°L | N°H |     |   | 15     | —   | 15  | —   | ← RAM |
| N°16[X2]                  | 91   | A9             | N°L | N°H |     |   | 15     | —   | 15  | —   |       |
| N°16[USP]                 | A1   | A9             | N°L | N°H |     |   | 15     | —   | 15  | —   |       |
| N°16[off N <sub>8</sub> ] | B4   | N <sub>8</sub> | A9  | N°L | N°H |   | 17     | 22  | 17  | 22  |       |
| N°16[N <sub>8</sub> ]     | B5   | N <sub>8</sub> | A9  | N°L | N°H |   | 17     | —   | 17  | —   |       |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**LCB A, N<sup>16</sup>**

8-bit Load ROM Reference (direct)

**obj**

**Function**

$A_L \leftarrow N^{16}$  (byte long)

**Description**

This instruction transfers the contents ( $N^{16}$ ) of the ROM<sup>1</sup> specified by direct addressing to the lower byte ( $A_L$ ) of the accumulator in a byte long operation.

[NOTE]<sup>1</sup> ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |    |                |                |   |   | CYCLES |     |
|-----|------|----|----------------|----------------|---|---|--------|-----|
|     | BYTE |    |                |                |   |   | INT    | EXT |
|     | 1    | 2  | 3              | 4              | 5 | 6 |        |     |
|     | 90   | 9D | N <sup>L</sup> | N <sup>H</sup> |   |   | 13     | 13  |

### Chapter 3 Details of Instructions Instruction Set

#### **LCB A, obj**

8-bit Load ROM Reference (indirect)

|            |                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> |                                                                                                                                               |
|            | [erN], [DP], [X1], [X2], [off N <sub>B</sub> ], [N <sub>B</sub> ], [[DP]], [ $\pm N_B$ [USP]], [N <sub>16</sub> [X1]], [N <sub>16</sub> [X2]] |

|                 |                                  |
|-----------------|----------------------------------|
| <b>Function</b> |                                  |
|                 | $A_L \leftarrow obj$ (byte long) |

|                    |                                                                                                                                                            |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> |                                                                                                                                                            |
|                    | This instruction transfers the contents of the addressing object (byte long) in the ROM <sup>1</sup> space to the lower byte ( $A_L$ ) of the accumulator. |

**[NOTE]<sup>1</sup>** ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

|              |                                                                                                                                                                                                   |    |    |    |    |   |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|--|--|--|
| <b>Flags</b> |                                                                                                                                                                                                   |    |    |    |    |   |  |  |  |
|              | Flags affected by execution:                                                                                                                                                                      |    |    |    |    |   |  |  |  |
|              | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td></td> <td></td> </tr> </table> | ZF | CF | HC | DD | * |  |  |  |
| ZF           | CF                                                                                                                                                                                                | HC | DD |    |    |   |  |  |  |
| *            |                                                                                                                                                                                                   |    |    |    |    |   |  |  |  |

Flags affecting execution:

|    |
|----|
| DD |
|    |

|                     |  |
|---------------------|--|
| <b>Codes/Cycles</b> |  |
|                     |  |

| obj                    | CODE |                |                |    |   |   | CYCLES |      |      |      |
|------------------------|------|----------------|----------------|----|---|---|--------|------|------|------|
|                        | BYTE |                |                |    |   |   | INT    | INT  | EX T | EX T |
|                        | 1    | 2              | 3              | 4  | 5 | 6 | INT    | EX T | INT  | EX T |
| [erN]                  | 44+N | AA             |                |    |   |   | 9      | 11   | 9    | 11   |
| [DP]                   | 92   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [X1]                   | 90   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [X2]                   | 91   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [USP]                  | A1   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [SSP]                  | A0   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [LRB]                  | A4   | AA             |                |    |   |   | 9      | —    | 9    | —    |
| [off N <sub>B</sub> ]  | B4   | N <sub>B</sub> | AA             |    |   |   | 11     | 16   | 11   | 16   |
| [N <sub>B</sub> ]      | B5   | N <sub>B</sub> | AA             |    |   |   | 11     | —    | 11   | —    |
| [[DP]]                 | B2   | AA             |                |    |   |   | 11     | 15   | 11   | 15   |
| [ $\pm N_B$ [USP]]     | B3   | N <sub>B</sub> | AA             |    |   |   | 12     | 16   | 12   | 16   |
| [N <sub>16</sub> [X1]] | B0   | N <sub>L</sub> | N <sub>H</sub> | AA |   |   | 13     | 17   | 13   | 17   |
| [N <sub>16</sub> [X2]] | B1   | N <sub>L</sub> | N <sub>H</sub> | AA |   |   | 13     | 17   | 13   | 17   |

← ROM

← RAM

## Chapter 3 Details of Instructions

### Instruction Set

#### LCB A, obj

8-bit Load ROM Reference (indirect with 16-bit base)

##### obj

N<sup>16</sup>[DP], N<sup>16</sup>[X1], N<sup>16</sup>[X2], N<sup>16</sup>[USP], N<sup>16</sup>[off N<sub>B</sub>], N<sup>16</sup>[N<sub>B</sub>]

##### Function

A<sub>L</sub> ← obj (byte long)

##### Description

This instruction transfers the contents of the addressing object (byte long) in the ROM<sup>1</sup> space to the lower byte (A<sub>L</sub>) of the accumulator.

**[NOTE]<sup>1</sup>** ROM as used here means the program memory in the program space. The on-chip memory is always considered ROM; however, the external memory, if used, may possibly include ROM, RAM, and I/O units allocated to the program space.

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

##### Codes/Cycles

| obj                                   | CODE |                |                              |                              |                              |   | CYCLES |     |     |     |
|---------------------------------------|------|----------------|------------------------------|------------------------------|------------------------------|---|--------|-----|-----|-----|
|                                       | BYTE |                |                              |                              |                              |   | INT    | INT | EXT | EXT |
|                                       | 1    | 2              | 3                            | 4                            | 5                            | 6 |        |     |     |     |
| N <sup>16</sup> [DP]                  | 92   | AB             | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |                              |   | 13     | —   | 13  | —   |
| N <sup>16</sup> [X1]                  | 90   | AB             | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |                              |   | 13     | —   | 13  | —   |
| N <sup>16</sup> [X2]                  | 91   | AB             | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |                              |   | 13     | —   | 13  | —   |
| N <sup>16</sup> [USP]                 | A1   | AB             | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |                              |   | 13     | —   | 13  | —   |
| N <sup>16</sup> [off N <sub>B</sub> ] | B4   | N <sub>B</sub> | AB                           | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |   | 17     | 22  | 17  | 22  |
| N <sup>16</sup> [N <sub>B</sub> ]     | B5   | N <sub>B</sub> | AB                           | N <sup>16</sup> <sub>L</sub> | N <sup>16</sup> <sub>H</sub> |   | 17     | —   | 17  | —   |

← ROM

← RAM

### Chapter 3 Details of Instructions Instruction Set

#### **MB C, obj.bit**

Move Bit (direct bit addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

C ← obj.bit

**Description**

This instruction transfers the contents of the specified bit of the operand "obj" (byte long) that is the addressing object in this instruction to the carry (C). The location of the bit is specified by the term "bit" whose value ranges from 0 to 7.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |      |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|------|---|---|--------|-----|
|                       | BYTE |                |                |      |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4    | 5 | 6 |        |     |
| A                     |      |                |                |      |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |      |   |   |        |     |
| rN                    | 20+N | 28+n           |                |      |   |   | 5      | 7   |
| PSWH                  | A2   | 28+n           |                |      |   |   | 5      | —   |
| PSWL                  | A3   | 28+n           |                |      |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 28+n           |      |   |   | 7      | 10  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 28+n           |      |   |   | 7      | —   |
| [DP]                  | C2   | 28+n           |                |      |   |   | 7      | 9   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 28+n           |      |   |   | 8      | 10  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 28+n |   |   | 9      | 11  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 28+n |   |   | 9      | 11  |

[NOTE] "n" is determined from the value of the "bit", and ranges from 0 to 7.

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MB obj.bit, C**

Move Bit (direct bit addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj.bit ← C

**Description**

This instruction transfers the contents of the carry (C) to the specified bit of the operand "obj" (byte long) that is the addressing object in this instruction. The location of the specified bit is given by the term "bit" in the instruction and its value ranges from 0 to 7.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |      |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|------|---|---|--------|-----|
|                       | BYTE |                |                |      |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4    | 5 | 6 |        |     |
| A                     |      |                |                |      |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |      |   |   |        |     |
| rN                    | 20+N | 38+n           |                |      |   |   | 10     | 16  |
| PSWH                  | A2   | 38+n           |                |      |   |   | 10     | —   |
| PSWL                  | A3   | 38+n           |                |      |   |   | 10     | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 38+n           |      |   |   | 12     | 19  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 38+n           |      |   |   | 12     | —   |
| [DP]                  | C2   | 38+n           |                |      |   |   | 12     | 18  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 38+n           |      |   |   | 13     | 19  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 38+n |   |   | 14     | 20  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 38+n |   |   | 14     | 20  |

[NOTE] "n" is determined from the value of the "bit", and ranges from 0 to 7.

### Chapter 3 Details of Instructions

---

#### Instruction Set

---

**MBR C, obj**

Move Bit (register indirect bit addressing)

**obj**

 rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

 C ← obj.bit (A<sub>2-0</sub>)

**Description**

This instruction transfers the contents of the specified bit of the operand "obj" (byte long) that is the addressing object in this instruction to the carry (C). The location of the bit is specified at the execution time of the instruction by the contents of the lower 3 bits (A<sub>2-0</sub>) of the accumulator.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 21             |                |    |   |   | 5      | 7   |
| PSWH                  | A2   | 21             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 21             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 21             |    |   |   | 7      | 10  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 21             |    |   |   | 7      | —   |
| [DP]                  | C2   | 21             |                |    |   |   | 7      | 9   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 21             |    |   |   | 8      | 10  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 21 |   |   | 9      | 11  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 21 |   |   | 9      | 11  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MBR obj, C**

Move Bit (register indirect bit addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj.bit (A<sub>2-0</sub>) ← C

**Description**

This instruction transfers the contents of the carry (C) to the specified bit of the operand "obj" (byte long) that is the addressing object in this instruction. The location of the bit is specified at the execution time of the instruction by the contents of the lower 3 bits (A<sub>2-0</sub>) of the accumulator.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| o b j                 | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 20             |                |    |   |   | 10     | 16  |
| PSWH                  | A2   | 20             |                |    |   |   | 10     | —   |
| PSWL                  | A3   | 20             |                |    |   |   | 10     | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 20             |    |   |   | 12     | 19  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 20             |    |   |   | 12     | —   |
| [DP]                  | C2   | 20             |                |    |   |   | 12     | 18  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 20             |    |   |   | 13     | 19  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 20 |   |   | 14     | 20  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 20 |   |   | 14     | 20  |

### Chapter 3 Details of Instructions Instruction Set

---

#### **MOV A, obj**

16-bit Move

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>B</sub>, N<sub>B</sub>, [DP], ±N<sub>B</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ← obj (word long)  
DD ← 1

**Description**

This instruction transfers the contents of the addressing object (word long) to the accumulator.

*This instruction sets the data descriptor (DD) to 1.*

Also, this instruction functionally overlaps part of the "L A, obj" instruction. This instruction differs from "L A, obj" instruction in that the execution of this instruction is not affected by the zero flag, and, also, this instruction incurs a comparatively large number of bytes and cycles.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    | 1  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 99             |                |    |   |   | 4      | 8   |
| DP                    | 92   | 99             |                |    |   |   | 4      | —   |
| X1                    | 90   | 99             |                |    |   |   | 4      | —   |
| X2                    | 91   | 99             |                |    |   |   | 4      | —   |
| USP                   | A1   | 99             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 99             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 99             |                |    |   |   | 4      | —   |
| off N <sub>B</sub>    | B4   | N <sub>B</sub> | 99             |    |   |   | 6      | 11  |
| N <sub>B</sub>        | B5   | N <sub>B</sub> | 99             |    |   |   | 6      | —   |
| [DP]                  | B2   | 99             |                |    |   |   | 6      | 10  |
| ±N <sub>B</sub> [USP] | B3   | N <sub>B</sub> | 99             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 99 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 99 |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV DP, obj**

16-bit Move

**obj**

A, #N<sub>16</sub>, erN, DP, X<sub>1</sub>, X<sub>2</sub>, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X<sub>1</sub>], N<sub>16</sub>[X<sub>2</sub>]

**Function**

DP ← obj (word long)

**Description**

This instruction transfers the contents of the addressing object (word long) to the data pointer.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                               | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------------------|------|----------------|----------------|----|---|---|--------|-----|
|                                   | BYTE |                |                |    |   |   | INT    | EXT |
|                                   | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                                 | 52   |                |                |    |   |   | 2      | —   |
| #N <sub>16</sub>                  | 62   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                               | 44+N | 7A             |                |    |   |   | 4      | 8   |
| DP                                | 92   | 7A             |                |    |   |   | 4      | —   |
| X <sub>1</sub>                    | 90   | 7A             |                |    |   |   | 4      | —   |
| X <sub>2</sub>                    | 91   | 7A             |                |    |   |   | 4      | —   |
| USP                               | A1   | 7A             |                |    |   |   | 4      | —   |
| SSP                               | A0   | 7A             |                |    |   |   | 4      | —   |
| LRB                               | A4   | 7A             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>                | B4   | N <sub>8</sub> | 7A             |    |   |   | 6      | 11  |
| N <sub>8</sub>                    | B5   | N <sub>8</sub> | 7A             |    |   |   | 6      | —   |
| [DP]                              | B2   | 7A             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP]             | B3   | N <sub>8</sub> | 7A             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X <sub>1</sub> ] | B0   | N <sub>L</sub> | N <sub>H</sub> | 7A |   |   | 8      | 12  |
| N <sub>16</sub> [X <sub>2</sub> ] | B1   | N <sub>L</sub> | N <sub>H</sub> | 7A |   |   | 8      | 12  |

---

### Chapter 3 Details of Instructions

#### Instruction Set

---

**MOV erN, obj**

16-bit Move

**obj** A, #N<sub>16</sub>, erN', DP, X<sub>1</sub>, X<sub>2</sub>, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X<sub>1</sub>], N<sub>16</sub>[X<sub>2</sub>]

**Function** erN ← obj (word long)

**Description** This instruction transfers the contents of the addressing object (word long) to the extended local register (erN).

**Flags** Flags affected by execution: Flags affecting execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

| DD |
|----|
|    |

**Codes/Cycles**

| obj                               | CODE  |                |                |                |   |   | CYCLES |     |      |      |
|-----------------------------------|-------|----------------|----------------|----------------|---|---|--------|-----|------|------|
|                                   | BYTE  |                |                |                |   |   | INT    | INT | EX T | EX T |
|                                   | 1     | 2              | 3              | 4              | 5 | 6 |        |     |      |      |
| A                                 | 44+N  | 8A             |                |                |   |   | 4      | —   | —    | 12   |
| #N <sub>16</sub>                  | 44+N  | 98             | N <sub>L</sub> | N <sub>H</sub> |   |   | 8      | —   | —    | 16   |
| erN'                              | 44+N' | 48+N           |                |                |   |   | 4      | —   | —    | 12   |
| DP                                | 92    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| X <sub>1</sub>                    | 90    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| X <sub>2</sub>                    | 91    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| USP                               | A1    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| SSP                               | A0    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| LRB                               | A4    | 48+N           |                |                |   |   | 4      | —   | 8    | —    |
| off N <sub>8</sub>                | B4    | N <sub>8</sub> | 48+N           |                |   |   | 6      | —   | —    | 15   |
| N <sub>8</sub>                    | B5    | N <sub>8</sub> | 48+N           |                |   |   | 6      | —   | 10   | —    |
| [DP]                              | B2    | 48+N           |                |                |   |   | 6      | 10  | 10   | 14   |
| ±N <sub>8</sub> [USP]             | B3    | N <sub>8</sub> | 48+N           |                |   |   | 7      | 11  | 11   | 15   |
| N <sub>16</sub> [X <sub>1</sub> ] | B0    | N <sub>L</sub> | N <sub>H</sub> | 48+N           |   |   | 8      | 12  | 12   | 16   |
| N <sub>16</sub> [X <sub>2</sub> ] | B1    | N <sub>L</sub> | N <sub>H</sub> | 48+N           |   |   | 8      | 12  | 12   | 16   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV LRB, obj]**

16-bit Move

**obj**

A, #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

LRB ← obj (word long)

**Description**

This instruction transfers the contents of the addressing object (word long) to the local register base (LRB).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     | A4   | 8A             |                |    |   |   | 4      | —   |
| #N <sub>16</sub>      | 57   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 44+N | 7F             |                |    |   |   | 4      | 8   |
| DP                    | 92   | 7F             |                |    |   |   | 4      | —   |
| X1                    | 90   | 7F             |                |    |   |   | 4      | —   |
| X2                    | 91   | 7F             |                |    |   |   | 4      | —   |
| USP                   | A1   | 7F             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 7F             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 7F             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 7F             |    |   |   | 6      | 11  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 7F             |    |   |   | 6      | —   |
| [DP]                  | B2   | 7F             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 7F             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 7F |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 7F |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### **MOV obj, A**

16-bit Move

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← A (word long)

**Description**

This instruction transfers the contents of the accumulator to the addressing object (word long).

This instruction functionally overlap the part of the "ST A, obj" instruction. This instruction differs from the "ST A, obj" instruction in that the execution of this instruction is not affected by the data descriptor (DD). On the other hand, the instruction "ST A, obj" incurs fewer bytes and cycles, hence the use of the "ST A, obj" is preferred because it results in better program efficiency.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 8A             |                |    |   |   | 4      | 12  |
| DP                    | 52   |                |                |    |   |   | 2      | —   |
| X1                    | 50   |                |                |    |   |   | 2      | —   |
| X2                    | 51   |                |                |    |   |   | 2      | —   |
| USP                   | A1   | 8A             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 8A             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 8A             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 8A             |    |   |   | 6      | 15  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 8A             |    |   |   | 6      | —   |
| [DP]                  | B2   | 8A             |                |    |   |   | 6      | 14  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 8A             |    |   |   | 7      | 15  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 8A |   |   | 8      | 16  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 8A |   |   | 8      | 16  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV obj, #N<sub>16</sub>**

16-bit Move

**obj** erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'16[X1], N'16[X2]

**Function** obj ← #N<sub>16</sub> (word long)

**Description** This instruction transfers the contents of the 16-bit immediate value (#N<sub>16</sub>) to the addressing object (word long).

**Flags** Flags affected by execution: Flags affecting execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | 98              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 16  |
| DP                    | 62   | N <sub>L</sub>  | N <sub>H</sub>  |                |                |                | 6      | —   |
| X1                    | 60   | N <sub>L</sub>  | N <sub>H</sub>  |                |                |                | 6      | —   |
| X2                    | 61   | N <sub>L</sub>  | N <sub>H</sub>  |                |                |                | 6      | —   |
| USP                   | A1   | 98              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | 98              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | 57   | N <sub>L</sub>  | N <sub>H</sub>  |                |                |                | 6      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | 98              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 19  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | 98              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | 98              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 18  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | 98              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 19  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | 98             | N <sub>L</sub> | N <sub>H</sub> | 12     | 20  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | 98             | N <sub>L</sub> | N <sub>H</sub> | 12     | 20  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV off N<sub>8</sub>, obj**

16-bit Move

|     |                                                                                                                                                                       |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| obj | A, #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N' <sub>8</sub> , [DP], ±N' <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|          |                                      |
|----------|--------------------------------------|
| Function | off N <sub>8</sub> ← obj (word long) |
|----------|--------------------------------------|

|             |                                                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction transfers the contents of the addressing object (word long) to the data memory (off N <sub>8</sub> ) specified by direct page addressing. |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                              |                            |
|-------|------------------------------|----------------------------|
| Flags | Flags affected by execution: | Flags affecting execution: |
|-------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

| DD |
|----|
|    |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                    | CODE |                 |                |                |                |   | CYCLES |     |      |      |
|------------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                        | BYTE |                 |                |                |                |   | INT    | INT | EX T | EX T |
|                        | 1    | 2               | 3              | 4              | 5              | 6 |        |     |      |      |
| A                      | B4   | N <sub>8</sub>  | 8A             |                |                |   | 6      | —   | 15   | —    |
| #N <sub>16</sub>       | B4   | N <sub>8</sub>  | 98             | N <sub>L</sub> | N <sub>H</sub> |   | 10     | —   | 19   | —    |
| erN                    | 44+N | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | —    | 12   |
| DP                     | 92   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| X1                     | 90   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| X2                     | 91   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| USP                    | A1   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| SSP                    | A0   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| LRB                    | A4   | 7C              | N <sub>8</sub> |                |                |   | 6      | —   | 11   | —    |
| off N <sub>8</sub>     | B4   | N' <sub>8</sub> | 7C             | N <sub>8</sub> |                |   | 8      | —   | —    | 18   |
| N' <sub>8</sub>        | B5   | N' <sub>8</sub> | 7C             | N <sub>8</sub> |                |   | 8      | —   | 13   | —    |
| [DP]                   | B2   | 7C              | N <sub>8</sub> |                |                |   | 8      | 12  | 13   | 17   |
| ±N' <sub>8</sub> [USP] | B3   | N' <sub>8</sub> | 7C             | N <sub>8</sub> |                |   | 9      | 13  | 14   | 18   |
| N <sub>16</sub> [X1]   | B0   | N <sub>L</sub>  | N <sub>H</sub> | 7C             | N <sub>8</sub> |   | 10     | 14  | 15   | 19   |
| N <sub>16</sub> [X2]   | B1   | N <sub>L</sub>  | N <sub>H</sub> | 7C             | N <sub>8</sub> |   | 10     | 14  | 15   | 19   |

← off N<sub>8</sub>

← obj

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV PSW, obj**

16-bit Move

| <b>obj</b>            | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |                |                |    |                            |   |        |     |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----|----------------------------|---|--------|-----|
| <b>Function</b>       | PSW ← obj (word long)                                                                                                                         |                |                |    |                            |   |        |     |
| <b>Description</b>    | This instruction transfers the addressing object (word long) to the program status word (PSW).                                                |                |                |    |                            |   |        |     |
| <b>Flags</b>          | Flags affected by execution:                                                                                                                  |                |                |    | Flags affecting execution: |   |        |     |
|                       | ZF                                                                                                                                            | CF             | HC             | DD |                            |   |        |     |
|                       | *                                                                                                                                             | *              | *              | *  |                            |   |        |     |
| <b>Codes/Cycles</b>   |                                                                                                                                               |                |                |    |                            |   |        |     |
| obj                   | CODE                                                                                                                                          |                |                |    |                            |   | CYCLES |     |
|                       | BYTE                                                                                                                                          |                |                |    |                            |   | INT    | EXT |
|                       | 1                                                                                                                                             | 2              | 3              | 4  | 5                          | 6 |        |     |
| A                     |                                                                                                                                               |                |                |    |                            |   |        |     |
| #N <sub>16</sub>      |                                                                                                                                               |                |                |    |                            |   |        |     |
| erN                   | 44+N                                                                                                                                          | 7D             |                |    |                            |   | 4 8    |     |
| DP                    | 92                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| X1                    | 90                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| X2                    | 91                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| USP                   | A1                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| SSP                   | A0                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| LRB                   | A4                                                                                                                                            | 7D             |                |    |                            |   | 4 —    |     |
| off N <sub>8</sub>    | B4                                                                                                                                            | N <sub>8</sub> | 7D             |    |                            |   | 6 11   |     |
| N <sub>8</sub>        | B5                                                                                                                                            | N <sub>8</sub> | 7D             |    |                            |   | 6 —    |     |
| [DP]                  | B2                                                                                                                                            | 7D             |                |    |                            |   | 6 10   |     |
| ±N <sub>8</sub> [USP] | B3                                                                                                                                            | N <sub>8</sub> | 7D             |    |                            |   | 7 11   |     |
| N <sub>16</sub> [X1]  | B0                                                                                                                                            | N <sub>L</sub> | N <sub>H</sub> | 7D |                            |   | 8 12   |     |
| N <sub>16</sub> [X2]  | B1                                                                                                                                            | N <sub>L</sub> | N <sub>H</sub> | 7D |                            |   | 8 12   |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV SSP, obj**

16-bit Move

|                    |                                                                                                                                                                     |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b>         | A, #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
| <b>Function</b>    | SSP ← obj (word long)                                                                                                                                               |
| <b>Description</b> | This instruction transfers the contents of the addressing object (word long) to the system stack pointer (SSP).                                                     |
| <b>Flags</b>       | Flags affected by execution: Flags affecting execution:                                                                                                             |

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----------------|---|---|--------|-----|
|                       | BYTE |                |                |                |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4              | 5 | 6 |        |     |
| A                     | A0   | 8A             |                |                |   |   | 4      | —   |
| #N <sub>16</sub>      | A0   | 98             | N <sub>L</sub> | N <sub>H</sub> |   |   | 8      | —   |
| erN                   | 44+N | 7E             |                |                |   |   | 4      | 8   |
| DP                    | 92   | 7E             |                |                |   |   | 4      | —   |
| X1                    | 90   | 7E             |                |                |   |   | 4      | —   |
| X2                    | 91   | 7E             |                |                |   |   | 4      | —   |
| USP                   | A1   | 7E             |                |                |   |   | 4      | —   |
| SSP                   | A0   | 7E             |                |                |   |   | 4      | —   |
| LRB                   | A4   | 7E             |                |                |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 7E             |                |   |   | 6      | 11  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 7E             |                |   |   | 6      | —   |
| [DP]                  | B2   | 7E             |                |                |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 7E             |                |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 7E             |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 7E             |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV USP, obj**

16-bit Move

obj

A, #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

USP ← obj (word long)

Description

This instruction transfers the contents of the addressing object (word long) to the user stack pointer (USP).

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj                   | CODE |                |                |                |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----------------|---|---|--------|-----|
|                       | BYTE |                |                |                |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4              | 5 | 6 |        |     |
| A                     | A1   | 8A             |                |                |   |   | 4      | —   |
| #N <sub>16</sub>      | A1   | 98             | N <sub>L</sub> | N <sub>H</sub> |   |   | 8      | —   |
| erN                   | 44+N | 7B             |                |                |   |   | 4      | 8   |
| DP                    | 92   | 7B             |                |                |   |   | 4      | —   |
| X1                    | 90   | 7B             |                |                |   |   | 4      | —   |
| X2                    | 91   | 7B             |                |                |   |   | 4      | —   |
| USP                   | A1   | 7B             |                |                |   |   | 4      | —   |
| SSP                   | A0   | 7B             |                |                |   |   | 4      | —   |
| LRB                   | A4   | 7B             |                |                |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 7B             |                |   |   | 6      | 11  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 7B             |                |   |   | 6      | —   |
| [DP]                  | B2   | 7B             |                |                |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 7B             |                |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 7B             |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 7B             |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOV X1, obj**

16-bit Move

|     |                                                                                                                                                                     |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| obj | A, #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|          |                      |
|----------|----------------------|
| Function | X1 ← obj (word long) |
|----------|----------------------|

|             |                                                                                                          |
|-------------|----------------------------------------------------------------------------------------------------------|
| Description | This instruction transfers the contents of the addressing object (word long) to the index register (X1). |
|-------------|----------------------------------------------------------------------------------------------------------|

|       |                                                                                                                                                                                                          |    |    |    |    |  |  |  |  |                                                                                                                                      |    |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|--|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------|----|--|
| Flags | Flags affected by execution:<br><br><table border="1" style="margin-left: 20px;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td></td> <td></td> <td></td> <td></td> </tr> </table> | ZF | CF | HC | DD |  |  |  |  | Flags affecting execution:<br><br><table border="1" style="margin-left: 20px;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | DD |  |
| ZF    | CF                                                                                                                                                                                                       | HC | DD |    |    |  |  |  |  |                                                                                                                                      |    |  |
|       |                                                                                                                                                                                                          |    |    |    |    |  |  |  |  |                                                                                                                                      |    |  |
| DD    |                                                                                                                                                                                                          |    |    |    |    |  |  |  |  |                                                                                                                                      |    |  |
|       |                                                                                                                                                                                                          |    |    |    |    |  |  |  |  |                                                                                                                                      |    |  |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     | 50   |                |                |    |   |   | 2      | —   |
| #N <sub>16</sub>      | 60   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 44+N | 78             |                |    |   |   | 4      | 8   |
| DP                    | 92   | 78             |                |    |   |   | 4      | —   |
| X1                    | 90   | 78             |                |    |   |   | 4      | —   |
| X2                    | 91   | 78             |                |    |   |   | 4      | —   |
| USP                   | A1   | 78             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 78             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 78             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 78             |    |   |   | 6      | 11  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 78             |    |   |   | 6      | —   |
| [DP]                  | B2   | 78             |                |    |   |   | 8      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 78             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 78 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 78 |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### MOV X2, obj

16-bit Move

obj

A, #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

X2 ← obj (word long)

Description

This instruction transfers the contents of the addressing object (word long) to the index register (X2).

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     | 51   |                |                |    |   |   | 2      | —   |
| #N <sub>16</sub>      | 61   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 44+N | 79             |                |    |   |   | 4      | 8   |
| DP                    | 92   | 79             |                |    |   |   | 4      | —   |
| X1                    | 90   | 79             |                |    |   |   | 4      | —   |
| X2                    | 91   | 79             |                |    |   |   | 4      | —   |
| USP                   | A1   | 79             |                |    |   |   | 4      | —   |
| SSP                   | A0   | 79             |                |    |   |   | 4      | —   |
| LRB                   | A4   | 79             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 79             |    |   |   | 6      | 11  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 79             |    |   |   | 6      | —   |
| [DP]                  | B2   | 79             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 79             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 79 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 79 |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### **MOVB A, obj**

8-bit Move

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b>         | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Function</b>    | A <sub>L</sub> ← obj (byte long)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>Description</b> | <p>This instruction transfers the contents (byte long) of the addressing object to the lower byte of the accumulator (A<sub>L</sub>).</p> <p><i>This instruction sets the data descriptor (DD) to 0.</i></p> <p>Also, this instruction functionally overlaps part of the "LB A, obj" instruction. This instruction differs from "LB A, obj" instruction in that this instruction is not affected by the stack flag (SF) and does not affect the zero flag (ZF). On the other hand, the "LB A, obj" instruction incurs comparatively fewer numbers of bytes and cycles, hence the use of "LB A, obj" is preferred because it results in better program efficiency.</p> |

|              |                                                                                                                                                                                           |                            |    |    |    |  |  |  |   |                                                                                                                              |    |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|----|----|--|--|--|---|------------------------------------------------------------------------------------------------------------------------------|----|--|
| <b>Flags</b> | Flags affected by execution:                                                                                                                                                              | Flags affecting execution: |    |    |    |  |  |  |   |                                                                                                                              |    |  |
|              | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td></td><td></td><td></td><td>0</td></tr> </table> | ZF                         | CF | HC | DD |  |  |  | 0 | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table> | DD |  |
| ZF           | CF                                                                                                                                                                                        | HC                         | DD |    |    |  |  |  |   |                                                                                                                              |    |  |
|              |                                                                                                                                                                                           |                            | 0  |    |    |  |  |  |   |                                                                                                                              |    |  |
| DD           |                                                                                                                                                                                           |                            |    |    |    |  |  |  |   |                                                                                                                              |    |  |
|              |                                                                                                                                                                                           |                            |    |    |    |  |  |  |   |                                                                                                                              |    |  |

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 99             |                |    |   |   | 4      | 6   |
| PSWH                  | A2   | 99             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 99             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 99             |    |   |   | 6      | 9   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 99             |    |   |   | 6      | —   |
| [DP]                  | C2   | 99             |                |    |   |   | 6      | 8   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 99             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 99 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 99 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOVB obj, A**

8-bit Move

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← A<sub>L</sub> (byte long)

**Description**

This instruction transfers the contents of the lower byte of the accumulator (A<sub>L</sub>) to the addressing object (byte long).

This instruction functionally overlaps part of the "STB A, obj" instruction. This instruction differs from "STB A, obj" instruction in that this instruction is not affected by the data descriptor (DD). On the other hand, "STB A, obj" incurs comparatively fewer numbers of bytes and cycles, hence the use of "STB A, obj" is preferred because of the resulting program efficiency.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 8A             |                |    |   |   | 4      | 8   |
| PSWH                  | A2   | 8A             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 8A             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 8A             |    |   |   | 6      | 11  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 8A             |    |   |   | 6      | —   |
| [DP]                  | C2   | 8A             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 8A             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 8A |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 8A |   |   | 8      | 12  |

### Chapter 3 Details of Instructions Instruction Set

#### **MOVB off N<sub>8</sub>, obj**

8-bit Move

|     |                                                                                                    |
|-----|----------------------------------------------------------------------------------------------------|
| obj | A, #N'8, rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|----------------------------------------------------------------------------------------------------|

|          |                                      |
|----------|--------------------------------------|
| Function | off N <sub>8</sub> ← obj (byte long) |
|----------|--------------------------------------|

|             |                                                                                                                                                           |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction transfers the content (byte long) of the addressing object to the data memory specified by direct page addressing (off N <sub>8</sub> ). |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|

|       |                              |                            |
|-------|------------------------------|----------------------------|
| Flags | Flags affected by execution: | Flags affecting execution: |
|-------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

| DD |
|----|
|    |

|              |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------|--|--|--|--|--|--|--|--|--|--|--|--|
| Codes/Cycles |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------|--|--|--|--|--|--|--|--|--|--|--|--|

| obj                  | CODE |                |                |                |                |   | CYCLES |      |      |      | ← off N <sub>8</sub> | ← obj |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|------|------|------|----------------------|-------|
|                      | BYTE |                |                |                |                |   | INT    | INT  | EX T | EX T |                      |       |
|                      | 1    | 2              | 3              | 4              | 5              | 6 | INT    | EX T | INT  | EX T |                      |       |
| A                    | C4   | N <sub>8</sub> | 8A             |                |                |   | 6      | —    | 13   | —    |                      |       |
| #N'8                 | C4   | N <sub>8</sub> | 98             | N'8            |                |   | 8      | —    | 13   | —    |                      |       |
| rN                   | 20+N | 7C             | N <sub>8</sub> |                |                |   | 6      | —    | —    | 11   |                      |       |
| PSWH                 | A2   | 7C             | N <sub>8</sub> |                |                |   | 6      | —    | 9    | —    |                      |       |
| PSWL                 | A3   | 7C             | N <sub>8</sub> |                |                |   | 6      | —    | 9    | —    |                      |       |
| off N'8              | C4   | N'8            | 7C             | N <sub>8</sub> |                |   | 8      | —    | —    | 14   |                      |       |
| N'8                  | C5   | N'8            | 7C             | N <sub>8</sub> |                |   | 8      | —    | 11   | —    |                      |       |
| [DP]                 | C2   | 7C             | N <sub>8</sub> |                |                |   | 8      | 10   | 11   | 13   |                      |       |
| ±N'8[USP]            | C3   | N'8            | 7C             | N <sub>8</sub> |                |   | 9      | 11   | 12   | 14   |                      |       |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | 7C             | N <sub>8</sub> |   | 10     | 12   | 13   | 15   |                      |       |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | 7C             | N <sub>8</sub> |   | 10     | 12   | 13   | 15   |                      |       |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOVB obj, #N<sub>8</sub>**

8-bit Move

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← #N<sub>8</sub> (byte long)

**Description**

This instruction transfers the byte long immediate value (#N<sub>8</sub>) to the addressing object (byte long).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |                |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                       | BYTE |                |                |                |                |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                     |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>       |      |                |                |                |                |   |        |     |
| rN                    | 98+N | N <sub>8</sub> |                |                |                |   | 4      | 6   |
| PSWH                  | A2   | 98             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                  | A3   | 98             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 98             | N <sub>8</sub> |                |   | 8      | 13  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 98             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                  | C2   | 98             | N <sub>8</sub> |                |                |   | 8      | 12  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 98             | N <sub>8</sub> |                |   | 9      | 13  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 98             | N <sub>8</sub> |   | 10     | 14  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 98             | N <sub>8</sub> |   | 10     | 14  |

---

### Chapter 3 Details of Instructions

#### Instruction Set

---

**MOVB PSWH, obj**

8-bit Move

|            |                                                                                                                                                    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> | A, #N <sub>8</sub> , rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|

|                 |                        |
|-----------------|------------------------|
| <b>Function</b> | PSWH ← obj (byte long) |
|-----------------|------------------------|

|                    |                                                                                                   |
|--------------------|---------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction transfers the addressing object (byte long) to the upper byte of the PSW (PSWH). |
|--------------------|---------------------------------------------------------------------------------------------------|

|              |                                                                                                                                                                                                      |                            |    |    |    |   |   |   |   |                                                                                                                                 |    |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|----|----|---|---|---|---|---------------------------------------------------------------------------------------------------------------------------------|----|--|
| <b>Flags</b> | Flags affected by execution:                                                                                                                                                                         | Flags affecting execution: |    |    |    |   |   |   |   |                                                                                                                                 |    |  |
|              | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td>*</td> <td>*</td> </tr> </table> | ZF                         | CF | HC | DD | * | * | * | * | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td> </td> </tr> </table> | DD |  |
| ZF           | CF                                                                                                                                                                                                   | HC                         | DD |    |    |   |   |   |   |                                                                                                                                 |    |  |
| *            | *                                                                                                                                                                                                    | *                          | *  |    |    |   |   |   |   |                                                                                                                                 |    |  |
| DD           |                                                                                                                                                                                                      |                            |    |    |    |   |   |   |   |                                                                                                                                 |    |  |
|              |                                                                                                                                                                                                      |                            |    |    |    |   |   |   |   |                                                                                                                                 |    |  |

|                     |  |
|---------------------|--|
| <b>Codes/Cycles</b> |  |
|---------------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     | A2   | 8A             |                |    |   |   | 4      | —   |
| #N <sub>8</sub>       | A2   | 98             | N <sub>8</sub> |    |   |   | 6      | —   |
| rN                    | 20+N | 89             |                |    |   |   | 4      | 8   |
| PSWH                  | A2   | 89             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 89             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 89             |    |   |   | 6      | 9   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 89             |    |   |   | 6      | —   |
| [DP]                  | C2   | 89             |                |    |   |   | 6      | 8   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 89             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 89 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 89 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOVB PSWL, obj**

8-bit Move

**obj**

A, #N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

PSWL ← obj (byte long)

**Description**

This instruction transfers the addressing object (byte long) to the lower byte of the PSW (PSWL).

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     | A3   | 8A             |                |    |   |   | 4      | —   |
| #N <sub>8</sub>       | A3   | 98             | N <sub>8</sub> |    |   |   | 6      | —   |
| rN                    | 20+N | 88             |                |    |   |   | 4      | 6   |
| PSWH                  | A2   | 88             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 88             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 88             |    |   |   | 6      | 9   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 88             |    |   |   | 6      | —   |
| [DP]                  | C2   | 88             |                |    |   |   | 6      | 8   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 88             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 88 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 88 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**MOVB rN, obj**

8-bit Move (Byte)

|     |                                                                                                                                                     |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| obj | A, #N <sub>8</sub> , rN', PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|

|          |                      |
|----------|----------------------|
| Function | rN ← obj (byte long) |
|----------|----------------------|

|             |                                                                                                          |
|-------------|----------------------------------------------------------------------------------------------------------|
| Description | This instruction transfers the contents (byte long) of the addressing object to the local register (rN). |
|-------------|----------------------------------------------------------------------------------------------------------|

|       |                                                |                                  |
|-------|------------------------------------------------|----------------------------------|
| Flags | Flags affected by execution:<br>ZF, CF, HC, DD | Flags affecting execution:<br>DD |
|-------|------------------------------------------------|----------------------------------|

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE  |                |                |      |   |   | CYCLES |      |      |      |
|-----------------------|-------|----------------|----------------|------|---|---|--------|------|------|------|
|                       | BYTE  |                |                |      |   |   | INT    | INT  | EX T | EX T |
|                       | 1     | 2              | 3              | 4    | 5 | 6 | INT    | EX T | INT  | EX T |
| A                     | 20+N  | 8A             |                |      |   |   | 4      | —    | 8    | —    |
| #N <sub>8</sub>       | 98+N  | N <sub>8</sub> |                |      |   |   | 4      | —    | 6    | —    |
| rN'                   | 20+N' | 48+N           |                |      |   |   | 4      | —    | —    | 8    |
| PSWH                  | A2    | 48+N           |                |      |   |   | 4      | —    | 6    | —    |
| PSWL                  | A3    | 48+N           |                |      |   |   | 4      | —    | 6    | —    |
| off N <sub>8</sub>    | C4    | N <sub>8</sub> | 48+N           |      |   |   | 6      | —    | —    | 11   |
| N <sub>8</sub>        | C5    | N <sub>8</sub> | 48+N           |      |   |   | 6      | —    | 8    | —    |
| [DP]                  | C2    | 48+N           |                |      |   |   | 6      | 8    | 8    | 10   |
| ±N <sub>8</sub> [USP] | C3    | N <sub>8</sub> | 48+N           |      |   |   | 7      | 9    | 9    | 11   |
| N <sub>16</sub> [X1]  | C0    | N <sub>L</sub> | N <sub>H</sub> | 48+N |   |   | 8      | 10   | 10   | 12   |
| N <sub>16</sub> [X2]  | C1    | N <sub>L</sub> | N <sub>H</sub> | 48+N |   |   | 8      | 10   | 10   | 12   |

← rN  
← obj

## Chapter 3 Details of Instructions

### Instruction Set

#### MUL

16-bit Multiply

**obj**

**Function**

$(er1, A) \leftarrow A \times er0$

**Description**

16 bits  $\times$  16 bits  $\rightarrow$  32-bit multiply instruction

This instruction performs multiplication between the contents of the accumulator and the extended local register (er0). The upper 16 bits of the resulting product is stored in the extended local register (er1) and the lower 16 bits of the product is stored in the accumulator.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| o b j | CODE |    |   |   |   |   | CYCLES |     |
|-------|------|----|---|---|---|---|--------|-----|
|       | BYTE |    |   |   |   |   | INT    | EXT |
|       | 1    | 2  | 3 | 4 | 5 | 6 |        |     |
|       | 90   | 35 |   |   |   |   | 27     | 35  |

$\leftarrow er0, er1$

## Chapter 3 Details of Instructions

### Instruction Set

#### MULB

8-bit Multiply

obj

Function

$A \leftarrow A_L \times r0$

Description

8 bits  $\times$  8 bits  $\rightarrow$  16-bit multiply instruction

This instruction performs multiplication between the lower byte of the accumulator ( $A_L$ ) and the local register ( $r0$ ). The resulting product (16 bits) is stored in the accumulator.

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj | CODE |    |   |   |   |   | CYCLES |     |
|-----|------|----|---|---|---|---|--------|-----|
|     | BYTE |    |   |   |   |   | INT    | EXT |
|     | 1    | 2  | 3 | 4 | 5 | 6 |        |     |
|     | A2   | 34 |   |   |   |   | 19     | 21  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**NOP** No Operation

**obj**

**Function** No Operation

**Description** This instruction performs no operation, but consumes time for 2 cycles.

**Flags** Flags affected by execution: Flags affecting execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 00   |   |   |   |   |   | 2      |     |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### **OR A, obj**

16-bit logical OR

|     |                                                                                                                                                                  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| obj | #N <sub>16</sub> , erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|          |                         |
|----------|-------------------------|
| Function | A ← A ∨ obj (word long) |
|----------|-------------------------|

|             |                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction performs the logical OR operation on the contents of the accumulator and the addressing object. The result (16 bits) is stored in the accumulator. |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=1.

|       |                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |                                                                                                                                                        |    |   |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|
| Flags | Flags affected by execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td>*</td><td></td><td></td><td></td></tr></table> | ZF | CF | HC | DD | * |  |  |  | Flags affecting execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>DD</td></tr><tr><td>1</td></tr></table> | DD | 1 |
| ZF    | CF                                                                                                                                                                                                                   | HC | DD |    |    |   |  |  |  |                                                                                                                                                        |    |   |
| *     |                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |                                                                                                                                                        |    |   |
| DD    |                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |                                                                                                                                                        |    |   |
| 1     |                                                                                                                                                                                                                      |    |    |    |    |   |  |  |  |                                                                                                                                                        |    |   |

|              |  |  |  |  |  |  |  |  |
|--------------|--|--|--|--|--|--|--|--|
| Codes/Cycles |  |  |  |  |  |  |  |  |
|--------------|--|--|--|--|--|--|--|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | E6   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 68+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | E2             |                |    |   |   | 4      | —   |
| X1                    | 90   | E2             |                |    |   |   | 4      | —   |
| X2                    | 91   | E2             |                |    |   |   | 4      | —   |
| USP                   | A1   | E2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | E2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | E2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | E2             |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | E2             |    |   |   | 6      | —   |
| [DP]                  | B2   | E2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | E2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | E2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | E2 |   |   | 8      | 12  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### OR obj, A

16-bit logical OR

##### obj

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

##### Function

obj ← obj ∨ A (word long)

##### Description

This instruction performs the word long logical OR operation on the contents of the addressing object and the accumulator.

The result (16 bits) is stored in the addressing object.

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

##### Codes/Cycles

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | E1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | E1             |                |    |   |   | 5      | —   |
| X1                    | 90   | E1             |                |    |   |   | 5      | —   |
| X2                    | 91   | E1             |                |    |   |   | 5      | —   |
| USP                   | A1   | E1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | E1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | E1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | E1             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | E1             |    |   |   | 7      | —   |
| [DP]                  | B2   | E1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | E1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | E1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | E1 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**OR obj, off N<sub>8</sub>**

16-bit logical OR

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∨ off N<sub>8</sub> (word long)

**Description**

This instruction performs the word long logical OR operation on the contents of the addressing object and the data memory specified by direct page addressing (off N<sub>8</sub>).

The result (16 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                    | CODE |                 |                |                |                |   | CYCLES |     |      |      |
|------------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                        | BYTE |                 |                |                |                |   | INT    | INT | EX T | EX T |
|                        | 1    | 2               | 3              | 4              | 5              | 6 |        |     |      |      |
| A                      |      |                 |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>       |      |                 |                |                |                |   |        |     |      |      |
| erN                    | 44+N | E3              | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                     | 92   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                     | 90   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                     | 91   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                    | A1   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                    | A0   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                    | A4   | E3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>     | B4   | N' <sub>8</sub> | E3             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N' <sub>8</sub>        | B5   | N' <sub>8</sub> | E3             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                   | B2   | E3              | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N' <sub>8</sub> [USP] | B3   | N' <sub>8</sub> | E3             |                |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1]   | B0   | N <sub>L</sub>  | N <sub>H</sub> | E3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2]   | B1   | N <sub>L</sub>  | N <sub>H</sub> | E3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

← obj

← off N<sub>8</sub>

### Chapter 3 Details of Instructions Instruction Set

#### **ORB A, obj**

8-bit logical OR

|     |  |
|-----|--|
| obj |  |
|-----|--|

#N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

|          |  |
|----------|--|
| Function |  |
|----------|--|

A<sub>L</sub> ← A<sub>L</sub> V obj (byte long)

|             |  |
|-------------|--|
| Description |  |
|-------------|--|

This instruction performs the logical OR operation on the contents of the lower byte of the accumulator (A<sub>L</sub>) and the contents of the addressing object (byte long).

The result (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>). This instruction is affected by the data descriptor (DD). For this instruction to be executed correctly it is necessary to set DD=0.

|       |  |
|-------|--|
| Flags |  |
|-------|--|

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | E6   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 68+N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2   | E2             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | E2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | E7   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | E2             |    |   |   | 6      | —   |
| [DP]                  | C2   | E2             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | E2             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | E2 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | E2 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ORB obj, A**

8-bit logical OR

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ∨ A<sub>L</sub> (byte long)

**Description**

This instruction performs the logical OR operation on the contents of the lower byte of the accumulator (A<sub>L</sub>) and the contents of the addressing object (byte long).

The result (8 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | E1             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | E1             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | E1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | E1             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | E1             |    |   |   | 7      | —   |
| [DP]                  | C2   | E1             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | E1             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | E1 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | E1 |   |   | 9      | 13  |

### Chapter 3 Details of Instructions Instruction Set

#### **ORB obj, off N<sub>8</sub>**

8-bit logical OR

|                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|
| <b>obj</b>                                                                                                                                                                                                                     | rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| <b>Function</b>                                                                                                                                                                                                                | $\text{obj} \leftarrow \text{obj} \vee \text{off N}_8$ (byte long)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| <b>Description</b>                                                                                                                                                                                                             | This instruction performs the byte long logical OR operation on the contents of the addressing object and the data memory specified by the direct page addressing (off N <sub>8</sub> ).<br><br>The result (8 bits) is stored in the addressing object.                                                                                                                                                                                                                                                                                                                                                                                                                        |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| <b>Flags</b>                                                                                                                                                                                                                   | <table border="0" style="margin-left: auto; margin-right: auto;"> <tr> <td style="padding-right: 20px;">Flags affected by execution:</td> <td>Flags affecting execution:</td> </tr> <tr> <td style="text-align: center;"> <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td>*</td> <td></td> </tr> </table> </td> <td style="text-align: center;"> <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> </td> </tr> </table> | Flags affected by execution: | Flags affecting execution: | <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td>*</td> <td></td> </tr> </table> | ZF | CF | HC | DD | *                                                                                                                                                         | *  | * |  | <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | DD |  |
| Flags affected by execution:                                                                                                                                                                                                   | Flags affecting execution:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td>*</td> <td>*</td> <td></td> </tr> </table> | ZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CF                           | HC                         | DD                                                                                                                                                                                                                             | *  | *  | *  |    | <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | DD |   |  |                                                                                                                                                           |    |  |
| ZF                                                                                                                                                                                                                             | CF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HC                           | DD                         |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| *                                                                                                                                                                                                                              | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | *                            |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
| DD                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |
|                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                            |                                                                                                                                                                                                                                |    |    |    |    |                                                                                                                                                           |    |   |  |                                                                                                                                                           |    |  |

#### **Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                    |      |                |                |                |                |   |        |     |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |      |      |
| rN                   | 20+N | E3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   |
| PSWH                 | A2   | E3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| PSWL                 | A3   | E3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| off N <sub>8</sub>   | C4   | N'8            | E3             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |
| N'8                  | C5   | N'8            | E3             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |
| [DP]                 | C2   | E3             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | E3             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | E3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | E3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### ORB obj, #N<sub>8</sub>

8-bit logical OR

##### obj

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

##### Function

obj ← obj V #N<sub>8</sub> (byte long)

##### Description

This instruction performs the logical OR operation on the content of the addressing object (byte long) and the 8-bit immediate value (#N<sub>8</sub>).

The result (8 bits) is stored in the addressing object.

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

##### Codes/Cycles

| obj                  | CODE |                |                |                |                |   | CYCLES |     |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                      | BYTE |                |                |                |                |   | INT    | EXT |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                    |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |
| rN                   | 20+N | E0             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                 | A2   | E0             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                 | A3   | E0             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N'8              | C4   | N'8            | E0             | N <sub>8</sub> |                |   | 8      | 14  |
| N'8                  | C5   | N'8            | E0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                 | C2   | E0             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N'8[USP]            | C3   | N'8            | E0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | E0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | E0             | N <sub>8</sub> |   | 10     | 15  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### **POPS A**

16-bit Pop (system stack)

**obj** \_\_\_\_\_

**Function** \_\_\_\_\_

$\text{SSP} \leftarrow \text{SSP} + 2$   
 $A \leftarrow (\text{SSP})$  (word long)  
 $DD \leftarrow 1$

**Description** \_\_\_\_\_

This instruction pops the data from the system stack into the accumulator in a word long operation.

*This instruction sets the data descriptor (DD) to 1.*

[NOTE] Note that the "PUSHS A" instruction does not affect DD, while the "POPS A" instruction sets DD=1.

**Flags** \_\_\_\_\_

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    | 1  |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles** \_\_\_\_\_

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 65   |   |   |   |   |   | 4      | 8   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| orN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**POPS LRB**

16-bit Pop (system stack)

**obj**

---

**Function**

$SSP \leftarrow SSP + 2$   
 $LRB \leftarrow (SSP) \text{ (word long)}$

**Description**

This instruction pops the data from the system stack into LRB in a word long operation.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     |      |   |   |   |   |   |        |     |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| erN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   | 64   |   |   |   |   |   | 4      | 8   |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**PUSHS obj**

16-bit Push (system stack)

**obj** \_\_\_\_\_  
A, LRB

**Function** \_\_\_\_\_  
 $(SSP) \leftarrow obj$  (word long)  
 $SSP \leftarrow SSP - 2$

**Description** \_\_\_\_\_  
This instruction pushes the contents of the addressing object into the system stack in a word long operation.

**Flags** \_\_\_\_\_  
Flags affected by execution: \_\_\_\_\_ Flags affecting execution: \_\_\_\_\_

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

|    |
|----|
| DD |
|    |

**Codes/Cycles** \_\_\_\_\_

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 55   |   |   |   |   |   | 3      | 7   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| orN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   | 54   |   |   |   |   |   | 3      | 7   |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**RB obj.bit**

Reset Bit (direct bit addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

IF obj.bit = 0 THEN Z ← 1  
ELSE Z ← 0  
obj.bit ← 0

**Description**

This instruction resets the specified bit of the addressing object, "obj" (byte long), to 0. The location of the bit is specified by the "bit" in the operand. The value of the "bit" ranges from 0 to 7.

Prior to the execution of this instruction, the content of the specified bit is examined and the zero flag (ZF) is set accordingly. If the specified bit is 0 prior to the execution of the instruction, the zero flag is 1, otherwise the ZF=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

---

| obj                   | CODE |                 |                 |      |   |   | CYCLES |     |
|-----------------------|------|-----------------|-----------------|------|---|---|--------|-----|
|                       | BYTE |                 |                 |      |   |   | INT    | EXT |
|                       | 1    | 2               | 3               | 4    | 5 | 6 |        |     |
| A                     |      |                 |                 |      |   |   |        |     |
| #N <sub>8</sub>       |      |                 |                 |      |   |   |        |     |
| rN                    | 20+N | 08+n            |                 |      |   |   | 7      | 13  |
| PSWH                  | A2   | 08+n            |                 |      |   |   | 7      | —   |
| PSWL                  | A3   | 08+n            |                 |      |   |   | 7      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub>  | 08+n            |      |   |   | 9      | 16  |
| N <sub>8</sub>        | C5   | N <sub>8</sub>  | 08+n            |      |   |   | 9      | —   |
| [DP]                  | C2   | 08+n            |                 |      |   |   | 9      | 15  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub>  | 08+n            |      |   |   | 10     | 16  |
| N <sub>16</sub> [X1]  | C0   | N <sub>16</sub> | N <sub>16</sub> | 08+n |   |   | 11     | 17  |
| N <sub>16</sub> [X2]  | C1   | N <sub>16</sub> | N <sub>16</sub> | 08+n |   |   | 11     | 17  |

[NOTE] "n" is determined from the value of the "bit", and ranges from 0 to 7.

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**RBR obj**

Reset Bit (register indirect bit addressing)

|            |                                                                                                                               |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|------------|-------------------------------------------------------------------------------------------------------------------------------|

|                 |                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------|
| <b>Function</b> | <pre>IF obj.bit(A<sub>2-0</sub>) = 0 THEN Z ← 1 ELSE Z ← 0 obj.bit(A<sub>2-0</sub>) ← 0</pre> |
|-----------------|-----------------------------------------------------------------------------------------------|

|                    |                                                                                                                                                                                                                                                                      |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction resets the specified bit of the operand "obj" (byte long) which is the addressing object. The location of the bit is specified by the contents of the lower 3 bits of the accumulator (A <sub>2-0</sub> ) at the execution time of the instruction. |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Prior to the execution of the instruction, the contents of the specified bit is examined and the zero flag (ZF) is set accordingly. If the specified bit is 0 prior to the execution of the instruction, the zero flag is 1; otherwise ZF=0.

|              |                                                                                                                                                                                                                      |                            |    |    |    |   |  |  |  |                                                                                                                                                         |    |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|----|----|---|--|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|
| <b>Flags</b> | Flags affected by execution:                                                                                                                                                                                         | Flags affecting execution: |    |    |    |   |  |  |  |                                                                                                                                                         |    |  |
|              | <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td></td><td></td><td></td></tr> </table> | ZF                         | CF | HC | DD | * |  |  |  | <table border="1" style="display: inline-table; vertical-align: middle; border-collapse: collapse;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table> | DD |  |
| ZF           | CF                                                                                                                                                                                                                   | HC                         | DD |    |    |   |  |  |  |                                                                                                                                                         |    |  |
| *            |                                                                                                                                                                                                                      |                            |    |    |    |   |  |  |  |                                                                                                                                                         |    |  |
| DD           |                                                                                                                                                                                                                      |                            |    |    |    |   |  |  |  |                                                                                                                                                         |    |  |
|              |                                                                                                                                                                                                                      |                            |    |    |    |   |  |  |  |                                                                                                                                                         |    |  |

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| iN                    | 20+N | 12             |                |    |   |   | 7      | 13  |
| PSWH                  | A2   | 12             |                |    |   |   | 7      | —   |
| PSWL                  | A3   | 12             |                |    |   |   | 7      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 12             |    |   |   | 9      | 16  |
| N <sub>8</sub>        | CS   | N <sub>8</sub> | 12             |    |   |   | 9      | —   |
| [DP]                  | C2   | 12             |                |    |   |   | 9      | 15  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 12             |    |   |   | 10     | 16  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 12 |   |   | 11     | 17  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 12 |   |   | 11     | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**RC** Reset Carry

**obj**

**Function**

$C \leftarrow 0$

**Description**

This instruction resets the carry (C) by making C=0

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
| 0  |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A   | 95   |   |   |   |   |   | 2      | -   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ROL A**

16-bit Rotate Left

**obj**

**Function**



**Description**

This instruction rotates the contents (word long) of the accumulator including the carry, one bit to the left.

*This instruction is affected by the data descriptor (DD).*  
For the instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "ROLB A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 33   |   |   |   |   |   | 2      | —   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| orN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

---

**Instruction Set**

---

**ROL obj**

16-bit Rotate Left

**obj**erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]**Function****Description**

This instruction rotates the content (word long) of the addressing object including the carry, one bit to the left.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | B7             |                |    |   |   | 5      | 13  |
| DP                    | 92   | B7             |                |    |   |   | 5      | —   |
| X1                    | 90   | B7             |                |    |   |   | 5      | —   |
| X2                    | 91   | B7             |                |    |   |   | 5      | —   |
| USP                   | A1   | B7             |                |    |   |   | 5      | —   |
| SSP                   | A0   | B7             |                |    |   |   | 5      | —   |
| LRB                   | A4   | B7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | B7             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | B7             |    |   |   | 7      | —   |
| [DP]                  | B2   | B7             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | B7             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | B7 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | B7 |   |   | 9      | 17  |

---

## Chapter 3 Details of Instructions

### Instruction Set

#### ROLB A

8-bit Rotate Left

**obj**

**Function**



**Description**

This instruction rotates the contents of the lower byte of the accumulator ( $A_L$ ) including the carry, one bit to the left.

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "ROL A".

**Flags**

Flags affected by execution:

| ZF | CF | HF | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 33   |   |   |   |   |   | 2      | —   |
| #N <sub>8</sub>       |      |   |   |   |   |   |        |     |
| N                     |      |   |   |   |   |   |        |     |
| PSWH                  |      |   |   |   |   |   |        |     |
| PSWL                  |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ROLB obj**

8-bit Rotate Left

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



**Description**

This instruction rotates the contents of the addressing object (word long) including the carry, one bit to the left.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | B7             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | B7             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | B7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | B7             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | B7             |    |   |   | 7      | —   |
| [DP]                  | C2   | B7             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | B7             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | B7 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | B7 |   |   | 9      | 13  |

### Chapter 3 Details of Instructions Instruction Set

---

#### ROR A

16-bit Rotate Right



*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "RORB A".



| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

| DD |
|----|
| 1  |



| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 43   |   |   |   |   |   | 2      | —   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| orN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ROR obj**

16-bit Rotate Right

**obj**

erN, DP, X1, X2, USP, SSP, LRB off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



**Description**

This instruction rotates the contents of the addressing object (word long) including the carry, one bit to the right.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44-N | C7             |                |    |   |   | 5      | 13  |
| DP                    | 92   | C7             |                |    |   |   | 5      | —   |
| X1                    | 90   | C7             |                |    |   |   | 5      | —   |
| X2                    | 91   | C7             |                |    |   |   | 5      | —   |
| USP                   | A1   | C7             |                |    |   |   | 5      | —   |
| SSP                   | A0   | C7             |                |    |   |   | 5      | —   |
| LRB                   | A4   | C7             |                |    |   |   | 5      | —   |
| off N <sub>4</sub>    | B4   | N <sub>8</sub> | C7             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | C7             |    |   |   | 7      | —   |
| [DP]                  | B2   | C7             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>L</sub> | C7             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | C7 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | C7 |   |   | 9      | 17  |

## Chapter 3 Details of Instructions Instruction Set

---

### RORB A

8-bit Rotate Right

**obj**

**Function**



**Description**

This instruction rotates the contents of the lower byte of the accumulator ( $A_L$ ) including the carry, one bit to the right.

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "ROR A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 43   |   |   |   |   |   | 2      | —   |
| #N <sub>8</sub>       |      |   |   |   |   |   |        |     |
| rN                    |      |   |   |   |   |   |        |     |
| PSWH                  |      |   |   |   |   |   |        |     |
| PSWL                  |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**RORB obj**

8-bit Rotate Right

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



**Description**

This instruction rotates the content (word long) of the addressing object including the carry, one bit to the right.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | C7             |                |    |   |   | 5      | —   |
| PSWH                  | A2   | C7             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | C7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | C7             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | C7             |    |   |   | 7      | —   |
| [DP]                  | C2   | C7             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | C7             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | C7 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | C7 |   |   | 9      | 13  |

## Chapter 3 Details of Instructions Instruction Set

### RT

Return from Normal Subroutine

**obj**

**Function**

SSP  $\leftarrow$  SSP +2  
PC  $\leftarrow$  (SSP)  
SF  $\leftarrow$  0

**Description**

This instruction is used to return from normal subroutines that are called by the instructions "SCAL" and "CAL". (See RTI Instruction)

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 01   |   |   |   |   |   | 7      | 11  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**RTI**

Return from Interrupt Routine

**obj**

**Function**

SSP  $\leftarrow$  SSP +2  
PSW  $\leftarrow$  (SSP)  
SSP  $\leftarrow$  SSP +2  
LRB  $\leftarrow$  (SSP)  
SSP  $\leftarrow$  SSP +2  
A  $\leftarrow$  (SSP)  
SSP  $\leftarrow$  SSP +2  
PC  $\leftarrow$  (SSP)

**Description**

This instruction is used to return from the interrupt routines. (See RT instruction.)

The data saved in the system stack are returned to the units in the order : PSW, LRB, A, and PC. The system stack pointer is ultimately incremented by 8.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 02   |   |   |   |   |   | 15     | 31  |

## Chapter 3 Details of Instructions

### Instruction Set

---

**SB obj.bit**

Set Bit (direct bit addressing)

**obj**

 rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

```
IF obj.bit = 0 THEN Z ← 1
ELSE Z ← 0
obj.bit ← 1
```

**Description**

This instruction sets the specified bit of the addressing object (obj) to 1.

The location of the bit is specified by the bit in the second operand. The value of the "bit" is from 0 to 7. Prior to the execution of the instruction, the content of the specified bit is examined and the zero flag (ZF) is set accordingly. If the specified bit is 0 prior to the execution of the instruction, the zero flag is 1, otherwise ZF=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |      |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|------|---|---|--------|-----|
|                       | BYTE |                |                |      |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4    | 5 | 6 |        |     |
| A                     |      |                |                |      |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |      |   |   |        |     |
| rN                    | 20+N | 18+n           |                |      |   |   | 7      | 13  |
| PSWH                  | A2   | 18+n           |                |      |   |   | 7      | —   |
| PSWL                  | A3   | 18+n           |                |      |   |   | 7      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 18+n           |      |   |   | 9      | 16  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 18+n           |      |   |   | 9      | —   |
| [DP]                  | C2   | 18+n           |                |      |   |   | 9      | 15  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 18+n           |      |   |   | 10     | 16  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 18+n |   |   | 11     | 17  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 18+n |   |   | 11     | 17  |

[NOTE] The value of n is determined following evaluation of "bit". The value of n ranges from 0 to 7.

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SBC A, obj

16-bit Subtract with Carry

**obj**

#N<sub>8</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ← A - obj - C (word long)

**Description**

This instruction subtracts from the contents of the accumulator, the contents of the addressing object, and the contents of the carry (C) in the word long operation.

The resulting difference (16 bits) is stored in the accumulator. The borrow that occurs during the subtraction is stored in the carry (C).

*The instruction is affected by the data descriptor (DD). For this instruction to be executed correctly, it is necessary to set DD=1.*

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

---

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | B6   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 38+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | B2             |                |    |   |   | 4      | —   |
| X1                    | 90   | B2             |                |    |   |   | 4      | —   |
| X2                    | 91   | B2             |                |    |   |   | 4      | —   |
| USP                   | A1   | B2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | B2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | B2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | B7   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | B2             |    |   |   | 6      | —   |
| [DP]                  | B2   | B2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | B2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | B2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | B2 |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SBC obj, A**

16-bit Subtract with Carry

|     |                                                                                                                                               |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| obj | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|

|          |                               |
|----------|-------------------------------|
| Function | obj ← obj - A - C (word long) |
|----------|-------------------------------|

|             |                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction subtracts from the contents of the addressing object, the contents of the accumulator, and the contents of the carry (C) in a word long operation. |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|

The resulting difference (16 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

|       |                              |                            |
|-------|------------------------------|----------------------------|
| Flags | Flags affected by execution: | Flags affecting execution: |
|-------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

| DD |
|----|
|    |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | B1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | B1             |                |    |   |   | 5      | —   |
| X1                    | 90   | B1             |                |    |   |   | 5      | —   |
| X2                    | 91   | B1             |                |    |   |   | 5      | —   |
| USP                   | A1   | B1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | B1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | B1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | B1             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | B1             |    |   |   | 7      | —   |
| [DP]                  | B2   | B1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | B1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | B1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | B1 |   |   | 9      | 17  |

## Instruction Set

### SBC obj, off N<sub>8</sub>

16-bit Subtract with Carry

obj

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N'8, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

obj ← obj - off N<sub>8</sub> - C (word long)

Description

This instruction subtracts from the contents of the addressing object, the contents of the data memory specified by direct page addressing (off N<sub>8</sub>), and the contents of the carry (C) in a word long operation.

The resulting difference (16 bits) is stored in the addressing object, and the borrow that occurs during the subtraction is stored in the carry (C).

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj                   | CODE |                 |                |                |                |   | CYCLES |     |      |      |
|-----------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                       | BYTE |                 |                |                |                |   | INT    | INT | EX T | EX T |
|                       | 1    | 2               | 3              | 4              | 5              | 6 |        |     |      |      |
| A                     |      |                 |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>      |      |                 |                |                |                |   |        |     |      |      |
| erN                   | 44+N | B3              | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                    | 92   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                    | 90   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                    | 91   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                   | A1   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                   | A0   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                   | A4   | B3              | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>    | B4   | N' <sub>8</sub> | B3             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N' <sub>8</sub>       | B5   | N' <sub>8</sub> | B3             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                  | B2   | B3              | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N <sub>8</sub> [USP] | B3   | N' <sub>8</sub> | B3             | N <sub>8</sub> |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1]  | 80   | N <sub>L</sub>  | N <sub>H</sub> | B3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub>  | N <sub>H</sub> | B3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

← obj  
← off N<sub>8</sub>

## Chapter 3 Details of Instructions Instruction Set

---

### SBC obj, #N<sub>16</sub>

16-bit Subtract with Carry

#### obj

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'<sub>16</sub>[X1], N'<sub>16</sub>[X2]

#### Function

obj ← obj - #N<sub>16</sub> - C (word long)

#### Description

This instruction subtracts from the contents of the addressing object (word long), the 16 bit immediate value (#N<sub>16</sub>), and the contents of the carry (C).

The resulting difference (16 bits) is stored in the addressing object, and the borrow that occurs during the subtraction is stored in the carry (C).

#### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

#### Codes/Cycles

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | B0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | B0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | B0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | B0              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N' <sub>16</sub> [X1] | B0   | N' <sub>L</sub> | N' <sub>H</sub> | B0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N' <sub>16</sub> [X2] | B1   | N' <sub>L</sub> | N' <sub>H</sub> | B0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SBCB A, obj

8-bit Subtract with Carry

|            |                                                                                                                                                 |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> | #N <sub>8</sub> , rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|

|                 |                                            |
|-----------------|--------------------------------------------|
| <b>Function</b> | $A_L \leftarrow A_L - obj - C$ (byte long) |
|-----------------|--------------------------------------------|

|                    |                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction subtracts from the contents of the lower byte of the accumulator (A <sub>L</sub> ) the contents (byte long) of the addressing object, and the contents of the carry (C). The resulting sum (8 bits) is stored in the lower byte of the accumulator (A <sub>L</sub> ), and the carry from the highest (most significant) bit is stored in the carry (C). |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

*This instruction is affected by the data descriptor (DD).*  
For the instruction to be executed correctly, it is necessary to set DD=0.

|              |                              |                            |
|--------------|------------------------------|----------------------------|
| <b>Flags</b> | Flags affected by execution: | Flags affecting execution: |
|--------------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

| DD |
|----|
| 0  |

|                     |      |   |   |   |   |   |            |            |
|---------------------|------|---|---|---|---|---|------------|------------|
| <b>Codes/Cycles</b> | CODE |   |   |   |   |   | CYCLES     |            |
| <b>obj</b>          | BYTE |   |   |   |   |   | <b>INT</b> | <b>EXT</b> |
|                     | 1    | 2 | 3 | 4 | 5 | 6 |            |            |

|                       |      |                |                |    |  |  |   |    |
|-----------------------|------|----------------|----------------|----|--|--|---|----|
| <b>A</b>              |      |                |                |    |  |  |   |    |
| #N <sub>8</sub>       | B6   | N <sub>8</sub> |                |    |  |  | 4 | —  |
| rN                    | 38+N |                |                |    |  |  | 3 | 5  |
| PSWH                  | A2   | B2             |                |    |  |  | 4 | —  |
| PSWL                  | A3   | B2             |                |    |  |  | 4 | —  |
| off N <sub>8</sub>    | B7   | N <sub>8</sub> |                |    |  |  | 4 | 7  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | B2             |    |  |  | 6 | —  |
| [DP]                  | C2   | B2             |                |    |  |  | 6 | —  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | B2             |    |  |  | 7 | 9  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | B2 |  |  | 8 | 10 |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | B2 |  |  | 8 | 10 |

## Chapter 3 Details of Instructions

### Instruction Set

#### SBCB obj, A

8-bit Subtract with Carry

|                    |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|--|----|--|
| <b>obj</b>         | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                  |    |    |    |    |   |   |   |  |    |  |
| <b>Function</b>    | obj ← obj - A <sub>L</sub> - C (byte long)                                                                                                                                                                                                                                                                                                                                                     |    |    |    |    |   |   |   |  |    |  |
| <b>Description</b> | <p>This instruction subtracts from the contents of the lower byte of the accumulator (A<sub>L</sub>), the contents (byte long) of the addressing object, and the contents of the carry (C).</p> <p>The resulting sum (8 bits) is stored in the addressing object, and the borrow that occurs during the subtraction is stored in the carry (C).</p>                                            |    |    |    |    |   |   |   |  |    |  |
| <b>Flags</b>       | <p>Flags affected by execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td>*</td><td>*</td><td></td></tr> </table> <p>Flags affecting execution:</p> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table> | ZF | CF | HC | DD | * | * | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                             | HC | DD |    |    |   |   |   |  |    |  |
| *                  | *                                                                                                                                                                                                                                                                                                                                                                                              | *  |    |    |    |   |   |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |   |   |   |  |    |  |

| o b j                 | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | B1             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | B1             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | B1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | B1             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | B1             |    |   |   | 7      | —   |
| [DP]                  | C2   | B1             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | B1             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | B1 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | B1 |   |   | 9      | 13  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SBCB obj, off N<sub>8</sub>

8-bit Subtract with Carry

##### obj

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

##### Function

obj ← obj - off N<sub>8</sub> - C (byte long)

##### Description

This instruction subtracts from the contents (byte long) of the addressing object, the contents of the data memory specified by direct page addressing (off N<sub>8</sub>), and the contents of the carry (C).

The resulting difference (8 bits) is stored in the addressing object, and the borrow that occurs during the subtraction is stored in the carry (C).

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

##### Codes/Cycles

| obj                  | CODE |                |                |                |                |   | CYCLES |      |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|------|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT  | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 | INT    | EX T | INT  | EX T |
| A                    |      |                |                |                |                |   |        |      |      |      |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |      |      |      |
| rN                   | 20+N | B3             | N <sub>8</sub> |                |                |   | 7      | —    | —    | 14   |
| PSWH                 | A2   | B3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| PSWL                 | A3   | B3             | N <sub>8</sub> |                |                |   | 7      | 12   | —    | —    |
| off N'8              | C4   | N'8            | B3             | N <sub>8</sub> |                |   | 9      | —    | —    | 17   |
| N'8                  | C5   | N'8            | B3             | N <sub>8</sub> |                |   | 9      | 14   | —    | —    |
| [DP]                 | C2   | B3             | N <sub>8</sub> |                |                |   | 9      | 14   | 11   | 16   |
| ±N'8[USP]            | C3   | N'8            | B3             | N <sub>8</sub> |                |   | 10     | 15   | 12   | 17   |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | B3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | B3             | N <sub>8</sub> |   | 11     | 16   | 13   | 18   |

← obj

← off N<sub>8</sub>

---

### Chapter 3 Details of Instructions

#### Instruction Set

---

**SBCB obj, #N<sub>8</sub>**

8-bit Subtract with Carry

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |    |    |   |   |   |  |    |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|--|----|--|
| <b>obj</b>         | rN, PSWH, PSWL, off N' <sub>8</sub> , N' <sub>8</sub> , [DP], ±N' <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                            |    |    |    |    |   |   |   |  |    |  |
| <b>Function</b>    | $\text{obj} \leftarrow \text{obj} - \#N_8 - C$ (byte long)                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |    |   |   |   |  |    |  |
| <b>Description</b> | <p>This instruction subtracts from the contents (byte long) of the addressing object, the 8 bit immediate value (#N<sub>8</sub>), and the contents of the carry (C).</p> <p>The resulting difference (8 bits) is stored in the addressing object, and the borrow that occurs during the subtraction is stored in the carry (C).</p>                                                                                         |    |    |    |    |   |   |   |  |    |  |
| <b>Flags</b>       | Flags affected by execution:<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr> <tr> <td>*</td><td>*</td><td>*</td><td></td></tr> </table> <span style="margin-left: 20px;">Flags affecting execution:</span> <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td></tr> <tr> <td></td></tr> </table> | ZF | CF | HC | DD | * | * | * |  | DD |  |
| ZF                 | CF                                                                                                                                                                                                                                                                                                                                                                                                                          | HC | DD |    |    |   |   |   |  |    |  |
| *                  | *                                                                                                                                                                                                                                                                                                                                                                                                                           | *  |    |    |    |   |   |   |  |    |  |
| DD                 |                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |    |    |   |   |   |  |    |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |    |    |   |   |   |  |    |  |

| obj                    | CODE |                 |                |                |                |   | CYCLES |     |
|------------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|
|                        | BYTE |                 |                |                |                |   | INT    | EXT |
|                        | 1    | 2               | 3              | 4              | 5              | 6 |        |     |
| A                      |      |                 |                |                |                |   |        |     |
| #N <sub>8</sub>        |      |                 |                |                |                |   |        |     |
| rN                     | 20+N | B0              | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                   | A2   | B0              | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                   | A3   | B0              | N <sub>8</sub> |                |                |   | 6      | —   |
| off N' <sub>8</sub>    | C4   | N' <sub>8</sub> | B0             | N <sub>8</sub> |                |   | 8      | 14  |
| N' <sub>8</sub>        | C5   | N' <sub>8</sub> | B0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                   | C2   | B0              | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N' <sub>8</sub> [USP] | C3   | N' <sub>8</sub> | B0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1]   | C0   | N <sub>L</sub>  | N <sub>H</sub> | B0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2]   | C1   | N <sub>L</sub>  | N <sub>H</sub> | B0             | N <sub>8</sub> |   | 10     | 15  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SBR obj**

Set Bit (register indirect bit addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

IF obj.bit (A<sub>2-0</sub>) = 0 THEN Z ← 1  
ELSE Z ← 0  
obj.bit (A<sub>2-0</sub>) ← 0

**Description**

This instruction sets the specified bit of the addressing object obj (byte long) to 1.

The bit location is specified by the contents of the lower 3 bits of the accumulator (A<sub>2-0</sub>) at the execution time of the instruction.

Prior to the execution of the instruction, the contents of the specified bit is examined and the zero flag (ZF) is set accordingly. If the specified bit is 0 prior to the execution of the instruction, the zero flag is 1, otherwise ZF=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 11             |                |    |   |   | 7      | 13  |
| PSWH                  | A2   | 11             |                |    |   |   | 7      | —   |
| PSWL                  | A3   | 11             |                |    |   |   | 7      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 11             |    |   |   | 9      | 16  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 11             |    |   |   | 9      | —   |
| [DP]                  | C2   | 11             |                |    |   |   | 9      | 15  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 11             |    |   |   | 10     | 16  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 11 |   |   | 11     | 17  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 11 |   |   | 11     | 17  |

### **Chapter 3 Details of Instructions**

#### **Instruction Set**

---

##### **SC**

**Set Carry**

**obj** \_\_\_\_\_

**Function** \_\_\_\_\_

$C \leftarrow 1$

**Description** \_\_\_\_\_

This instruction sets the carry (C) to 1.

**Flags** \_\_\_\_\_

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    | 1  |    |    |

|    |
|----|
| DD |
|    |

Flags affecting execution:

**Codes/Cycles** \_\_\_\_\_

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A   | 85   |   |   |   |   |   | 2      | —   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SCAL address**

Short Call

**obj**

**Function**

$(SSP) \leftarrow PC + 2$   
 $SSP \leftarrow SSP - 2$   
 $SF \leftarrow 0$   
 $PC \leftarrow \text{address}$

where  $PC^* - 128 \leq \text{address} \leq PC^* + 127$   
 $PC^* = \text{head address of the instruction following the SCAL instruction}$   
 $= (\text{address of the first byte of the SCAL instruction}) + 2$

**Description**

This instruction is a call instruction with a 7-bit displacement whose origin is at the starting address of the next instruction. The range of the call is from -128 to +127 with the starting address of the next instruction serving as the origin.

[NOTE] This call instruction manipulates the PC with the displacement. However, in the source program of the assembler (RAS66K), the destination address of a call, such as a label and not the actual displacement, is entered as the operand of the instruction. The assembler figures out the amount of the displacement, which if it stays within the allowable range, is used to generate the machine codes. If the amount of the displacement is outside of the allowable range, the assembler issues an error warning.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj | CODE |                |   |   |   |   | CYCLES |     |
|-----|------|----------------|---|---|---|---|--------|-----|
|     | BYTE |                |   |   |   |   | INT    | EXT |
|     | 1    | 2              | 3 | 4 | 5 | 6 |        |     |
|     | 31   | N <sub>g</sub> |   |   |   |   | 9      | 13  |

[NOTE] N<sub>g</sub> is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as 2's complement.

[EXAMPLE]

| Displacement | N <sub>g</sub>        |
|--------------|-----------------------|
| 0            | 00000000 <sub>b</sub> |
| +1           | 00000001 <sub>b</sub> |
| +127         | 01111111 <sub>b</sub> |
| -1           | 11111111 <sub>b</sub> |
| -127         | 10000001 <sub>b</sub> |
| -128         | 10000000 <sub>b</sub> |

## Chapter 3 Details of Instructions Instruction Set

### Example

Case where Displacement = -1, PC\* = 0100H

Machine Code: CB<sub>H</sub> FF<sub>H</sub>

PC\*

|      |      |      |      |
|------|------|------|------|
| 0000 | 0001 | 0000 | 0000 |
|------|------|------|------|

0100<sub>H</sub>

+

Displacement

|      |      |      |      |
|------|------|------|------|
| 1111 | 1111 | 1111 | 1111 |
|------|------|------|------|

-1

Sign bit is  
extended

↓

PC

|      |      |      |      |
|------|------|------|------|
| 0000 | 0000 | 1111 | 1111 |
|------|------|------|------|

00FF<sub>H</sub>

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SJ address

Short Jump

**obj**

**Function**

PC ← address

where  $PC^* - 128 \leq \text{address} \leq PC^* + 127$

$PC^*$  = head address of the instruction following the SCAL instruction  
= (address of the first byte of the SCAL instruction) + 2

**Description**

This instruction performs a jump within a 7-bit displacement whose origin is at the starting address of the instruction that follows this SJ instruction. The range of the jump of this instruction is from -128 to +127 with the starting address of the next instruction serving as the origin.

[NOTE] This jump instruction manipulates the PC with the displacement. However, in the source program of the assembler (RAS66K), the destination address of the call such as a label and not the displacement, is entered as the operand of the instruction. The assembler figures out the amount of the displacement, which if it stays within the callable range, is used to generate the machine codes. If the amount of the displacement is outside of the callable range, the assembler issues an error warning.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |                |   |   |   |   | CYCLES |     |
|-----|------|----------------|---|---|---|---|--------|-----|
|     | BYTE |                |   |   |   |   | INT    | EXT |
|     | 1    | 2              | 3 | 4 | 5 | 6 |        |     |
|     | CB   | N <sub>8</sub> |   |   |   |   | 8      | —   |

[NOTE] N<sub>8</sub> is the 8-bit code to represent the displacement in the range from -128 to +127. Negative values are expressed as the complement of 2.

[EXAMPLE]

| Displacement | N <sub>8</sub>        |
|--------------|-----------------------|
| 0            | 0000000 <sub>8</sub>  |
| +1           | 00000001 <sub>8</sub> |
| +127         | 01111111 <sub>8</sub> |
| -1           | 11111111 <sub>8</sub> |
| -127         | 10000001 <sub>8</sub> |
| -128         | 10000000 <sub>8</sub> |

### **Chapter 3 Details of Instructions Instruction Set**

---

#### **Example**

Case where Displacement = -1, PC\* = 0100H

Machine Code: CBH FFH



## Chapter 3 Details of Instructions

### Instruction Set

---

#### SLL A

16-bit Left Shift

**obj**

**Function**



$C \leftarrow A_{15}$   
 $A_n \leftarrow A_{n-1} \text{ (n=15-1)}$   
 $A_0 \leftarrow 0$

**Description**

This instruction shifts the contents (word long) of the accumulator one bit to the left. The overflow from  $A_{15}$  is entered in the carry (C).

0 (zero) is entered in  $A_0$ .

*This instruction is affected by the data descriptor (DD).*  
 For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "SLLB A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 53   |   |   |   |   |   | 2      | —   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| enN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SLL obj

16-bit Left Shift

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



**Description**

This instruction shifts the contents of the addressing object (word long) (obj) one bit to the left.

The overflow from obj<sub>15</sub> is entered in the carry (C). Also, 0 (zero) is entered in obj<sub>0</sub>.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | D7             |                |    |   |   | 5      | 13  |
| DP                    | 92   | D7             |                |    |   |   | 5      | —   |
| X1                    | 90   | D7             |                |    |   |   | 5      | —   |
| X2                    | 91   | D7             |                |    |   |   | 5      | —   |
| USP                   | A1   | D7             |                |    |   |   | 5      | —   |
| SSP                   | A0   | D7             |                |    |   |   | 5      | —   |
| LRB                   | A4   | D7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | D7             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | D7             |    |   |   | 7      | —   |
| [DP]                  | B2   | D7             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | D7             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | D7 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | D7 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SLLB A**

8-bit Left Shift

**obj**

**Function**



$$\begin{aligned} C &\leftarrow A_7 \\ A_n &\leftarrow A_{n-1} \text{ (n=7-1)} \\ A_0 &\leftarrow 0 \end{aligned}$$

**Description**

This instruction shifts the contents of the lower byte of the accumulator (AL) one bit to the left.

The overflow from A7 is entered in the carry (C) and 0 (zero) is entered in A0.

*This instruction is affected by the data descriptor (DD).*

For this instruction to be performed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "SLL A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

|    |
|----|
| DD |
| 0  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 53   |   |   |   |   |   | 2      | —   |
| #N <sub>8</sub>       |      |   |   |   |   |   |        |     |
| rN                    |      |   |   |   |   |   |        |     |
| PSWH                  |      |   |   |   |   |   |        |     |
| PSWL                  |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> (X1)  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> (X2)  |      |   |   |   |   |   |        |     |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**SLLB obj**

8-bit Left Shift

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



C ← obj<sub>7</sub>  
obj<sub>n</sub> ← obj<sub>n-1</sub> (n=7-1)  
obj<sub>0</sub> ← 0

**Description**

This instruction shifts the contents (byte long) of the addressing object (obj) one bit to the left.

The overflow from obj<sub>7</sub> is entered in the carry (C). Also, 0 (zero) is entered in obj<sub>0</sub>.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | D7             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | D7             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | D7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | D7             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | D7             |    |   |   | 7      | —   |
| [DP]                  | C2   | D7             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | D7             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | D7 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | D7 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**SRA A**

16-bit Arithmetic Right Shift

**obj**

**Function**



**Description**

This instruction arithmetically shifts the contents (word long) of the accumulator one bit to the right.

The overflow from  $A_0$  is entered in the carry (C), while bit  $A_{15}$  following the shift is entered by  $A_{15}$  itself.

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "SRAB A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 73   |   |   |   |   |   | 2      | —   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| erN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

### Chapter 3 Details of Instructions

#### Instruction Set

##### SRA obj

16-bit Arithmetic Right Shift

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



$$\begin{aligned} C &\leftarrow obj_0 \\ obj_n &\leftarrow obj_{n+1} \quad (n=14-0) \\ obj_{15} &\leftarrow obj_{15} \end{aligned}$$

**Description**

This instruction arithmetically shifts the contents of the addressing object (word long) (obj) one bit to the right.

The overflow from obj<sub>0</sub> is entered in the carry (C), while the bit obj<sub>15</sub> following the shift is entered by obj<sub>15</sub> itself.

**Flags**

Flags affected by execution:

| ZF | CF | HF | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | F7             |                |    |   |   | 5      | 13  |
| DP                    | 92   | F7             |                |    |   |   | 5      | —   |
| X1                    | 90   | F7             |                |    |   |   | 5      | —   |
| X2                    | 91   | F7             |                |    |   |   | 5      | —   |
| USP                   | A1   | F7             |                |    |   |   | 5      | —   |
| SSP                   | A0   | F7             |                |    |   |   | 5      | —   |
| LRB                   | A4   | F7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | F7             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | F7             |    |   |   | 7      | —   |
| [DP]                  | B2   | F7             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | F7             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | F7 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | F7 |   |   | 9      | 17  |

### Chapter 3 Details of Instructions

#### Instruction Set

##### SRAB A

8-bit Arithmetic Right Shift

obj

Function



$$\begin{aligned} C &\leftarrow A_0 \\ A_n &\leftarrow A_{n+1} \quad (n=6-0) \\ A_7 &\leftarrow A_7 \end{aligned}$$

##### Description

This instruction arithmetically shifts the contents of the lower byte of the accumulator ( $A_L$ ) one bit to the right.

The overflow from  $A_0$  is entered in the carry (C), while bit  $A_7$  following the shift is entered by  $A_7$  itself.

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "SRA A".

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

##### Codes/Cycles

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 73   |   |   |   |   |   | 2      | —   |
| #N <sub>8</sub>       |      |   |   |   |   |   |        |     |
| rN                    |      |   |   |   |   |   |        |     |
| PSWH                  |      |   |   |   |   |   |        |     |
| PSWL                  |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### **SRAB obj**

8-bit Arithmetic Right Shift

**obj**

**Function**



$C \leftarrow obj_0$   
 $obj_n \leftarrow obj_{n+1} \quad (n=6-0)$   
 $obj_7 \leftarrow obj_7$

**Description**

This instruction arithmetically shifts the contents (byte long) of the addressing object (obj) one bit to the right.

The overflow from obj is entered in the carry (C), while the bit obj<sub>7</sub> following the shift is entered by obj<sub>7</sub> itself.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | F7             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | F7             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | F7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | F7             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | F7             |    |   |   | 7      | —   |
| [DP]                  | C2   | F7             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | F7             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | F7 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | F7 |   |   | 9      | 13  |

## Chapter 3 Details of Instructions

---

### Instruction Set

#### SRL A

16-bit Right Shift

**obj**

**Function**



**Description**

This instruction shifts the contents (word long) of the accumulator one bit to the right.

The overflow from  $A_0$  is entered in the carry (C). Also, 0 (zero) is entered in  $A_{15}$ .

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "SRLB A".

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 63   |   |   |   |   |   | 2      | —   |
| #N <sub>16</sub>      |      |   |   |   |   |   |        |     |
| orN                   |      |   |   |   |   |   |        |     |
| DP                    |      |   |   |   |   |   |        |     |
| X1                    |      |   |   |   |   |   |        |     |
| X2                    |      |   |   |   |   |   |        |     |
| USP                   |      |   |   |   |   |   |        |     |
| SSP                   |      |   |   |   |   |   |        |     |
| LRB                   |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SRL obj

16-bit Right Shift

**obj** erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



**Description**

This instruction shifts the contents of the addressing object (word long) (obj) one bit to the right.

The overflow from obj<sub>0</sub> is entered in the carry (C). Also, 0 (zero) is entered in obj<sub>15</sub>.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | E7             |                |    |   |   | 5      | 13  |
| DP                    | 92   | E7             |                |    |   |   | 5      | —   |
| X1                    | 90   | E7             |                |    |   |   | 5      | —   |
| X2                    | 91   | E7             |                |    |   |   | 5      | —   |
| USP                   | A1   | E7             |                |    |   |   | 5      | —   |
| SSP                   | A0   | E7             |                |    |   |   | 5      | —   |
| LRB                   | A4   | E7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | E7             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | E7             |    |   |   | 7      | —   |
| [DP]                  | B2   | E7             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | E7             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | E7 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | E7 |   |   | 9      | 17  |

### Chapter 3 Details of Instructions

#### Instruction Set

##### SRLB A

8-bit Right Shift

**ob]**

**Function**



$$\begin{aligned} C &\leftarrow A_0 \\ A_n &\leftarrow A_{n+1} \quad (n=6-0) \\ A_7 &\leftarrow 0 \end{aligned}$$

##### Description

This instruction shifts the contents of the lower byte of the accumulator ( $A_L$ ) one bit to the right.

The overflow from  $A_0$  is entered in the carry (C) and 0 (zero) is entered in  $A_7$ .

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be performed correctly, it is necessary to set  $DD=0$ . When  $DD=1$ , the instruction actually executed becomes "SRL A".

##### Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

##### Codes/Cycles

| ob]                   | CODE |   |   |   |   |   | CYCLES |     |
|-----------------------|------|---|---|---|---|---|--------|-----|
|                       | BYTE |   |   |   |   |   | INT    | EXT |
|                       | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
| A                     | 63   |   |   |   |   |   | 2      | —   |
| #N <sub>8</sub>       |      |   |   |   |   |   |        |     |
| rN                    |      |   |   |   |   |   |        |     |
| PSWH                  |      |   |   |   |   |   |        |     |
| PSWL                  |      |   |   |   |   |   |        |     |
| off N <sub>8</sub>    |      |   |   |   |   |   |        |     |
| N <sub>8</sub>        |      |   |   |   |   |   |        |     |
| [DP]                  |      |   |   |   |   |   |        |     |
| ±N <sub>8</sub> [USP] |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X1]  |      |   |   |   |   |   |        |     |
| N <sub>16</sub> [X2]  |      |   |   |   |   |   |        |     |

### Chapter 3 Details of Instructions Instruction Set

---

#### SRLB obj

8-bit Right Shift

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**



C ← obj  
obj<sub>n</sub> ← obj<sub>n+1</sub> (n=6—0)  
A<sub>7</sub> ← 0

**Description**

This instruction shifts the contents (byte long) of the addressing object (obj) one bit to the right.

The overflow from obj<sub>0</sub> is entered in the carry (C). Also, 0 (zero) is entered in obj<sub>7</sub>.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    | *  |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | E7             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | E7             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | E7             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | E7             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | E7             |    |   |   | 7      | —   |
| [DP]                  | C2   | E7             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | E7             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | E7 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | E7 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**ST A, obj**

16-bit Transfer

**obj**

erN, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A → obj (word long)

**Description**

This instruction transfers the contents of the accumulator to the addressing object (word long).

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "STB A, obj".

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
| 1  |

**Codes/Cycles**

| obj                   | CODE |                |                |   |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|---|---|---|--------|-----|
|                       | BYTE |                |                |   |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4 | 5 | 6 |        |     |
| A                     |      |                |                |   |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |   |   |   |        |     |
| erN                   | 88+N |                |                |   |   |   | 2      | 6   |
| DP                    |      |                |                |   |   |   |        |     |
| X1                    |      |                |                |   |   |   |        |     |
| X2                    |      |                |                |   |   |   |        |     |
| USP                   |      |                |                |   |   |   |        |     |
| SSP                   |      |                |                |   |   |   |        |     |
| LRB                   |      |                |                |   |   |   |        |     |
| off N <sub>8</sub>    | D4   | N <sub>8</sub> |                |   |   |   | 4      | 9   |
| N <sub>8</sub>        | D5   | N <sub>8</sub> |                |   |   |   | 4      | —   |
| [DP]                  | D2   |                |                |   |   |   | 4      | 8   |
| ±N <sub>8</sub> [USP] | D3   | N <sub>8</sub> |                |   |   |   | 5      | 9   |
| N <sub>16</sub> [X1]  | D0   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 10  |
| N <sub>16</sub> [X2]  | D1   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**STB A, obj**

8-bit Transfer

|     |                                                                                                                   |
|-----|-------------------------------------------------------------------------------------------------------------------|
| obj | rN, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-------------------------------------------------------------------------------------------------------------------|

|          |                                  |
|----------|----------------------------------|
| Function | A <sub>L</sub> → obj (byte long) |
|----------|----------------------------------|

|             |                                                                                                                                  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction transfers the contents of the lower byte of accumulator (A <sub>L</sub> ) to the addressing object (byte long). |
|-------------|----------------------------------------------------------------------------------------------------------------------------------|

*This instruction is affected by the data descriptor (DD). For this instruction to be executed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "ST A, obj".*

|       |                                                                                                                                                                  |    |    |    |    |  |  |  |  |                                                                                                     |    |   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|--|--|--|--|-----------------------------------------------------------------------------------------------------|----|---|
| Flags | Flags affected by execution:<br><br><table border="1"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td></td><td></td><td></td><td></td></tr></table> | ZF | CF | HC | DD |  |  |  |  | Flags affecting execution:<br><br><table border="1"><tr><td>DD</td></tr><tr><td>0</td></tr></table> | DD | 0 |
| ZF    | CF                                                                                                                                                               | HC | DD |    |    |  |  |  |  |                                                                                                     |    |   |
|       |                                                                                                                                                                  |    |    |    |    |  |  |  |  |                                                                                                     |    |   |
| DD    |                                                                                                                                                                  |    |    |    |    |  |  |  |  |                                                                                                     |    |   |
| 0     |                                                                                                                                                                  |    |    |    |    |  |  |  |  |                                                                                                     |    |   |

| obj                   | CODE |                |                |   |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|---|---|---|--------|-----|
|                       | BYTE |                |                |   |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4 | 5 | 6 |        |     |
| A                     |      |                |                |   |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |   |   |   |        |     |
| rN                    | 88+N |                |                |   |   |   | 2      | 4   |
| PSWH                  |      |                |                |   |   |   |        |     |
| PSWL                  |      |                |                |   |   |   |        |     |
| off N <sub>8</sub>    | D4   | N <sub>8</sub> |                |   |   |   | 4      | 7   |
| N <sub>8</sub>        | D5   | N <sub>8</sub> |                |   |   |   | 4      | —   |
| [DP]                  | D2   |                |                |   |   |   | 4      | 6   |
| ±N <sub>8</sub> [USP] | D3   | N <sub>8</sub> |                |   |   |   | 5      | 7   |
| N <sub>16</sub> [X1]  | D0   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 8   |
| N <sub>16</sub> [X2]  | D1   | N <sub>L</sub> | N <sub>H</sub> |   |   |   | 6      | 8   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUB A, obj**

16-bit Subtract

**obj**

#N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ← A - obj (word long)

**Description**

This instruction subtracts the contents of the addressing object from the contents of the accumulator in a word long operation. The resulting difference (16 bits) is stored in the accumulator. The borrow that occurs during the subtraction is stored in the carry.

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=1.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | A6   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 28+N |                |                |    |   |   | 3      | 7   |
| DP                    | 92   | A2             |                |    |   |   | 4      | —   |
| X1                    | 90   | A2             |                |    |   |   | 4      | —   |
| X2                    | 91   | A2             |                |    |   |   | 4      | —   |
| USP                   | A1   | A2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | A2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | A2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | A7   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | A2             |    |   |   | 6      | —   |
| [DP]                  | B2   | A2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | A2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | A2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | A2 |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUB obj, A**

16-bit Subtract

|     |                                                                                                                                               |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| obj | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|

|          |                           |
|----------|---------------------------|
| Function | obj ← obj - A (word long) |
|----------|---------------------------|

|             |                                                                                                                                 |
|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction subtracts the contents of the accumulator from the contents of the addressing object in a word long operation. |
|-------------|---------------------------------------------------------------------------------------------------------------------------------|

The resulting difference (16 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

|       |                                                |                                  |
|-------|------------------------------------------------|----------------------------------|
| Flags | Flags affected by execution:<br>ZF, CF, HC, DD | Flags affecting execution:<br>DD |
|-------|------------------------------------------------|----------------------------------|

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | A1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | A1             |                |    |   |   | 5      | —   |
| X1                    | 90   | A1             |                |    |   |   | 5      | —   |
| X2                    | 91   | A1             |                |    |   |   | 5      | —   |
| USP                   | A1   | A1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | A1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | A1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | A1             |    |   |   | 7      | 18  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | A1             |    |   |   | 7      | —   |
| [DP]                  | B2   | A1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | A1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | A1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | A1 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUB obj, off N<sub>8</sub>**

16-bit Subtract

**obj** erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function** obj ← obj - off N<sub>8</sub> (word long)

**Description** This instruction subtracts the contents of the data memory specified by direct page addressing (off N<sub>8</sub>) from the contents of the addressing object in a word long operation.

The resulting difference (16 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 1  |

**Codes/Cycles**

| obj                  | CODE |                |                |                |                |   | CYCLES |     |      |      |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                      | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                    |      |                |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>     |      |                |                |                |                |   |        |     |      |      |
| erN                  | 44+N | A3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                   | 92   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                   | 90   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                   | 91   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                  | A1   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                  | A0   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                  | A4   | A3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>   | B4   | N'8            | A3             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N <sub>8</sub>       | B5   | N'8            | A3             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                 | B2   | A3             | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N'8[USP]            | B3   | N'8            | A3             |                |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1] | B0   | N <sub>L</sub> | N <sub>H</sub> | A3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2] | B1   | N <sub>L</sub> | N <sub>H</sub> | A3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUB obj, #N<sub>16</sub>**

16-bit Subtract

|     |                                                                                                                       |
|-----|-----------------------------------------------------------------------------------------------------------------------|
| obj | erN, DP, X1, X2, USP, SSP, LRB, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N'16[X1], N'16[X2] |
|-----|-----------------------------------------------------------------------------------------------------------------------|

|          |                                          |
|----------|------------------------------------------|
| Function | obj ← obj - #N <sub>16</sub> (word long) |
|----------|------------------------------------------|

|             |                                                                                                                                   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction subtracts the 16 bit immediate value (#N <sub>16</sub> ) from the contents of the addressing object (word long). |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------|

The resulting difference (16 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

|       |                                                                                                                                                                 |    |    |    |    |   |   |   |  |                                                                                                |    |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|--|------------------------------------------------------------------------------------------------|----|--|
| Flags | Flags affected by execution:<br><table border="1"><tr><td>ZF</td><td>CF</td><td>HC</td><td>DD</td></tr><tr><td>*</td><td>*</td><td>*</td><td></td></tr></table> | ZF | CF | HC | DD | * | * | * |  | Flags affecting execution:<br><table border="1"><tr><td>DD</td></tr><tr><td></td></tr></table> | DD |  |
| ZF    | CF                                                                                                                                                              | HC | DD |    |    |   |   |   |  |                                                                                                |    |  |
| *     | *                                                                                                                                                               | *  |    |    |    |   |   |   |  |                                                                                                |    |  |
| DD    |                                                                                                                                                                 |    |    |    |    |   |   |   |  |                                                                                                |    |  |
|       |                                                                                                                                                                 |    |    |    |    |   |   |   |  |                                                                                                |    |  |

| o b j                 | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | A0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | A0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | A0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | A0              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | A0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | A0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

## Chapter 3 Details of Instructions

### Instruction Set

---

#### SUBB A, obj

8-bit Subtract

**obj**

---

#N<sub>8</sub>, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

---

A<sub>L</sub> ← A<sub>L</sub> - obj (byte long)

**Description**

---

This instruction subtracts the contents (byte long) of the addressing object from the contents of the lower byte of the accumulator (A<sub>L</sub>).

The resulting difference (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>). The borrow that occurs during the subtraction is stored in the carry (C).

*This instruction is affected by the data descriptor (DD). For this instruction to be executed correctly, it is necessary to set DD=0.*

**Flags**

---

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

---

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | A6   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 28+N |                |                |    |   |   | 3      | 5   |
| PSWH                  | A2   | A2             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | A2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | A2             |    |   |   | 5      | —   |
| [DP]                  | C2   | A2             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | A2             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | A2 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | A2 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUBB obj, A**

8-bit Subtract

|     |                                                                                                                               |
|-----|-------------------------------------------------------------------------------------------------------------------------------|
| obj | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|-------------------------------------------------------------------------------------------------------------------------------|

|          |                                        |
|----------|----------------------------------------|
| Function | obj ← obj - A <sub>L</sub> (byte long) |
|----------|----------------------------------------|

|             |                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | This instruction subtracts the contents of the lower byte of the accumulator (A <sub>L</sub> ) from the contents (byte long) of the addressing object. |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|

The resulting difference (8 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

|       |                              |                            |
|-------|------------------------------|----------------------------|
| Flags | Flags affected by execution: | Flags affecting execution: |
|-------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

| DD |
|----|
|    |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | A1             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | A1             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | A1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | A1             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | A1             |    |   |   | 7      | —   |
| [DP]                  | C2   | A1             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | A1             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | A1 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | A1 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUBB obj, off N<sub>8</sub>**

8-bit Subtract

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj - off N<sub>8</sub> (byte long)

**Description**

This instruction subtracts from the addressing object, the data memory specified by direct page addressing (off N<sub>8</sub>).

The resulting difference (8 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |                |   | CYCLES |     |      |      |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                       | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                     |      |                |                |                |                |   |        |     |      |      |
| ±N <sub>8</sub>       |      |                |                |                |                |   |        |     |      |      |
| rN                    | 20+N | A3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   |
| PSWH                  | A2   | A3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| PSWL                  | A3   | A3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | A3             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | A3             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |
| [DP]                  | C2   | A3             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | A3             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | A3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | A3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |

← obj

← off N<sub>8</sub>

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SUBB obj, #N<sub>8</sub>**

8-bit Subtract

|     |                                                                                                                                  |
|-----|----------------------------------------------------------------------------------------------------------------------------------|
| obj | rN, PSWH, PSWL, off N' <sub>8</sub> , N' <sub>8</sub> , [DP], ±N' <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|-----|----------------------------------------------------------------------------------------------------------------------------------|

|          |                                         |
|----------|-----------------------------------------|
| Function | obj ← obj - #N <sub>8</sub> (byte long) |
|----------|-----------------------------------------|

|             |                                                                                                                 |
|-------------|-----------------------------------------------------------------------------------------------------------------|
| Description | This instruction subtracts the 8-bit immediate value (#N <sub>8</sub> ) from the addressing object (byte long). |
|-------------|-----------------------------------------------------------------------------------------------------------------|

The resulting difference (8 bits) is stored in the addressing object. The borrow that occurs during the subtraction is stored in the carry (C).

|       |                              |                            |
|-------|------------------------------|----------------------------|
| Flags | Flags affected by execution: | Flags affecting execution: |
|-------|------------------------------|----------------------------|

| ZF | CF | HC | DD |
|----|----|----|----|
| *  | *  | *  |    |

| DD |
|----|
|    |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                    | CODE |                 |                |                |                |   | CYCLES |     |
|------------------------|------|-----------------|----------------|----------------|----------------|---|--------|-----|
|                        | BYTE |                 |                |                |                |   | INT    | EXT |
|                        | 1    | 2               | 3              | 4              | 5              | 6 |        |     |
| A                      |      |                 |                |                |                |   |        |     |
| #N <sub>8</sub>        |      |                 |                |                |                |   |        |     |
| rN                     | 20+N | A0              | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                   | A2   | A0              | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                   | A3   | A0              | N <sub>8</sub> |                |                |   | 6      | —   |
| off N' <sub>8</sub>    | C4   | N' <sub>8</sub> | A0             | N <sub>8</sub> |                |   | 8      | 14  |
| N' <sub>8</sub>        | C5   | N' <sub>8</sub> | A0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                   | C2   | A0              | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N' <sub>8</sub> [USP] | C3   | N' <sub>8</sub> | A0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1]   | C0   | N <sub>L</sub>  | N <sub>H</sub> | A0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2]   | C1   | N <sub>L</sub>  | N <sub>H</sub> | A0             | N <sub>8</sub> |   | 10     | 15  |

## Chapter 3 Details of Instructions

### Instruction Set

#### SWAP

16-bit Swap

obj

Function



Description

This instruction exchanges the upper byte (A<sub>H</sub>) and the lower byte (A<sub>L</sub>) of the accumulator.

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=1. When DD=0, the instruction actually executed becomes "SWAPS".

Flags

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HF | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
| 1  |

Codes/Cycles

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 83   |   |   |   |   |   | 2      | —   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**SWAPB**

8-bit Swap

**obj**

**Function**



**Description**

This instruction exchanges the upper 4 bits and the lower 4 bits of the lower byte of the accumulator ( $A_L$ ).

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=0. When DD=1, the instruction actually executed becomes "SWAP".

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

|    |
|----|
| DD |
| 0  |

Flags affecting execution:

**Codes/Cycles**

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 83   |   |   |   |   |   | 2      | -   |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**TBR obj**

Test Bit (Register Indirect Bit Addressing)

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

IF obj.bit (A<sub>2-0</sub>) = 0 THEN Z ← 1  
ELSE Z ← 0

**Description**

This instruction tests the contents of the specified bit of the the addressing object (byte long).

The location of the bit is specified by the contents of the lower 3 bits of the accumulator (A<sub>2-0</sub>) at the execution time of the instruction.

If the specified bit is 0, the zero flag (Z) is set to 1; otherwise the zero flag is set to 0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 13             |                |    |   |   | 4      | 6   |
| PSWH                  | A2   | 13             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | 13             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 13             |    |   |   | 6      | 9   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 13             |    |   |   | 6      | —   |
| [DP]                  | C2   | 13             |                |    |   |   | 6      | 8   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 13             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 13 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 13 |   |   | 8      | 10  |

## Chapter 3 Details of Instructions Instruction Set

---

### VCAL table-address

Vector Call

|                 |  |
|-----------------|--|
| <b>obj</b>      |  |
| <b>Function</b> |  |

(SSP)  $\leftarrow$  PC + 1  
 SSP  $\leftarrow$  SSP - 2  
 SF  $\leftarrow$  0  
 PC  $\leftarrow$  (table-address)

where "table-address" must be an even-numbered address of the VCAL table space (28H—37H).

#### Description

This instruction calls the vector address in the VCAL space.

After the return address is saved in the system stack and SSP is revised, the contents of the ROM at the address specified by "table-address" is stored in the lower 8 bits of the PC, while the contents of the ROM whose address follows the first ROM address is stored in the upper 8 bits of the PC.

*This instruction clears the stack flag (SF) by setting it to 0.*

#### Flags

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

#### Codes/Cycles

| obj | CODE |   |   |   |   |   | CYCLES |     |
|-----|------|---|---|---|---|---|--------|-----|
|     | BYTE |   |   |   |   |   | INT    | EXT |
|     | 1    | 2 | 3 | 4 | 5 | 6 |        |     |
|     | 10+n |   |   |   |   |   | 11     | 15  |

[NOTE] The value of n varies with the "table-address" as shown in the following table.

| table-address | n | table-address | n |
|---------------|---|---------------|---|
| 0028H         | 0 | 0030H         | 4 |
| 002AH         | 1 | 0032H         | 5 |
| 002CH         | 2 | 0034H         | 6 |
| 002EH         | 3 | 0036H         | 7 |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**XCHG A, obj**

16-bit Exchange

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A ↔ obj (word long)

**Description**

This instruction exchanges the contents of the addressing object and the accumulator in a word long operation.

*This instruction is affected by the data descriptor (DD).*  
For this instruction to be executed correctly, it is necessary to set DD=1.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
| 1  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | 10             |                |    |   |   | 5      | 13  |
| DP                    | 92   | 10             |                |    |   |   | 5      | —   |
| X1                    | 90   | 10             |                |    |   |   | 5      | —   |
| X2                    | 91   | 10             |                |    |   |   | 5      | —   |
| USP                   | A1   | 10             |                |    |   |   | 5      | —   |
| SSP                   | A0   | 10             |                |    |   |   | 5      | —   |
| LRB                   | A4   | 10             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | 10             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | 10             |    |   |   | 7      | —   |
| [DP]                  | B2   | 10             |                |    |   |   | 8      | 16  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | 10             |    |   |   | 9      | 17  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | 10 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | 10 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XCHGB A, obj** 8-bit Exchange

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

A<sub>L</sub> ↔ obj (byte long)

**Description**

This instruction exchanges the contents of the addressing object and the lower byte of the accumulator (A<sub>L</sub>) in a byte long operation.

*This instruction is affected by the data description (DD).*

For this instruction to be executed correctly, it is necessary to set DD=0.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
|    |    |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N | 10             |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | 10             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | 10             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | 10             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | 10             |    |   |   | 7      | —   |
| [DP]                  | C2   | 10             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | 10             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | 10 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | 10 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XNBL A, off N<sub>8</sub>**

4-bit (Nibble) Exchange

**obj**

---

**Function**

A<sub>3—0</sub> ↔ off N<sub>8</sub> 3—0

**Description**

This instruction exchanges the lower 4 bits of the data memory specified by direct addressing (off N<sub>8</sub>) and the lower 4 bits of the accumulator.

**Flags**

Flags affected by execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
|    |    |    |    |

Flags affecting execution:

|    |
|----|
| DD |
|    |

**Codes/Cycles**

| obj | CODE |                |   |   |   |   | CYCLES |     |
|-----|------|----------------|---|---|---|---|--------|-----|
|     | BYTE |                |   |   |   |   | INT    | EXT |
|     | 1    | 2              | 3 | 4 | 5 | 6 |        |     |
|     | 84   | N <sub>8</sub> |   |   |   |   | 5      | 10  |

### Chapter 3 Details of Instructions Instruction Set

---

**XOR A, obj**

16-bit Exclusive OR

**obj**      #N<sub>16</sub>, erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**      A ← A ⊕ obj (word long)

**Description**      This instruction performs an exclusive OR operation on the contents of the accumulator and the addressing object. The result (16 bits) is stored in the accumulator.

*This instruction is affected by the data descriptor (DD). For this instruction to be executed correctly, it is necessary to set DD=1.*

**Flags**      Flags affected by execution: Flags affecting execution:

|    |    |    |    |
|----|----|----|----|
| ZF | CF | HC | DD |
| *  |    |    |    |

|    |
|----|
| DD |
| 1  |

---

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      | F6   | N <sub>L</sub> | N <sub>H</sub> |    |   |   | 6      | —   |
| erN                   | 68+N |                |                |    |   |   | 4      | 8   |
| DP                    | 92   | F2             |                |    |   |   | 4      | —   |
| X1                    | 90   | F2             |                |    |   |   | 4      | —   |
| X2                    | 91   | F2             |                |    |   |   | 4      | —   |
| USP                   | A1   | F2             |                |    |   |   | 4      | —   |
| SSP                   | A0   | F2             |                |    |   |   | 4      | —   |
| LRB                   | A4   | F2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | F7   | N <sub>8</sub> |                |    |   |   | 4      | 9   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | F2             |    |   |   | 6      | —   |
| [DP]                  | B2   | F2             |                |    |   |   | 6      | 10  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | F2             |    |   |   | 7      | 11  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | F2 |   |   | 8      | 12  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | F2 |   |   | 8      | 12  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**XOR obj, A**

16-bit Exclusive OR

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj ⊕ A (word long)

**Description**

This instruction performs a word long exclusive OR operation on the contents of the addressing object and the accumulator.

The result (16 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>16</sub>      |      |                |                |    |   |   |        |     |
| erN                   | 44+N | F1             |                |    |   |   | 5      | 13  |
| DP                    | 92   | F1             |                |    |   |   | 5      | —   |
| X1                    | 90   | F1             |                |    |   |   | 5      | —   |
| X2                    | 91   | F1             |                |    |   |   | 5      | —   |
| USP                   | A1   | F1             |                |    |   |   | 5      | —   |
| SSP                   | A0   | F1             |                |    |   |   | 5      | —   |
| LRB                   | A4   | F1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | F1             |    |   |   | 7      | 16  |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | F1             |    |   |   | 7      | —   |
| [DP]                  | B2   | F1             |                |    |   |   | 7      | 15  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | F1             |    |   |   | 8      | 16  |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | F1 |   |   | 9      | 17  |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | F1 |   |   | 9      | 17  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XOR obj, off N<sub>8</sub>**

16-bit Exclusive OR

**obj**

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj  $\vee$  off N<sub>8</sub> (word long)

**Description**

This instruction performs a word long exclusive OR operation on the contents of the addressing object and the data memory specified by direct page addressing (off N<sub>8</sub>).

The result (16 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |                |                |   | CYCLES |     |      |      |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|
|                       | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |
| A                     |      |                |                |                |                |   |        |     |      |      |
| #N <sub>16</sub>      |      |                |                |                |                |   |        |     |      |      |
| erN                   | 44+N | F3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 20   |
| DP                    | 92   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X1                    | 90   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| X2                    | 91   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| USP                   | A1   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| SSP                   | A0   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| LRB                   | A4   | F3             | N <sub>8</sub> |                |                |   | 7      | 16  | —    | —    |
| off N <sub>8</sub>    | B4   | N <sub>8</sub> | F3             | N <sub>8</sub> |                |   | 9      | —   | —    | 23   |
| N <sub>8</sub>        | B5   | N <sub>8</sub> | F3             | N <sub>8</sub> |                |   | 9      | 18  | —    | —    |
| [DP]                  | B2   | F3             | N <sub>8</sub> |                |                |   | 9      | 18  | 13   | 22   |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub> | F3             |                |                |   | 10     | 19  | 14   | 23   |
| N <sub>16</sub> [X1]  | B0   | N <sub>L</sub> | N <sub>H</sub> | F3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |
| N <sub>16</sub> [X2]  | B1   | N <sub>L</sub> | N <sub>H</sub> | F3             | N <sub>8</sub> |   | 11     | 20  | 15   | 24   |

← obj

← off N<sub>8</sub>

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XOR obj, #N<sub>16</sub>**

16-bit Exclusive OR

obj

erN, DP, X1, X2, USP, SSP, LRB, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N'16[X1], N'16[X2]

Function

obj ← obj ∨ #N<sub>16</sub> (word long)

Description

This instruction performs an exclusive OR operation on the contents of the addressing object (word long) and the 16-bit immediate value (#N<sub>16</sub>).

The result is stored in the addressing object.

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj                   | CODE |                 |                 |                |                |                | CYCLES |     |
|-----------------------|------|-----------------|-----------------|----------------|----------------|----------------|--------|-----|
|                       | BYTE |                 |                 |                |                |                | INT    | EXT |
|                       | 1    | 2               | 3               | 4              | 5              | 6              |        |     |
| A                     |      |                 |                 |                |                |                |        |     |
| #N <sub>16</sub>      |      |                 |                 |                |                |                |        |     |
| erN                   | 44+N | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | 17  |
| DP                    | 92   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X1                    | 90   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| X2                    | 91   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| USP                   | A1   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| SSP                   | A0   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| LRB                   | A4   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 8      | —   |
| off N <sub>8</sub>    | B4   | N <sub>8</sub>  | F0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | 20  |
| N <sub>8</sub>        | B5   | N <sub>8</sub>  | F0              | N <sub>L</sub> | N <sub>H</sub> |                | 10     | —   |
| [DP]                  | B2   | F0              | N <sub>L</sub>  | N <sub>H</sub> |                |                | 10     | 19  |
| ±N <sub>8</sub> [USP] | B3   | N <sub>8</sub>  | F0              | N <sub>L</sub> | N <sub>H</sub> |                | 11     | 20  |
| N'16[X1]              | B0   | N' <sub>L</sub> | N' <sub>H</sub> | F0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |
| N'16[X2]              | B1   | N' <sub>L</sub> | N' <sub>H</sub> | F0             | N <sub>L</sub> | N <sub>H</sub> | 12     | 21  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XORB A, obj**

8-bit Exclusive OR

|     |  |
|-----|--|
| obj |  |
|-----|--|

#Ng, rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

|          |  |
|----------|--|
| Function |  |
|----------|--|

A<sub>L</sub> ← A<sub>L</sub> ∨ obj (byte long)

|             |  |
|-------------|--|
| Description |  |
|-------------|--|

This instruction performs an exclusive OR operation on the contents of the lower byte of the accumulator (A<sub>L</sub>) and the addressing object (byte long).

The result (8 bits) is stored in the lower byte of the accumulator (A<sub>L</sub>).

*This instruction is affected by the data descriptor (DD).*

For this instruction to be executed correctly, it is necessary to set DD=0.

|       |  |
|-------|--|
| Flags |  |
|-------|--|

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
| 0  |

|              |  |
|--------------|--|
| Codes/Cycles |  |
|--------------|--|

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       | F6   | N <sub>8</sub> |                |    |   |   | 4      | —   |
| rN                    | 20+N | F2             |                |    |   |   | 4      | 6   |
| PSWH                  | A2   | F2             |                |    |   |   | 4      | —   |
| PSWL                  | A3   | F2             |                |    |   |   | 4      | —   |
| off N <sub>8</sub>    | F7   | N <sub>8</sub> |                |    |   |   | 4      | 7   |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | F2             |    |   |   | 6      | —   |
| [DP]                  | C2   | F2             |                |    |   |   | 6      | —   |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | F2             |    |   |   | 7      | 9   |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | F2 |   |   | 8      | 10  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | F2 |   |   | 8      | 10  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

**XORB obj, A**

8-bit Exclusive OR

**obj**

rN, PSWH, PSWL, off N<sub>8</sub>, N<sub>8</sub>, [DP], ±N<sub>8</sub>[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

**Function**

obj ← obj  $\vee$  A<sub>L</sub> (byte long)

**Description**

This instruction performs an exclusive OR operation on the contents of the lower byte of the accumulator (A<sub>L</sub>) and the addressing object (byte long).

The result (8 bits) is stored in the addressing object.

**Flags**

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

**Codes/Cycles**

| obj                   | CODE |                |                |    |   |   | CYCLES |     |
|-----------------------|------|----------------|----------------|----|---|---|--------|-----|
|                       | BYTE |                |                |    |   |   | INT    | EXT |
|                       | 1    | 2              | 3              | 4  | 5 | 6 |        |     |
| A                     |      |                |                |    |   |   |        |     |
| #N <sub>8</sub>       |      |                |                |    |   |   |        |     |
| rN                    | 20+N |                |                |    |   |   | 5      | 9   |
| PSWH                  | A2   | F1             |                |    |   |   | 5      | —   |
| PSWL                  | A3   | F1             |                |    |   |   | 5      | —   |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | F1             |    |   |   | 7      | 12  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | F1             |    |   |   | 7      | —   |
| [DP]                  | C2   | F1             |                |    |   |   | 7      | 11  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | F1             |    |   |   | 8      | 12  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | F1 |   |   | 9      | 13  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | F1 |   |   | 9      | 13  |

**Chapter 3 Details of Instructions**  
**Instruction Set**

---

**XORB obj, off N<sub>8</sub>**

8-bit Exclusive OR

|            |                                                                                                                               |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| <b>obj</b> | rN, PSWH, PSWL, off N <sub>8</sub> , N <sub>8</sub> , [DP], ±N <sub>8</sub> [USP], N <sub>16</sub> [X1], N <sub>16</sub> [X2] |
|------------|-------------------------------------------------------------------------------------------------------------------------------|

|                 |                                                 |
|-----------------|-------------------------------------------------|
| <b>Function</b> | obj ← obj $\vee$ off N <sub>8</sub> (byte long) |
|-----------------|-------------------------------------------------|

|                    |                                                                                                                                                                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | This instruction performs a byte long exclusive OR operation on the contents of the addressing object and the data memory specified by direct page addressing (off N <sub>8</sub> ).<br><br>The result (8 bits) is stored in the addressing object. |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|              |                                                                                                                                                                                                   |                            |    |    |    |   |  |  |  |                                                                                                                                |    |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|----|----|---|--|--|--|--------------------------------------------------------------------------------------------------------------------------------|----|--|
| <b>Flags</b> | Flags affected by execution:                                                                                                                                                                      | Flags affecting execution: |    |    |    |   |  |  |  |                                                                                                                                |    |  |
|              | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>ZF</td> <td>CF</td> <td>HC</td> <td>DD</td> </tr> <tr> <td>*</td> <td></td> <td></td> <td></td> </tr> </table> | ZF                         | CF | HC | DD | * |  |  |  | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>DD</td> </tr> <tr> <td></td> </tr> </table> | DD |  |
| ZF           | CF                                                                                                                                                                                                | HC                         | DD |    |    |   |  |  |  |                                                                                                                                |    |  |
| *            |                                                                                                                                                                                                   |                            |    |    |    |   |  |  |  |                                                                                                                                |    |  |
| DD           |                                                                                                                                                                                                   |                            |    |    |    |   |  |  |  |                                                                                                                                |    |  |
|              |                                                                                                                                                                                                   |                            |    |    |    |   |  |  |  |                                                                                                                                |    |  |

| o b j                 | CODE |                |                |                |                |   | CYCLES |     |      |      | ← obj                |  |
|-----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|------|------|----------------------|--|
|                       | BYTE |                |                |                |                |   | INT    | INT | EX T | EX T |                      |  |
|                       | 1    | 2              | 3              | 4              | 5              | 6 |        |     |      |      |                      |  |
| A                     |      |                |                |                |                |   |        |     |      |      |                      |  |
| #N <sub>8</sub>       |      |                |                |                |                |   |        |     |      |      |                      |  |
| rN                    | 20+N | F3             | N <sub>8</sub> |                |                |   | 7      | —   | —    | 14   | ← off N <sub>8</sub> |  |
| PSWH                  | A2   | F3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |                      |  |
| PSWL                  | A3   | F3             | N <sub>8</sub> |                |                |   | 7      | 12  | —    | —    |                      |  |
| off N <sub>8</sub>    | C4   | N <sub>8</sub> | F3             | N <sub>8</sub> |                |   | 9      | —   | —    | 17   |                      |  |
| N <sub>8</sub>        | C5   | N <sub>8</sub> | F3             | N <sub>8</sub> |                |   | 9      | 14  | —    | —    |                      |  |
| [DP]                  | C2   | F3             | N <sub>8</sub> |                |                |   | 9      | 14  | 11   | 16   |                      |  |
| ±N <sub>8</sub> [USP] | C3   | N <sub>8</sub> | F3             | N <sub>8</sub> |                |   | 10     | 15  | 12   | 17   |                      |  |
| N <sub>16</sub> [X1]  | C0   | N <sub>L</sub> | N <sub>H</sub> | F3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |                      |  |
| N <sub>16</sub> [X2]  | C1   | N <sub>L</sub> | N <sub>H</sub> | F3             | N <sub>8</sub> |   | 11     | 16  | 13   | 18   |                      |  |

## Chapter 3 Details of Instructions

### Instruction Set

#### XORB obj, #N<sub>8</sub>

8-bit Exclusive OR

obj

rN, PSWH, PSWL, off N'8, N'8, [DP], ±N'8[USP], N<sub>16</sub>[X1], N<sub>16</sub>[X2]

Function

obj ← obj ∨ #N<sub>8</sub> (byte long)

Description

This instruction performs an exclusive OR operation on the contents (byte long) of the addressing object and the 8-bit immediate value (#N<sub>8</sub>).

The result (8 bits) is stored in the addressing object.

Flags

Flags affected by execution:

| ZF | CF | HC | DD |
|----|----|----|----|
| *  |    |    |    |

Flags affecting execution:

| DD |
|----|
|    |

Codes/Cycles

| obj                  | CODE |                |                |                |                |   | CYCLES |     |
|----------------------|------|----------------|----------------|----------------|----------------|---|--------|-----|
|                      | BYTE |                |                |                |                |   | INT    | EXT |
|                      | 1    | 2              | 3              | 4              | 5              | 6 |        |     |
| A                    |      |                |                |                |                |   |        |     |
| #N <sub>8</sub>      |      |                |                |                |                |   |        |     |
| rN                   | 20+N | F0             | N <sub>8</sub> |                |                |   | 6      | 11  |
| PSWH                 | A2   | F0             | N <sub>8</sub> |                |                |   | 6      | —   |
| PSWL                 | A3   | F0             | N <sub>8</sub> |                |                |   | 6      | —   |
| off N'8              | C4   | N'8            | F0             | N <sub>8</sub> |                |   | 8      | 14  |
| N'8                  | C5   | N'8            | F0             | N <sub>8</sub> |                |   | 8      | —   |
| [DP]                 | C2   | F0             | N <sub>8</sub> |                |                |   | 8      | 13  |
| ±N'8[USP]            | C3   | N'8            | F0             | N <sub>8</sub> |                |   | 9      | 14  |
| N <sub>16</sub> [X1] | C0   | N <sub>L</sub> | N <sub>H</sub> | F0             | N <sub>8</sub> |   | 10     | 15  |
| N <sub>16</sub> [X2] | C1   | N <sub>L</sub> | N <sub>H</sub> | F0             | N <sub>8</sub> |   | 10     | 15  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-1. Data Transfer Instructions (1)**

\*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                    | Operation                              | Int '1 | Int '1 | Ext '1 | Ext '1 | Byte no. | Flags |    |    |    | Page |
|-----|------------------------------|----------------------------------------|--------|--------|--------|--------|----------|-------|----|----|----|------|
|     |                              |                                        | Int '2 | Ext '2 | Int '2 | Ext '2 |          | ZF    | CF | HC | DD |      |
| 1   | L A, #N <sub>16</sub>        | A ← #N <sub>16</sub>                   | 6      | —      | —      | —      | 3        | •     | •  | •  | •  | 70   |
|     | L A, erN                     | A ← erN                                | 2      | 6      | —      | —      | 1        | •     | •  | •  | •  | 70   |
|     | L A, DP                      | A ← DP                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 70   |
|     | L A, X1                      | A ← X1                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 70   |
|     | L A, X2                      | A ← X2                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 70   |
|     | L A, off N <sub>8</sub>      | A ← off N <sub>8</sub>                 | 4      | 9      | —      | —      | 2        | •     | •  | •  | •  | 70   |
|     | L A, N <sub>8</sub>          | A ← N <sub>8</sub>                     | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 70   |
|     | L A, [DP]                    | A ← [DP]                               | 4      | 8      | —      | —      | 1        | •     | •  | •  | •  | 70   |
|     | L A, ±N <sub>8</sub> [USP]   | A ← ±N <sub>8</sub> [USP]              | 5      | 9      | —      | —      | 2        | •     | •  | •  | •  | 70   |
|     | L A, N <sub>16</sub> [X1]    | A ← N <sub>16</sub> [X1]               | 6      | 10     | —      | —      | 3        | •     | •  | •  | •  | 70   |
|     | L A, N <sub>16</sub> [X2]    | A ← N <sub>16</sub> [X2]               | 6      | 10     | —      | —      | 3        | •     | •  | •  | •  | 70   |
| 12  | LB A, #N <sub>8</sub>        | A <sub>L</sub> ← #N <sub>8</sub>       | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 71   |
|     | LB A, rN                     | A <sub>L</sub> ← rN                    | 2      | 4      | —      | —      | 1        | •     | •  | •  | •  | 71   |
|     | LB A, off N <sub>8</sub>     | A <sub>L</sub> ← off N <sub>8</sub>    | 4      | 7      | —      | —      | 2        | •     | •  | •  | •  | 71   |
|     | LB A, N <sub>8</sub>         | A <sub>L</sub> ← N <sub>8</sub>        | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 71   |
|     | LB A, [DP]                   | A <sub>L</sub> ← [DP]                  | 4      | 6      | —      | —      | 1        | •     | •  | •  | •  | 71   |
|     | LB A, ±N <sub>8</sub> [USP]  | A <sub>L</sub> ← ±N <sub>8</sub> [USP] | 5      | 7      | —      | —      | 2        | •     | •  | •  | •  | 71   |
|     | LB A, N <sub>16</sub> [X1]   | A <sub>L</sub> ← N <sub>16</sub> [X1]  | 6      | 8      | —      | —      | 3        | •     | •  | •  | •  | 71   |
|     | LB A, N <sub>16</sub> [X2]   | A <sub>L</sub> ← N <sub>16</sub> [X2]  | 6      | 8      | —      | —      | 3        | •     | •  | •  | •  | 71   |
| 20  | ST A, erN                    | A → erN                                | 2      | 6      | —      | —      | 1        | •     | •  | •  | •  | 155  |
|     | ST A, off N <sub>8</sub>     | A → off N <sub>8</sub>                 | 4      | 9      | —      | —      | 2        | •     | •  | •  | •  | 155  |
|     | ST A, N <sub>8</sub>         | A → N <sub>8</sub>                     | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 155  |
|     | ST A, [DP]                   | A → [DP]                               | 4      | 8      | —      | —      | 2        | •     | •  | •  | •  | 155  |
|     | ST A, ±N <sub>8</sub> [USP]  | A → ±N <sub>8</sub> [USP]              | 5      | 9      | —      | —      | 2        | •     | •  | •  | •  | 155  |
|     | ST A, N <sub>16</sub> [X1]   | A → N <sub>16</sub> [X1]               | 6      | 10     | —      | —      | 3        | •     | •  | •  | •  | 155  |
|     | ST A, N <sub>16</sub> [X2]   | A → N <sub>16</sub> [X2]               | 6      | 10     | —      | —      | 3        | •     | •  | •  | •  | 155  |
| 27  | STB A, rN                    | A <sub>L</sub> → rN                    | 2      | 4      | —      | —      | 1        | •     | •  | •  | •  | 156  |
|     | STB A, off N <sub>8</sub>    | A <sub>L</sub> → off N <sub>8</sub>    | 4      | 7      | —      | —      | 2        | •     | •  | •  | •  | 156  |
|     | STB A, N <sub>8</sub>        | A <sub>L</sub> → N <sub>8</sub>        | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 156  |
|     | STB A, [DP]                  | A <sub>L</sub> → [DP]                  | 4      | 6      | —      | —      | 1        | •     | •  | •  | •  | 156  |
|     | STB A, ±N <sub>8</sub> [USP] | A <sub>L</sub> → ±N <sub>8</sub> [USP] | 5      | 7      | —      | —      | 2        | •     | •  | •  | •  | 156  |
|     | STB A, N <sub>16</sub> [X1]  | A <sub>L</sub> → N <sub>16</sub> [X1]  | 6      | 8      | —      | —      | 3        | •     | •  | •  | •  | 156  |
|     | STB A, N <sub>16</sub> [X2]  | A <sub>L</sub> → N <sub>16</sub> [X2]  | 6      | 8      | —      | —      | 3        | •     | •  | •  | •  | 156  |
| 34  | MOV A, erN                   | A ← erN                                | 4      | 8      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, DP                    | A ← DP                                 | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, X1                    | A ← X1                                 | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, X2                    | A ← X2                                 | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, USP                   | A ← USP                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, SSP                   | A ← SSP                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, LRB                   | A ← LRB                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, off N <sub>8</sub>    | A ← off N <sub>8</sub>                 | 6      | 11     | —      | —      | 3        | •     | •  | •  | •  | 82   |
|     | MOV A, N <sub>8</sub>        | A ← N <sub>8</sub>                     | 6      | —      | —      | —      | 3        | •     | •  | •  | •  | 82   |
|     | MOV A, [DP]                  | A ← [DP]                               | 6      | 10     | —      | —      | 2        | •     | •  | •  | •  | 82   |
|     | MOV A, ±N <sub>8</sub> [USP] | A ← ±N <sub>8</sub> [USP]              | 7      | 11     | —      | —      | 3        | •     | •  | •  | •  | 82   |
|     | MOV A, N <sub>16</sub> [X1]  | A ← N <sub>16</sub> [X1]               | 8      | 12     | —      | —      | 4        | •     | •  | •  | •  | 82   |
|     | MOV A, N <sub>16</sub> [X2]  | A ← N <sub>16</sub> [X2]               | 8      | 12     | —      | —      | 4        | •     | •  | •  | •  | 82   |
| 47  | MOV erN, A                   | erN ← A                                | 4      | —      | 12     | —      | 2        | •     | •  | •  | •  | 85   |
|     | MOV DP, A                    | DP ← A                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 85   |
|     | MOV X1, A                    | X1 ← A                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 85   |
|     | MOV X2, A                    | X2 ← A                                 | 2      | —      | —      | —      | 1        | •     | •  | •  | •  | 85   |
|     | MOV USP, A                   | USP ← A                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 85   |
|     | MOV SSP, A                   | SSP ← A                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 85   |
|     | MOV LRB, A                   | LRB ← A                                | 4      | —      | —      | —      | 2        | •     | •  | •  | •  | 85   |
|     | MOV off N <sub>8</sub> , A   | off N <sub>8</sub> ← A                 | 6      | —      | 15     | —      | 3        | •     | •  | •  | •  | 85   |
|     | MOV N <sub>8</sub> , A       | N <sub>8</sub> ← A                     | 6      | —      | —      | —      | 3        | •     | •  | •  | •  | 85   |
|     | MOV [DP], A                  | [DP] ← A                               | 6      | —      | 14     | —      | 2        | •     | •  | •  | •  | 85   |
|     | MOV ±N <sub>8</sub> [USP], A | ±N <sub>8</sub> [USP] ← A              | 7      | —      | 15     | —      | 3        | •     | •  | •  | •  | 85   |
|     | MOV N <sub>16</sub> [X1], A  | N <sub>16</sub> [X1] ← A               | 8      | —      | 16     | —      | 4        | •     | •  | •  | •  | 85   |
|     | MOV N <sub>16</sub> [X2], A  | N <sub>16</sub> [X2] ← A               | 8      | —      | 16     | —      | 4        | •     | •  | •  | •  | 85   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-2. Data Transfer Instructions (2)**

\*1 - the first operand  
 \*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Int <sup>*1</sup>                                                                     | Int <sup>*1</sup>                                                                                                                                              | Ext <sup>*1</sup>                                                                                                                                        | Ext <sup>*1</sup>                                                                 | Byte no. | Flags |    |    |    | Page |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------|-------|----|----|----|------|
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Int <sup>*2</sup>                                                                     | Ext <sup>*2</sup>                                                                                                                                              | Int <sup>*2</sup>                                                                                                                                        | Ext <sup>*2</sup>                                                                 |          | ZF    | CF | HC | DD |      |
| 60  | MOV arN, #N <sub>16</sub><br>MOV DP, #N <sub>16</sub><br>MOV X1, #N <sub>16</sub><br>MOV X2, #N <sub>16</sub><br>MOV USP, #N <sub>16</sub><br>MOV SSP, #N <sub>16</sub><br>MOV LRB, #N <sub>16</sub><br>MOV off N <sub>8</sub> , #N <sub>16</sub><br>MOV N <sub>8</sub> , #N <sub>16</sub><br>MOV [DP], #N <sub>16</sub><br>MOV ±N <sub>8</sub> [USP], #N <sub>16</sub><br>MOV N <sub>16</sub> [X1], #N <sub>16</sub><br>MOV N <sub>16</sub> [X2], #N <sub>16</sub>                                                                                                                 | arN ← #N <sub>16</sub><br>DP ← #N <sub>16</sub><br>X1 ← #N <sub>16</sub><br>X2 ← #N <sub>16</sub><br>USP ← #N <sub>16</sub><br>SSP ← #N <sub>16</sub><br>LRB ← #N <sub>16</sub><br>off N <sub>8</sub> ← #N <sub>16</sub><br>N <sub>8</sub> ← #N <sub>16</sub><br>[DP] ← #N <sub>16</sub><br>±N <sub>8</sub> [USP] ← #N <sub>16</sub><br>N <sub>16</sub> [X1] ← #N <sub>16</sub><br>N <sub>16</sub> [X2] ← #N <sub>16</sub>                                                                                              | 8<br>6<br>6<br>6<br>8<br>8<br>6<br>10<br>10<br>10<br>11<br>12                         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>16<br>—<br>16<br>16<br>16                                                                                                   | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—                                                                                                 | 4<br>3<br>3<br>3<br>4<br>4<br>3<br>5<br>5<br>4<br>5<br>6                          |          |       |    |    | 67 |      |
| 73  | MOV arN, A<br>MOV arN, #N <sub>16</sub><br>MOV arN, arN'<br>MOV arN, DP<br>MOV arN, X1<br>MOV arN, X2<br>MOV arN, USP<br>MOV arN, SSP<br>MOV arN, LRB<br>MOV arN, off N <sub>8</sub><br>MOV arN, N <sub>8</sub><br>MOV arN, [DP]<br>MOV arN, ±N <sub>8</sub> [USP]<br>MOV arN, N <sub>16</sub> [X1]<br>MOV arN, N <sub>16</sub> [X2]                                                                                                                                                                                                                                                | arN ← A<br>arN ← #N <sub>16</sub><br>arN ← arN'<br>arN ← DP<br>arN ← X1<br>arN ← X2<br>arN ← USP<br>arN ← SSP<br>arN ← LRB<br>arN ← off N <sub>8</sub><br>arN ← N <sub>8</sub><br>arN ← [DP]<br>arN ← ±N <sub>8</sub> [USP]<br>arN ← N <sub>16</sub> [X1]<br>arN ← N <sub>16</sub> [X2]                                                                                                                                                                                                                                 | 4<br>8<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8               | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>10<br>10<br>11<br>11<br>12                                                                         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>10<br>11<br>11<br>15                                                                   | 2<br>4<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4<br>4           |          |       |    |    | 64 |      |
| 88  | MOV off N <sub>8</sub> , A<br>MOV off N <sub>8</sub> , #N <sub>16</sub><br>MOV off N <sub>8</sub> , arN<br>MOV off N <sub>8</sub> , DP<br>MOV off N <sub>8</sub> , X1<br>MOV off N <sub>8</sub> , X2<br>MOV off N <sub>8</sub> , USP<br>MOV off N <sub>8</sub> , SSP<br>MOV off N <sub>8</sub> , LRB<br>MOV off N <sub>8</sub> , off N <sub>8</sub><br>MOV off N <sub>8</sub> , N <sub>8</sub><br>MOV off N <sub>8</sub> , [DP]<br>MOV off N <sub>8</sub> , ±N <sub>8</sub> [USP]<br>MOV off N <sub>8</sub> , N <sub>16</sub> [X1]<br>MOV off N <sub>8</sub> , N <sub>16</sub> [X2] | off N <sub>8</sub> ← A<br>off N <sub>8</sub> ← #N <sub>16</sub><br>off N <sub>8</sub> ← arN<br>off N <sub>8</sub> ← DP<br>off N <sub>8</sub> ← X1<br>off N <sub>8</sub> ← X2<br>off N <sub>8</sub> ← USP<br>off N <sub>8</sub> ← SSP<br>off N <sub>8</sub> ← LRB<br>off N <sub>8</sub> ← off N <sub>8</sub><br>off N <sub>8</sub> ← N <sub>8</sub><br>off N <sub>8</sub> ← [DP]<br>off N <sub>8</sub> ← ±N <sub>8</sub> [USP]<br>off N <sub>8</sub> ← N <sub>16</sub> [X1]<br>off N <sub>8</sub> ← N <sub>16</sub> [X2] | 6<br>10<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>8<br>8<br>8<br>9<br>9<br>10<br>10<br>10 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>19<br>15<br>11<br>11<br>11<br>11<br>11<br>11<br>13<br>13<br>13<br>13<br>14<br>14<br>15<br>15 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>15<br>15<br>11<br>11<br>11<br>11<br>11<br>13<br>13<br>13<br>13<br>14<br>14<br>15<br>15 | 3<br>5<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>4<br>4<br>4<br>4<br>4<br>4<br>5<br>5 |          |       |    |    | 65 |      |
| 103 | MOV DP, A<br>MOV DP, #N <sub>16</sub><br>MOV DP, arN<br>MOV DP, DP<br>MOV DP, X1<br>MOV DP, X2<br>MOV DP, USP<br>MOV DP, SSP<br>MOV DP, LRB<br>MOV DP, off N <sub>8</sub><br>MOV DP, N <sub>8</sub><br>MOV DP, [DP]<br>MOV DP, ±N <sub>8</sub> [USP]<br>MOV DP, N <sub>16</sub> [X1]<br>MOV DP, N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                | DP ← A<br>DP ← #N <sub>16</sub><br>DP ← arN<br>DP ← DP<br>DP ← X1<br>DP ← X2<br>DP ← USP<br>DP ← SSP<br>DP ← LRB<br>DP ← off N <sub>8</sub><br>DP ← N <sub>8</sub><br>DP ← [DP]<br>DP ← ±N <sub>8</sub> [USP]<br>DP ← N <sub>16</sub> [X1]<br>DP ← N <sub>16</sub> [X2]                                                                                                                                                                                                                                                 | 2<br>6<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>6<br>7<br>8<br>6<br>6     | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>10<br>11<br>11<br>11                                                                               | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—                                                                   | 1<br>3<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>3<br>3<br>4<br>4 |          |       |    |    | 63 |      |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-3. Data Transfer Instructions (3)**

\*1 - the first operand

\*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                                                                                                                                          | Operation                                                                                                                                                                                                                                                                             | Int '1                                                                  | Int '1                                                                       | Ext '1                                                                       | Ext '1                                                                  | Byte no.                                                      | Flags                                                         |                                                               |                                                               | Page |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|------|
|     |                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                       | Int '2 Cyc                                                              | Ext '2 Cyc                                                                   | Int '2 Cyc                                                                   | Ext '2 Cyc                                                              |                                                               | ZF                                                            | CF                                                            | HC                                                            |      |
| 118 | MOV X1, A<br>MOV X1, #N <sub>16</sub><br>MOV X1, eN<br>MOV X1, DP<br>MOV X1, X1<br>MOV X1, X2<br>MOV X1, USP<br>MOV X1, SSP<br>MOV X1, LRB<br>MOV X1, off N <sub>8</sub><br>MOV X1, N <sub>8</sub><br>MOV X1, [DP]<br>MOV X1, ±N <sub>8</sub> [USP]<br>MOV X1, N <sub>16</sub> [X1]<br>MOV X1, N <sub>16</sub> [X2]                | X1 ← A<br>X1 ← #N <sub>16</sub><br>X1 ← eN<br>X1 ← DP<br>X1 ← X1<br>X1 ← X2<br>X1 ← USP<br>X1 ← SSP<br>X1 ← LRB<br>X1 ← off N <sub>8</sub><br>X1 ← N <sub>8</sub><br>X1 ← [DP]<br>X1 ← ±N <sub>8</sub> [USP]<br>X1 ← N <sub>16</sub> [X1]<br>X1 ← N <sub>16</sub> [X2]                | 2<br>6<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8 | —<br>—<br>8<br>—<br>—<br>—<br>—<br>—<br>—<br>11<br>—<br>10<br>11<br>12<br>12 | —<br>—<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4<br>4 | 1<br>3<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>3<br>3 |                                                               |                                                               |                                                               |                                                               | 32   |
| 133 | MOV X2, A<br>MOV X2, #N <sub>16</sub><br>MOV X2, eN<br>MOV X2, DP<br>MOV X2, X1<br>MOV X2, X2<br>MOV X2, USP<br>MOV X2, SSP<br>MOV X2, LRB<br>MOV X2, off N <sub>8</sub><br>MOV X2, N <sub>8</sub><br>MOV X2, [DP]<br>MOV X2, ±N <sub>8</sub> [USP]<br>MOV X2, N <sub>16</sub> [X1]<br>MOV X2, N <sub>16</sub> [X2]                | X2 ← A<br>X2 ← #N <sub>16</sub><br>X2 ← eN<br>X2 ← DP<br>X2 ← X1<br>X2 ← X2<br>X2 ← USP<br>X2 ← SSP<br>X2 ← LRB<br>X2 ← off N <sub>8</sub><br>X2 ← N <sub>8</sub><br>X2 ← [DP]<br>X2 ← ±N <sub>8</sub> [USP]<br>X2 ← N <sub>16</sub> [X1]<br>X2 ← N <sub>16</sub> [X2]                | 2<br>6<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8 | —<br>—<br>8<br>—<br>—<br>—<br>—<br>—<br>—<br>11<br>—<br>10<br>11<br>12<br>12 | —<br>—<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4<br>4 | 1<br>3<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>3<br>3 |                                                               |                                                               |                                                               |                                                               | 32   |
| 148 | MOV USP, A<br>MOV USP, #N <sub>16</sub><br>MOV USP, eN<br>MOV USP, DP<br>MOV USP, X1<br>MOV USP, X2<br>MOV USP, USP<br>MOV USP, SSP<br>MOV USP, LRB<br>MOV USP, off N <sub>8</sub><br>MOV USP, N <sub>8</sub><br>MOV USP, [DP]<br>MOV USP, ±N <sub>8</sub> [USP]<br>MOV USP, N <sub>16</sub> [X1]<br>MOV USP, N <sub>16</sub> [X2] | USP ← A<br>USP ← #N <sub>16</sub><br>USP ← eN<br>USP ← DP<br>USP ← X1<br>USP ← X2<br>USP ← USP<br>USP ← SSP<br>USP ← LRB<br>USP ← off N <sub>8</sub><br>USP ← N <sub>8</sub><br>USP ← [DP]<br>USP ← ±N <sub>8</sub> [USP]<br>USP ← N <sub>16</sub> [X1]<br>USP ← N <sub>16</sub> [X2] | 4<br>8<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8 | —<br>—<br>8<br>—<br>—<br>—<br>—<br>—<br>—<br>11<br>—<br>10<br>11<br>12<br>12 | —<br>—<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4<br>4 | 2<br>4<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>3<br>3 |                                                               |                                                               |                                                               |                                                               | 32   |
| 163 | MOV PSW, eN<br>MOV PSW, DP<br>MOV PSW, X1<br>MOV PSW, X2<br>MOV PSW, USP<br>MOV PSW, SSP<br>MOV PSW, LRB<br>MOV PSW, off N <sub>8</sub><br>MOV PSW, N <sub>8</sub><br>MOV PSW, [DP]<br>MOV PSW, ±N <sub>8</sub> [USP]<br>MOV PSW, N <sub>16</sub> [X1]<br>MOV PSW, N <sub>16</sub> [X2]                                            | PSW ← eN<br>PSW ← DP<br>PSW ← X1<br>PSW ← X2<br>PSW ← USP<br>PSW ← SSP<br>PSW ← LRB<br>PSW ← off N <sub>8</sub><br>PSW ← N <sub>8</sub><br>PSW ← [DP]<br>PSW ← ±N <sub>8</sub> [USP]<br>PSW ← N <sub>16</sub> [X1]<br>PSW ← N <sub>16</sub> [X2]                                      | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8           | 8<br>—<br>—<br>—<br>—<br>—<br>—<br>11<br>—<br>10<br>11<br>12<br>12           | —<br>—<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4           | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4           | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | 32   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-4. Data Transfer Instructions (4)**

\*1 - the first operand  
 \*2 - the second operand

| No. | Mnemonics                                   | Operation                                          | Int '1 | Int '1 | Ext '1 | Ext '1 | Byte no. | Flags |    |    |    | Page |
|-----|---------------------------------------------|----------------------------------------------------|--------|--------|--------|--------|----------|-------|----|----|----|------|
|     |                                             |                                                    | Int '2 | Ext '2 | Int '2 | Ext '2 |          | ZF    | CF | HC | DD |      |
| 176 | MOV SSP, A                                  | SSP $\leftarrow$ A                                 | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, #N <sub>16</sub>                   | SSP $\leftarrow$ #N <sub>16</sub>                  | 6      | —      |        |        | 4        |       |    |    |    | 88   |
|     | MOV SSP, eN                                 | SSP $\leftarrow$ eN                                | 4      | 8      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, DP                                 | SSP $\leftarrow$ DP                                | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, X1                                 | SSP $\leftarrow$ X1                                | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, X2                                 | SSP $\leftarrow$ X2                                | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, USP                                | SSP $\leftarrow$ USP                               | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, SSP                                | SSP $\leftarrow$ SSP                               | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, LRB                                | SSP $\leftarrow$ LRB                               | 4      | —      |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, off N <sub>8</sub>                 | SSP $\leftarrow$ off N <sub>8</sub>                | 6      | 11     |        |        | 3        |       |    |    |    | 88   |
|     | MOV SSP, N <sub>8</sub>                     | SSP $\leftarrow$ N <sub>8</sub>                    | 6      | —      |        |        | 3        |       |    |    |    | 88   |
|     | MOV SSP, [DP]                               | SSP $\leftarrow$ [DP]                              | 6      | 10     |        |        | 2        |       |    |    |    | 88   |
|     | MOV SSP, ±N <sub>8</sub> [USP]              | SSP $\leftarrow$ ±N <sub>8</sub> [USP]             | 7      | 11     |        |        | 3        |       |    |    |    | 88   |
|     | MOV SSP, N <sub>16</sub> [X1]               | SSP $\leftarrow$ N <sub>16</sub> [X1]              | 8      | 12     |        |        | 4        |       |    |    |    | 88   |
|     | MOV SSP, N <sub>16</sub> [X2]               | SSP $\leftarrow$ N <sub>16</sub> [X2]              | 8      | 12     |        |        | 4        |       |    |    |    | 88   |
| 191 | MOV LRB, A                                  | LRB $\leftarrow$ A                                 | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, #N <sub>16</sub>                   | LRB $\leftarrow$ #N <sub>16</sub>                  | 6      | —      |        |        | 3        |       |    |    |    | 85   |
|     | MOV LRB, eN                                 | LRB $\leftarrow$ eN                                | 4      | 8      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, DP                                 | LRB $\leftarrow$ DP                                | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, X1                                 | LRB $\leftarrow$ X1                                | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, X2                                 | LRB $\leftarrow$ X2                                | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, USP                                | LRB $\leftarrow$ USP                               | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, SSP                                | LRB $\leftarrow$ SSP                               | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, LRB                                | LRB $\leftarrow$ LRB                               | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, off N <sub>8</sub>                 | LRB $\leftarrow$ off N <sub>8</sub>                | 6      | 11     |        |        | 3        |       |    |    |    | 85   |
|     | MOV LRB, N <sub>8</sub>                     | LRB $\leftarrow$ N <sub>8</sub>                    | 6      | —      |        |        | 3        |       |    |    |    | 85   |
|     | MOV LRB, [DP]                               | LRB $\leftarrow$ [DP]                              | 6      | 10     |        |        | 2        |       |    |    |    | 85   |
|     | MOV LRB, ±N <sub>8</sub> [USP]              | LRB $\leftarrow$ ±N <sub>8</sub> [USP]             | 7      | 11     |        |        | 3        |       |    |    |    | 85   |
|     | MOV LRB, N <sub>16</sub> [X1]               | LRB $\leftarrow$ N <sub>16</sub> [X1]              | 8      | 12     |        |        | 4        |       |    |    |    | 85   |
|     | MOV LRB, N <sub>16</sub> [X2]               | LRB $\leftarrow$ N <sub>16</sub> [X2]              | 8      | 12     |        |        | 4        |       |    |    |    | 85   |
| 206 | MOVB A, rN                                  | A <sub>L</sub> $\leftarrow$ rN                     | 4      | 6      |        |        | 2        |       |    |    |    | 0    |
|     | MOVB A, PSWH                                | A <sub>L</sub> $\leftarrow$ PSWH                   | 4      | —      |        |        | 2        |       |    |    |    | 0    |
|     | MOVB A, PSWL                                | A <sub>L</sub> $\leftarrow$ PSWL                   | 4      | —      |        |        | 2        |       |    |    |    | 0    |
|     | MOVB A, off N <sub>8</sub>                  | A <sub>L</sub> $\leftarrow$ off N <sub>8</sub>     | 6      | 9      |        |        | 3        |       |    |    |    | 0    |
|     | MOVB A, N <sub>8</sub>                      | A <sub>L</sub> $\leftarrow$ N <sub>8</sub>         | 6      | —      |        |        | 3        |       |    |    |    | 0    |
|     | MOVB A, [DP]                                | A <sub>L</sub> $\leftarrow$ [DP]                   | 6      | 8      |        |        | 2        |       |    |    |    | 0    |
|     | MOVB A, ±N <sub>8</sub> [USP]               | A <sub>L</sub> $\leftarrow$ ±N <sub>8</sub> [USP]  | 7      | 9      |        |        | 3        |       |    |    |    | 0    |
|     | MOVB A, N <sub>16</sub> [X1]                | A <sub>L</sub> $\leftarrow$ N <sub>16</sub> [X1]   | 8      | 10     |        |        | 4        |       |    |    |    | 0    |
|     | MOVB A, N <sub>16</sub> [X2]                | A <sub>L</sub> $\leftarrow$ N <sub>16</sub> [X2]   | 8      | 10     |        |        | 4        |       |    |    |    | 0    |
| 215 | MOVB rN, A                                  | rN $\leftarrow$ A <sub>L</sub>                     | 4      | 8      |        |        | 2        |       |    |    |    | 85   |
|     | MOVB PSWH, A                                | PSWH $\leftarrow$ A <sub>L</sub>                   | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOVB PSWL, A                                | PSWL $\leftarrow$ A <sub>L</sub>                   | 4      | —      |        |        | 2        |       |    |    |    | 85   |
|     | MOVB off N <sub>8</sub> , A                 | off N <sub>8</sub> $\leftarrow$ A <sub>L</sub>     | 6      | 11     |        |        | 3        |       |    |    |    | 85   |
|     | MOVB N <sub>8</sub> , A                     | N <sub>8</sub> $\leftarrow$ A <sub>L</sub>         | 6      | —      |        |        | 3        |       |    |    |    | 85   |
|     | MOVB [DP], A                                | [DP] $\leftarrow$ A <sub>L</sub>                   | 6      | 10     |        |        | 2        |       |    |    |    | 85   |
|     | MOVB ±N <sub>8</sub> [USP], A               | ±N <sub>8</sub> [USP] $\leftarrow$ A <sub>L</sub>  | 7      | 11     |        |        | 3        |       |    |    |    | 85   |
|     | MOVB N <sub>16</sub> [X1], A                | N <sub>16</sub> [X1] $\leftarrow$ A <sub>L</sub>   | 8      | 12     |        |        | 4        |       |    |    |    | 85   |
|     | MOVB N <sub>16</sub> [X2], A                | N <sub>16</sub> [X2] $\leftarrow$ A <sub>L</sub>   | 8      | 12     |        |        | 4        |       |    |    |    | 85   |
| 224 | MOVB rN, #N <sub>8</sub>                    | rN $\leftarrow$ #N <sub>8</sub>                    | 4      | 6      |        |        | 2        |       |    |    |    | 0    |
|     | MOVB PSWH, #N <sub>8</sub>                  | PSWH $\leftarrow$ #N <sub>8</sub>                  | 6      | —      |        |        | 3        |       |    |    |    | 0    |
|     | MOVB PSWL, #N <sub>8</sub>                  | PSWL $\leftarrow$ #N <sub>8</sub>                  | 6      | —      |        |        | 3        |       |    |    |    | 0    |
|     | MOVB off N <sub>8</sub> , #N <sub>8</sub>   | off N <sub>8</sub> $\leftarrow$ #N <sub>8</sub>    | 8      | 13     |        |        | 4        |       |    |    |    | 0    |
|     | MOVB N <sub>8</sub> , #N <sub>8</sub>       | N <sub>8</sub> $\leftarrow$ #N <sub>8</sub>        | 8      | —      |        |        | 4        |       |    |    |    | 0    |
|     | MOVB [DP], #N <sub>8</sub>                  | [DP] $\leftarrow$ #N <sub>8</sub>                  | 8      | 12     |        |        | 3        |       |    |    |    | 0    |
|     | MOVB ±N <sub>8</sub> [USP], #N <sub>8</sub> | ±N <sub>8</sub> [USP] $\leftarrow$ #N <sub>8</sub> | 9      | 13     |        |        | 4        |       |    |    |    | 0    |
|     | MOVB N <sub>16</sub> [X1], #N <sub>8</sub>  | N <sub>16</sub> [X1] $\leftarrow$ #N <sub>8</sub>  | 10     | 14     |        |        | 5        |       |    |    |    | 0    |
|     | MOVB N <sub>16</sub> [X2], #N <sub>8</sub>  | N <sub>16</sub> [X2] $\leftarrow$ #N <sub>8</sub>  | 10     | 14     |        |        | 5        |       |    |    |    | 0    |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-5. Data Transfer Instructions (5)**

\*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                        | Operation                                  | Int *1<br>Cyc | Int *2<br>Cyc | Ext *1<br>Cyc | Ext *2<br>Cyc | Byte no. | Flags |    |    |    | Page |
|-----|--------------------------------------------------|--------------------------------------------|---------------|---------------|---------------|---------------|----------|-------|----|----|----|------|
|     |                                                  |                                            |               |               |               |               |          | ZF    | CF | HC | DD |      |
| 233 | MOV B rN, A                                      | rN ← A                                     | 4             | —             | 8             | —             | 2        |       |    |    |    | 100  |
|     | MOV B rN, #N <sub>8</sub>                        | rN ← #N <sub>8</sub>                       | 4             | —             | 6             | —             | 2        |       |    |    |    | 100  |
|     | MOV B rN, rN'                                    | rN ← rN'                                   | 4             | —             | —             | —             | 2        |       |    |    |    | 100  |
|     | MOV B rN, PSWH                                   | rN ← PSWH                                  | 4             | —             | 5             | —             | 2        |       |    |    |    | 100  |
|     | MOV B rN, PSWL                                   | rN ← PSWL                                  | 4             | —             | 5             | —             | 2        |       |    |    |    | 100  |
|     | MOV B rN, off N <sub>8</sub>                     | rN ← off N <sub>8</sub>                    | 6             | —             | —             | —             | 3        |       |    |    |    | 100  |
|     | MOV B rN, N <sub>8</sub>                         | rN ← N <sub>8</sub>                        | 6             | —             | 8             | —             | 3        |       |    |    |    | 100  |
|     | MOV B rN, [DP]                                   | rN ← [DP]                                  | 6             | 8             | 8             | 10            | 2        |       |    |    |    | 100  |
|     | MOV B rN, ±N <sub>8</sub> [USP]                  | rN ← ±N <sub>8</sub> [USP]                 | 7             | 9             | 9             | 11            | 3        |       |    |    |    | 100  |
|     | MOV B rN, N <sub>16</sub> [X1]                   | rN ← N <sub>16</sub> [X1]                  | 8             | 10            | 10            | 12            | 4        |       |    |    |    | 100  |
|     | MOV B rN, N <sub>16</sub> [X2]                   | rN ← N <sub>16</sub> [X2]                  | 8             | 10            | 10            | 12            | 4        |       |    |    |    | 100  |
| 244 | MOV B off N <sub>8</sub> , A                     | off N <sub>8</sub> ← A                     | 4             | —             | 8             | —             | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , #N <sub>8</sub>       | off N <sub>8</sub> ← #N <sub>8</sub>       | 4             | —             | 6             | —             | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , rN                    | off N <sub>8</sub> ← rN                    | 4             | —             | —             | —             | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , PSWH                  | off N <sub>8</sub> ← PSWH                  | 4             | —             | 6             | —             | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , PSWL                  | off N <sub>8</sub> ← PSWL                  | 4             | —             | 6             | —             | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , off N <sub>8</sub>    | off N <sub>8</sub> ← off N <sub>8</sub>    | 6             | —             | —             | —             | 3        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , N <sub>8</sub>        | off N <sub>8</sub> ← N <sub>8</sub>        | 6             | —             | 8             | —             | 3        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , [DP]                  | off N <sub>8</sub> ← [DP]                  | 6             | 8             | 8             | 10            | 2        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , ±N <sub>8</sub> [USP] | off N <sub>8</sub> ← ±N <sub>8</sub> [USP] | 7             | 9             | 9             | 11            | 3        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , N <sub>16</sub> [X1]  | off N <sub>8</sub> ← N <sub>16</sub> [X1]  | 8             | 10            | 10            | 12            | 4        |       |    |    |    | 95   |
|     | MOV B off N <sub>8</sub> , N <sub>16</sub> [X2]  | off N <sub>8</sub> ← N <sub>16</sub> [X2]  | 8             | 10            | 10            | 12            | 4        |       |    |    |    | 95   |
| 255 | MOV B PSWH, A                                    | PSWH ← A                                   | 4             | —             | —             | —             | 2        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, #N <sub>8</sub>                      | PSWH ← #N <sub>8</sub>                     | 6             | —             | —             | —             | 3        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, rN                                   | PSWH ← rN                                  | 4             | 6             | —             | —             | 2        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, PSWH                                 | PSWH ← PSWH                                | 4             | —             | —             | —             | 2        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, PSWL                                 | PSWH ← PSWL                                | 4             | —             | —             | —             | 2        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, off N <sub>8</sub>                   | PSWH ← off N <sub>8</sub>                  | 6             | 9             | —             | —             | 3        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, N <sub>8</sub>                       | PSWH ← N <sub>8</sub>                      | 6             | —             | —             | —             | 3        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, [DP]                                 | PSWH ← [DP]                                | 6             | 8             | —             | —             | 2        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, ±N <sub>8</sub> [USP]                | PSWH ← ±N <sub>8</sub> [USP]               | 7             | 9             | —             | —             | 3        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, N <sub>16</sub> [X1]                 | PSWH ← N <sub>16</sub> [X1]                | 8             | 10            | —             | —             | 4        | .     | .  | .  | .  | 98   |
|     | MOV B PSWH, N <sub>16</sub> [X2]                 | PSWH ← N <sub>16</sub> [X2]                | 8             | 10            | —             | —             | 4        | .     | .  | .  | .  | 98   |
| 266 | MOV B PSWL, A                                    | PSWL ← A                                   | 4             | —             | —             | —             | 2        |       |    |    |    | 98   |
|     | MOV B PSWL, #N <sub>8</sub>                      | PSWL ← #N <sub>8</sub>                     | 6             | —             | —             | —             | 3        |       |    |    |    | 98   |
|     | MOV B PSWL, rN                                   | PSWL ← rN                                  | 4             | 6             | —             | —             | 2        |       |    |    |    | 98   |
|     | MOV B PSWL, PSWH                                 | PSWL ← PSWH                                | 4             | —             | —             | —             | 2        |       |    |    |    | 98   |
|     | MOV B PSWL, PSWL                                 | PSWL ← PSWL                                | 4             | —             | —             | —             | 2        |       |    |    |    | 98   |
|     | MOV B PSWL, off N <sub>8</sub>                   | PSWL ← off N <sub>8</sub>                  | 6             | 9             | —             | —             | 3        |       |    |    |    | 98   |
|     | MOV B PSWL, N <sub>8</sub>                       | PSWL ← N <sub>8</sub>                      | 6             | —             | —             | —             | 3        |       |    |    |    | 98   |
|     | MOV B PSWL, [DP]                                 | PSWL ← [DP]                                | 6             | 8             | —             | —             | 2        |       |    |    |    | 98   |
|     | MOV B PSWL, ±N <sub>8</sub> [USP]                | PSWL ← ±N <sub>8</sub> [USP]               | 7             | 9             | —             | —             | 3        |       |    |    |    | 98   |
|     | MOV B PSWL, N <sub>16</sub> [X1]                 | PSWL ← N <sub>16</sub> [X1]                | 8             | 10            | —             | —             | 4        |       |    |    |    | 98   |
|     | MOV B PSWL, N <sub>16</sub> [X2]                 | PSWL ← N <sub>16</sub> [X2]                | 8             | 10            | —             | —             | 4        |       |    |    |    | 98   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-6. Clear and Exchange Instructions**

\*1 - the first operand

\*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                                                                                  | Operation                                                                                                                                                                                                              | Int <sup>1</sup>                                              | Int <sup>1</sup>        | Ext <sup>1</sup>                                                    | Ext <sup>1</sup>        | Ext <sup>1</sup>        | Ext <sup>1</sup>        | Byte<br>no.                                                   | Flags |    |    | Page                                                                                           |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------|---------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|---------------------------------------------------------------|-------|----|----|------------------------------------------------------------------------------------------------|
|     |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                        | Int <sup>2</sup><br>Cyc                                       | Ext <sup>2</sup><br>Cyc | Int <sup>2</sup><br>Cyc                                             | Ext <sup>2</sup><br>Cyc | Ext <sup>2</sup><br>Cyc | Ext <sup>2</sup><br>Cyc |                                                               | ZF    | CF | HC |                                                                                                |
| 277 | CLR A                                                                                                                                                                                                                                                                      | A <sub>16</sub> ← 0<br>DD ← 1                                                                                                                                                                                          | 2                                                             |                         |                                                                     |                         |                         |                         | 1                                                             | 1     |    |    | 1 31                                                                                           |
| 278 | CLR rN<br>CLR DP<br>CLR X1<br>CLR X2<br>CLR USP<br>CLR SSP<br>CLR LRB<br>CLR off N <sub>8</sub><br>CLR N <sub>8</sub><br>CLR [DP]<br>CLR ±N <sub>8</sub> [USP]<br>CLR N <sub>16</sub> [X1]<br>CLR N <sub>16</sub> [X2]                                                     | rN ← 0<br>DP ← 0<br>X1 ← 0<br>X2 ← 0<br>USP ← 0<br>SSP ← 0<br>LRB ← 0<br>off N <sub>8</sub> ← 0<br>N <sub>8</sub> ← 0<br>[DP] ← 0<br>±N <sub>8</sub> [USP] ← 0<br>N <sub>16</sub> [X1] ← 0<br>N <sub>16</sub> [X2] ← 0 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8 |                         | 12<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>—<br>—<br>14<br>16<br>16  |                         |                         |                         | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4<br>4 |       |    |    | 32                                                                                             |
| 291 | CLRB A                                                                                                                                                                                                                                                                     | A <sub>8</sub> ← 0                                                                                                                                                                                                     | 2                                                             |                         |                                                                     |                         |                         |                         | 1                                                             | 1     |    |    | 0 33                                                                                           |
| 292 | CLRB rN<br>CLRB PSWH<br>CLRB PSWL<br>CLRB off N <sub>8</sub><br>CLRB N <sub>8</sub><br>CLRB [DP]<br>CLRB ±N <sub>8</sub> [USP]<br>CLRB N <sub>16</sub> [X1]<br>CLRB N <sub>16</sub> [X2]                                                                                   | rN ← 0<br>PSWH ← 0<br>PSWL ← 0<br>off N <sub>8</sub> ← 0<br>N <sub>8</sub> ← 0<br>[DP] ← 0<br>±N <sub>8</sub> [USP] ← 0<br>N <sub>16</sub> [X1] ← 0<br>N <sub>16</sub> [X2] ← 0                                        | 4<br>4<br>4<br>6<br>6<br>6<br>7<br>7<br>8                     |                         | 8<br>—<br>—<br>11<br>—<br>10<br>11<br>12<br>12                      |                         |                         |                         | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4                     |       |    |    | 34                                                                                             |
| 301 | SWAP<br>SWAPB                                                                                                                                                                                                                                                              | A <sub>15:8</sub> ← A <sub>7:0</sub><br>A <sub>7:4</sub> ← A <sub>3:0</sub>                                                                                                                                            | 2<br>2                                                        |                         |                                                                     |                         |                         |                         | 1                                                             | 1     |    |    | 165<br>166                                                                                     |
| 303 | XCHG A, rN<br>XCHG A, DP<br>XCHG A, X1<br>XCHG A, X2<br>XCHG A, USP<br>XCHG A, SSP<br>XCHG A, LRB<br>XCHG A, off N <sub>8</sub><br>XCHG A, N <sub>8</sub><br>XCHG A, [DP]<br>XCHG A, ±N <sub>8</sub> [USP]<br>XCHG A, N <sub>16</sub> [X1]<br>XCHG A, N <sub>16</sub> [X2] | A ← rN<br>A ← DP<br>A ← X1<br>A ← X2<br>A ← USP<br>A ← SSP<br>A ← LRB<br>A ← off N <sub>8</sub><br>A ← N <sub>8</sub><br>A ← [DP]<br>A ← ±N <sub>8</sub> [USP]<br>A ← N <sub>16</sub> [X1]<br>A ← N <sub>16</sub> [X2] | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>7<br>7<br>7<br>8<br>9<br>9 |                         | 13<br>—<br>—<br>—<br>—<br>—<br>—<br>18<br>—<br>15<br>16<br>17<br>17 |                         |                         |                         | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 |       |    |    | 169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169<br>169 |
| 316 | XCHGB A, rN<br>XCHGB A, PSWH<br>XCHGB A, PSWL<br>XCHGB A, off N <sub>8</sub><br>XCHGB A, N <sub>8</sub><br>XCHGB A, [DP]<br>XCHGB A, ±N <sub>8</sub> [USP]<br>XCHGB A, N <sub>16</sub> [X1]<br>XCHGB A, N <sub>16</sub> [X2]                                               | A <sub>8</sub> ← rN<br>A ← PSWH<br>A ← PSWL<br>A ← off N <sub>8</sub><br>A ← N <sub>8</sub><br>A ← [DP]<br>A ← ±N <sub>8</sub> [USP]<br>A ← N <sub>16</sub> [X1]<br>A ← N <sub>16</sub> [X2]                           | 5<br>5<br>5<br>7<br>7<br>7<br>8<br>9<br>9                     |                         | 9<br>—<br>—<br>12<br>—<br>11<br>12<br>13<br>13                      |                         |                         |                         | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4                     |       |    |    | 170<br>170<br>170<br>170<br>170<br>170<br>170<br>170<br>170                                    |
| 325 | XNBL A, off N <sub>8</sub>                                                                                                                                                                                                                                                 | A <sub>3:0</sub> ← off N <sub>8</sub> 3:0                                                                                                                                                                              | 5                                                             |                         | 10                                                                  |                         |                         |                         | 2                                                             |       |    |    | 200                                                                                            |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-7. Stack Operation Instructions**

\*1 - the first operand

\*2 - the second operand

| No. | Mnemonics            | Operation                                   | Int <sup>*1</sup> | Int <sup>*1</sup> | Ext <sup>*1</sup> | Ext <sup>*1</sup> | Byte no. | Flags |    |    |    | Page |
|-----|----------------------|---------------------------------------------|-------------------|-------------------|-------------------|-------------------|----------|-------|----|----|----|------|
|     |                      |                                             | Int <sup>*2</sup> | Ext <sup>*2</sup> | Int <sup>*2</sup> | Ext <sup>*2</sup> |          | ZF    | CF | HC | DD |      |
| 326 | PUSHS A<br>PUSHS LRB | (SSP) ← obj (word)<br>SSP ← LSP - 2         | 3<br>3            |                   | 7<br>7            |                   | 1        |       |    |    |    | 114  |
| 328 | POPS A               | SSP ← SSP + 2<br>A ← (SSP) (word)<br>DD ← 1 | 4                 | 8                 |                   |                   | 1        |       |    |    | 1  | 112  |
| 329 | POPS LRB             | SSP ← SSP + 2<br>LRB ← (SSP)                | 4                 | 8                 |                   |                   | 1        |       |    |    |    | 113  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-8. Rotate Instructions**

\*1 - the first operand  
 \*2 - the second operand

| No. | Mnemonics                  | Operation | Int <sup>*1</sup> | Int <sup>*1</sup> | Ext <sup>*1</sup> | Ext <sup>*1</sup> | Byte no. | Flags |    |    |    | Page |
|-----|----------------------------|-----------|-------------------|-------------------|-------------------|-------------------|----------|-------|----|----|----|------|
|     |                            |           | Int <sup>*2</sup> | Ext <sup>*2</sup> | Int <sup>*2</sup> | Ext <sup>*2</sup> |          | ZF    | CF | HQ | DD |      |
| 330 | ROL A                      |           | 2                 |                   |                   |                   | 1        |       | *  |    |    | 118  |
| 331 | ROL rn                     |           | 5                 |                   | 13                |                   | 2        |       | *  |    |    | 119  |
|     | ROL DP                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL X1                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL X2                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL USP                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL SSP                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL LRB                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 119  |
|     | ROL off N <sub>8</sub>     |           | 7                 |                   | 16                |                   | 3        |       | *  |    |    | 119  |
|     | ROL N <sub>8</sub>         |           | 7                 |                   | —                 |                   | 3        |       | *  |    |    | 119  |
|     | ROL [DP]                   |           | 7                 |                   | 15                |                   | 2        |       | *  |    |    | 119  |
|     | ROL ±N <sub>8</sub> [USP]  |           | 8                 |                   | 16                |                   | 3        |       | *  |    |    | 119  |
|     | ROL N <sub>16</sub> [X1]   |           | 9                 |                   | 17                |                   | 4        |       | *  |    |    | 119  |
|     | ROL N <sub>16</sub> [X2]   |           | 9                 |                   | 17                |                   | 4        |       | *  |    |    | 119  |
| 344 | ROLB A                     |           | 2                 |                   |                   |                   | 1        |       | *  |    |    | 120  |
| 345 | ROLB rn                    |           | 5                 |                   | 9                 |                   | 2        |       | *  |    |    | 121  |
|     | ROLB PSWH                  |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 121  |
|     | ROLB PSM                   |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 121  |
|     | ROLB off N <sub>8</sub>    |           | 7                 |                   | 12                |                   | 3        |       | *  |    |    | 121  |
|     | ROLB N <sub>8</sub>        |           | 7                 |                   | —                 |                   | 3        |       | *  |    |    | 121  |
|     | ROLB [DP]                  |           | 7                 |                   | 11                |                   | 2        |       | *  |    |    | 121  |
|     | ROLB ±N <sub>8</sub> [USP] |           | 8                 |                   | 12                |                   | 3        |       | *  |    |    | 121  |
|     | ROLB N <sub>16</sub> [X1]  |           | 9                 |                   | 13                |                   | 4        |       | *  |    |    | 121  |
|     | ROLB N <sub>16</sub> [X2]  |           | 9                 |                   | 13                |                   | 4        |       | *  |    |    | 121  |
| 354 | ROR A                      |           | 2                 |                   |                   |                   | 1        |       | *  |    |    | 122  |
| 368 | ROR rn                     |           | 5                 |                   | 13                |                   | 2        |       | *  |    |    | 123  |
|     | ROR DP                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR X1                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR X2                     |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR USP                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR SSP                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR LRB                    |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 123  |
|     | ROR off N <sub>8</sub>     |           | 7                 |                   | 16                |                   | 3        |       | *  |    |    | 123  |
|     | ROR N <sub>8</sub>         |           | 7                 |                   | —                 |                   | 3        |       | *  |    |    | 123  |
|     | ROR [DP]                   |           | 7                 |                   | 15                |                   | 2        |       | *  |    |    | 123  |
| 369 | ROR ±N <sub>8</sub> [USP]  |           | 8                 |                   | 16                |                   | 3        |       | *  |    |    | 123  |
|     | ROR N <sub>16</sub> [X1]   |           | 9                 |                   | 17                |                   | 4        |       | *  |    |    | 123  |
|     | ROR N <sub>16</sub> [X2]   |           | 9                 |                   | 17                |                   | 4        |       | *  |    |    | 123  |
| 368 | RORB A                     |           | 2                 |                   |                   |                   | 1        |       | *  |    |    | 124  |
| 369 | RORB rn                    |           | 5                 |                   | 9                 |                   | 2        |       | *  |    |    | 125  |
|     | RORB PSWH                  |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 125  |
|     | RORB PSWL                  |           | 5                 |                   | —                 |                   | 2        |       | *  |    |    | 125  |
|     | RORB off N <sub>8</sub>    |           | 7                 |                   | 12                |                   | 3        |       | *  |    |    | 125  |
|     | RORB N <sub>8</sub>        |           | 7                 |                   | —                 |                   | 3        |       | *  |    |    | 125  |
|     | RORB [DP]                  |           | 7                 |                   | 11                |                   | 2        |       | *  |    |    | 125  |
|     | RORB ±N <sub>8</sub> [USP] |           | 8                 |                   | 12                |                   | 3        |       | *  |    |    | 125  |
|     | RORB N <sub>16</sub> [X1]  |           | 9                 |                   | 13                |                   | 4        |       | *  |    |    | 125  |
|     | RORB N <sub>16</sub> [X2]  |           | 9                 |                   | 13                |                   | 4        |       | *  |    |    | 125  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-9. Shift Instructions (1)**

\*1 - the first operand

\*2 - the second operand

| No. | Mnemonics                                                                                                                                                | Operation                                                                                                                                                                                                         | Int *1     | Int *1     | Ext *1     | Ext *1     | Byte no. | Flags |    |   | Page |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|------------|------------|----------|-------|----|---|------|
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | Int *2 Cyc | Ext *2 Cyc | Int *2 Cyc | Ext *2 Cyc |          | ZF    | CF | H |      |
| 378 | SLL A                                                                                                                                                    | <br>$C \leftarrow A_{15}$<br>$A_n \leftarrow A_{n-1}$<br>$(n = 15-1)$<br>$A_0 \leftarrow 0$                                      | 2          |            |            |            | 1        | *     |    |   | 143  |
| 379 | SLL arN<br>SLL DP<br>SLL X1<br>SLL X2<br>SLL USP<br>SLL SSP<br>SLL LRB<br>SLL off N8<br>SLL N8<br>SLL [DP]<br>SLL zN8[USP]<br>SLL N16[X1]<br>SLL N16[X2] | <br>$C \leftarrow obj_{15}$<br>$obj_n \leftarrow obj_{n-1}$<br>$(n = 15-1)$<br>$obj_0 \leftarrow 0$                              | 5          |            | 13         |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 16         |            | 3        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | —          |            | 3        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 15         |            | 2        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 8          |            | 16         |            | 3        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 17         |            | 4        | *     |    |   | 144  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 17         |            | 4        | *     |    |   | 144  |
| 392 | SLLB A                                                                                                                                                   | <br>$C \leftarrow A_7$<br>$A_n \leftarrow A_{n-1}$<br>$(n = 7-1)$<br>$A_0 \leftarrow 0$                                          | 2          |            |            |            | 1        | *     |    |   | 145  |
| 393 | SLLB rN<br>SLLB PSWH<br>SLLB PSWL<br>SLLB off N8<br>SLLB N8<br>SLLB [DP]<br>SLLB zN8[USP]<br>SLLB N16[X1]<br>SLLB N16[X2]                                | <br>$C \leftarrow obj_7$<br>$obj_n \leftarrow obj_{n-1}$<br>$(n = 7-1)$<br>$obj_0 \leftarrow 0$                                | 5          |            | 9          |            | 2        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 12         |            | 3        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | —          |            | 3        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 11         |            | 2        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 8          |            | 12         |            | 3        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 13         |            | 4        | *     |    |   | 146  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 13         |            | 4        | *     |    |   | 146  |
| 402 | SRL A                                                                                                                                                    | <br>$0 \leftarrow A_{15}$<br>$A_0 \leftarrow C$<br>$A_n \leftarrow A_{n+1}$<br>$(n = 14-0)$<br>$A_{15} \leftarrow 0$           | 2          |            |            |            | 1        | *     |    |   | 151  |
| 403 | SRL arN<br>SRL DP<br>SRL X1<br>SRL X2<br>SRL USP<br>SRL SSP<br>SRL LRB<br>SRL off N8<br>SRL N8<br>SRL [DP]<br>SRL zN8[USP]<br>SRL N16[X1]<br>SRL N16[X2] | <br>$0 \leftarrow obj_{15}$<br>$obj_0 \leftarrow C$<br>$obj_n \leftarrow obj_{n+1}$<br>$(n = 14-0)$<br>$obj_{15} \leftarrow 0$ | 5          |            | 13         |            | 2        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 5          |            | —          |            | 2        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 16         |            | 3        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | —          |            | 3        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 7          |            | 15         |            | 2        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 8          |            | 16         |            | 3        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 17         |            | 4        | *     |    |   | 152  |
|     |                                                                                                                                                          |                                                                                                                                                                                                                   | 9          |            | 17         |            | 4        | *     |    |   | 152  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-10. Shift Instructions (2)**

\*1 - the first operand  
 \*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                               | Operation                                                                                                                                                                                                  | Int <sup>1</sup><br>Cyc              | Int <sup>1</sup><br>Cyc | Ext <sup>1</sup><br>Cyc                   | Ext <sup>1</sup><br>Cyc | Ext <sup>1</sup><br>Cyc | Ext <sup>2</sup><br>Cyc | Byte<br>no.                          | Flags |    |    |    | Page |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------|-------------------------------------------|-------------------------|-------------------------|-------------------------|--------------------------------------|-------|----|----|----|------|
|     |                                                                                                                                                                                                                         |                                                                                                                                                                                                            |                                      |                         |                                           |                         |                         |                         |                                      | ZF    | CF | HC | OD |      |
| 416 | SRLB A                                                                                                                                                                                                                  |  C ← A <sub>0</sub><br>A <sub>n</sub> ← A <sub>n+1</sub><br>(n = 8 → 0)<br>A <sub>7</sub> ← 0                             | 2                                    |                         |                                           |                         |                         |                         | 1                                    |       | *  |    |    | 153  |
| 417 | SRLB IN<br>SRLB PSWH<br>SRLB PSWL<br>SRLB off N <sub>8</sub><br>SRLB N <sub>8</sub><br>SRLB [DP]<br>SRLB ±N <sub>8</sub> [USP]<br>SRLB N <sub>16</sub> [X1]<br>SRLB N <sub>16</sub> [X2]                                |  obj <sub>n</sub> ← obj <sub>n+1</sub><br>(n = 8 → 0)<br>obj <sub>7</sub> ← 0                                             | 5<br>5<br>7<br>7<br>7<br>8<br>9<br>9 |                         | 9<br>—<br>12<br>—<br>11<br>12<br>13<br>13 |                         |                         |                         | 2<br>2<br>2<br>3<br>3<br>3<br>4<br>4 |       | *  |    |    | 154  |
| 426 | SRA A                                                                                                                                                                                                                   |  C ← A <sub>0</sub><br>A <sub>n</sub> ← A <sub>n+1</sub><br>(n = 14 → 0)<br>A <sub>15</sub> ← A <sub>15</sub>             | 2                                    |                         |                                           |                         |                         |                         | 1                                    |       | *  |    |    | 151  |
| 427 | SRA enN<br>SRA DP<br>SRA X1<br>SRA X2<br>SRA USP<br>SRA SSP<br>SRA LRB<br>SRA off N <sub>8</sub><br>SRA N <sub>8</sub><br>SRA [DP]<br>SRA ±N <sub>8</sub> [USP]<br>SRA N <sub>16</sub> [X1]<br>SRA N <sub>16</sub> [X2] |  C ← obj <sub>0</sub><br>obj <sub>n</sub> ← obj <sub>n+1</sub><br>(n = 14 → 0)<br>obj <sub>15</sub> ← obj <sub>15</sub> | 5<br>5<br>5<br>5<br>7<br>7<br>8<br>9 |                         | 13<br>—<br>—<br>—<br>16<br>15<br>16<br>17 |                         |                         |                         | 2<br>2<br>2<br>2<br>3<br>3<br>3<br>4 |       | *  |    |    | 148  |
| 440 | SRAB A                                                                                                                                                                                                                  |  C ← A <sub>0</sub><br>A <sub>n</sub> ← A <sub>n+1</sub><br>(n = 8 → 0)<br>A <sub>7</sub> ← A <sub>7</sub>              | 2                                    |                         |                                           |                         |                         |                         | 1                                    |       | *  |    |    | 149  |
| 441 | SRAB IN<br>SRAB PSWH<br>SRAB PSWL<br>SRAB off N <sub>8</sub><br>SRAB N <sub>8</sub><br>SRAB [DP]<br>SRAB ±N <sub>8</sub> [USP]<br>SRAB N <sub>16</sub> [X1]<br>SRAB N <sub>16</sub> [X2]                                |  C ← obj <sub>0</sub><br>obj <sub>n</sub> ← obj <sub>n+1</sub><br>(n = 8 → 0)<br>obj <sub>7</sub> ← obj <sub>7</sub>    | 5<br>5<br>7<br>7<br>7<br>8<br>9<br>9 |                         | 9<br>—<br>12<br>—<br>11<br>12<br>13<br>13 |                         |                         |                         | 2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 |       | *  |    |    | 150  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-11. Increment/Decrement Instructions**

\*1 - the first operand

\*2 - the second operand

| No. | Mnemonics                       | Operation                                                  | Int '1        | Int '1        | Ext '1        | Ext '1        | Byte no. | Flags |    |    |    | Page |
|-----|---------------------------------|------------------------------------------------------------|---------------|---------------|---------------|---------------|----------|-------|----|----|----|------|
|     |                                 |                                                            | Int '2<br>Cyc | Ext '2<br>Cyc | Int '2<br>Cyc | Ext '2<br>Cyc |          | ZF    | CF | HC | OD |      |
| 460 | INC $\alpha$ N                  | $\alpha$ N $\leftarrow \alpha$ N + 1                       | 5             |               | 13            |               | 2        | .     | .  | .  | .  | 60   |
|     | INC DP                          | DP $\leftarrow$ DP + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 60   |
|     | INC X1                          | X1 $\leftarrow$ X1 + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 60   |
|     | INC X2                          | X2 $\leftarrow$ X2 + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 60   |
|     | INC USP                         | USP $\leftarrow$ USP + 1                                   | 5             |               | —             |               | 2        | .     | .  | .  | .  | 60   |
|     | INC SSP                         | SSP $\leftarrow$ SSP + 1                                   | 5             |               | —             |               | 2        | .     | .  | .  | .  | 60   |
|     | INC LRB                         | LRB $\leftarrow$ LRB + 1                                   | 3             |               | —             |               | 1        | .     | .  | .  | .  | 60   |
|     | INC off N <sub>8</sub>          | off N <sub>8</sub> $\leftarrow$ off N <sub>8</sub> + 1     | 7             |               | 16            |               | 3        | .     | .  | .  | .  | 60   |
|     | INC N <sub>8</sub>              | N <sub>8</sub> $\leftarrow$ N <sub>8</sub> + 1             | 7             |               | —             |               | 3        | .     | .  | .  | .  | 60   |
|     | INC [DP]                        | [DP] $\leftarrow$ [DP] + 1                                 | 7             |               | 16            |               | 2        | .     | .  | .  | .  | 60   |
|     | INC $\pm$ N <sub>8</sub> [USP]  | $\pm$ N <sub>8</sub> [USP] $\leftarrow$                    | 8             |               | 16            |               | 3        | .     | .  | .  | .  | 60   |
|     |                                 | $\pm$ N <sub>8</sub> [USP] + 1                             |               |               |               |               |          |       |    |    |    |      |
|     | INC N <sub>16</sub> [X1]        | N <sub>16</sub> [X1] $\leftarrow$ N <sub>16</sub> [X1] + 1 | 9             |               | 17            |               | 4        | .     | .  | .  | .  | 60   |
|     | INC N <sub>16</sub> [X2]        | N <sub>16</sub> [X2] $\leftarrow$ N <sub>16</sub> [X2] + 1 | 9             |               | 17            |               | 4        | .     | .  | .  | .  | 60   |
| 463 | INCB $\beta$ N                  | $\beta$ N $\leftarrow$ $\beta$ N + 1                       | 3             |               | 7             |               | 1        | .     | .  | .  | .  | 61   |
|     | INCB PSWH                       | PSWH $\leftarrow$ PSWH + 1                                 | 5             |               | —             |               | 2        | .     | .  | .  | .  | 61   |
|     | INCB PSWL                       | PSWL $\leftarrow$ PSWL + 1                                 | 5             |               | —             |               | 2        | .     | .  | .  | .  | 61   |
|     | INCB off N <sub>8</sub>         | off N <sub>8</sub> $\leftarrow$ off N <sub>8</sub> + 1     | 7             |               | 12            |               | 3        | .     | .  | .  | .  | 61   |
|     | INCB N <sub>8</sub>             | N <sub>8</sub> $\leftarrow$ N <sub>8</sub> + 1             | 7             |               | —             |               | 3        | .     | .  | .  | .  | 61   |
|     | INCB [DP]                       | [DP] $\leftarrow$ [DP] + 1                                 | 7             |               | 11            |               | 2        | .     | .  | .  | .  | 61   |
|     | INCB $\pm$ N <sub>8</sub> [USP] | $\pm$ N <sub>8</sub> [USP] $\leftarrow$                    | 8             |               | 12            |               | 3        | .     | .  | .  | .  | 61   |
|     |                                 | $\pm$ N <sub>8</sub> [USP] + 1                             |               |               |               |               |          |       |    |    |    |      |
|     | INCB N <sub>16</sub> [X1]       | N <sub>16</sub> [X1] $\leftarrow$ N <sub>16</sub> [X1] + 1 | 9             |               | 13            |               | 4        | .     | .  | .  | .  | 61   |
|     | INCB N <sub>16</sub> [X2]       | N <sub>16</sub> [X2] $\leftarrow$ N <sub>16</sub> [X2] + 1 | 9             |               | 13            |               | 4        | .     | .  | .  | .  | 61   |
|     |                                 |                                                            |               |               |               |               |          |       |    |    |    |      |
| 472 | DEC $\alpha$ N                  | $\alpha$ N $\leftarrow \alpha$ N + 1                       | 5             |               | 13            |               | 2        | .     | .  | .  | .  | 65   |
|     | DEC DP                          | DP $\leftarrow$ DP + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 65   |
|     | DEC X1                          | X1 $\leftarrow$ X1 + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 65   |
|     | DEC X2                          | X2 $\leftarrow$ X2 + 1                                     | 3             |               | —             |               | 1        | .     | .  | .  | .  | 65   |
|     | DEC USP                         | USP $\leftarrow$ USP + 1                                   | 5             |               | —             |               | 2        | .     | .  | .  | .  | 65   |
|     | DEC SSP                         | SSP $\leftarrow$ SSP + 1                                   | 5             |               | —             |               | 2        | .     | .  | .  | .  | 65   |
|     | DEC LRB                         | LRB $\leftarrow$ LRB + 1                                   | 3             |               | —             |               | 1        | .     | .  | .  | .  | 65   |
|     | DEC off N <sub>8</sub>          | off N <sub>8</sub> $\leftarrow$ off N <sub>8</sub> + 1     | 7             |               | 15            |               | 3        | .     | .  | .  | .  | 65   |
|     | DEC N <sub>8</sub>              | N <sub>8</sub> $\leftarrow$ N <sub>8</sub> + 1             | 7             |               | —             |               | 3        | .     | .  | .  | .  | 65   |
|     | DEC [DP]                        | [DP] $\leftarrow$ [DP] + 1                                 | 7             |               | 15            |               | 2        | .     | .  | .  | .  | 65   |
|     | DEC $\pm$ N <sub>8</sub> [USP]  | $\pm$ N <sub>8</sub> [USP] $\leftarrow$                    | 8             |               | 16            |               | 3        | .     | .  | .  | .  | 65   |
|     |                                 | $\pm$ N <sub>8</sub> [USP] + 1                             |               |               |               |               |          |       |    |    |    |      |
|     | DEC N <sub>16</sub> [X1]        | N <sub>16</sub> [X1] $\leftarrow$ N <sub>16</sub> [X1] + 1 | 9             |               | 17            |               | 4        | .     | .  | .  | .  | 65   |
|     | DEC N <sub>16</sub> [X2]        | N <sub>16</sub> [X2] $\leftarrow$ N <sub>16</sub> [X2] + 1 | 9             |               | 17            |               | 4        | .     | .  | .  | .  | 65   |
| 485 | DECB $\beta$ N                  | $\beta$ N $\leftarrow$ $\beta$ N + 1                       | 3             |               | 7             |               | 1        | .     | .  | .  | .  | 55   |
|     | DECB PSWH                       | PSWH $\leftarrow$ PSWH + 1                                 | 5             |               | —             |               | 2        | .     | .  | .  | .  | 55   |
|     | DECB PSWL                       | PSWL $\leftarrow$ PSWL + 1                                 | 5             |               | —             |               | 2        | .     | .  | .  | .  | 55   |
|     | DECB off N <sub>8</sub>         | off N <sub>8</sub> $\leftarrow$ off N <sub>8</sub> + 1     | 7             |               | 12            |               | 3        | .     | .  | .  | .  | 55   |
|     | DECB N <sub>8</sub>             | N <sub>8</sub> $\leftarrow$ N <sub>8</sub> + 1             | 7             |               | —             |               | 3        | .     | .  | .  | .  | 55   |
|     | DECB [DP]                       | [DP] $\leftarrow$ [DP] + 1                                 | 7             |               | 11            |               | 2        | .     | .  | .  | .  | 55   |
|     | DECB $\pm$ N <sub>8</sub> [USP] | $\pm$ N <sub>8</sub> [USP] $\leftarrow$                    | 8             |               | 12            |               | 3        | .     | .  | .  | .  | 55   |
|     |                                 | $\pm$ N <sub>8</sub> [USP] + 1                             |               |               |               |               |          |       |    |    |    |      |
|     | DECB N <sub>16</sub> [X1]       | N <sub>16</sub> [X1] $\leftarrow$ N <sub>16</sub> [X1] + 1 | 9             |               | 13            |               | 4        | .     | .  | .  | .  | 55   |
|     | DECB N <sub>16</sub> [X2]       | N <sub>16</sub> [X2] $\leftarrow$ N <sub>16</sub> [X2] + 1 | 9             |               | 13            |               | 4        | .     | .  | .  | .  | 55   |
|     |                                 |                                                            |               |               |               |               |          |       |    |    |    |      |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-12. ROM Table Reference Instructions (1)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                    | Operation                                              | Int *1 | Int *1 | Ext *1 | Ext *1 | Ext *1 | Ext *1 | Byte no. | Flags |    |    |  | Page |
|-----|----------------------------------------------|--------------------------------------------------------|--------|--------|--------|--------|--------|--------|----------|-------|----|----|--|------|
|     |                                              |                                                        | Int *2 | Ext *2 | Int *2 | Ext *2 | Cyc    | ZF     |          | CF    | HC | DD |  |      |
| 404 | LC A, N <sup>16</sup>                        | A ← N <sup>16</sup> (word)                             | 15     |        | 15     |        |        |        | 4        | *     |    |    |  | 72   |
| 405 | LC A, [eN]                                   | A ← [eN]                                               | 11     | 15     | 11     | 15     |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [DP]                                   | A ← [DP]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [X1]                                   | A ← [X1]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [X2]                                   | A ← [X2]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [USP]                                  | A ← [USP]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [SSP]                                  | A ← [SSP]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [LBB]                                  | A ← [LBB]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [off N <sub>d</sub> ]                  | A ← [off N <sub>d</sub> ]                              | 13     | 18     | 13     | 18     |        |        | 3        | *     |    |    |  | 73   |
|     | LC A, [N <sub>d</sub> ]                      | A ← [N <sub>d</sub> ]                                  | 13     | —      | 13     | —      |        |        | 3        | *     |    |    |  | 73   |
|     | LC A, [DP]                                   | A ← [DP]                                               | 13     | 17     | 13     | 17     |        |        | 2        | *     |    |    |  | 73   |
|     | LC A, [N <sub>d</sub> [USP]]                 | A ← [N <sub>d</sub> [USP]]                             | 14     | 18     | 14     | 18     |        |        | 3        | *     |    |    |  | 73   |
|     | LC A, [N <sub>d</sub> [X1]]                  | A ← [N <sub>d</sub> [X1]]                              | 15     | 19     | 15     | 19     |        |        | 4        | *     |    |    |  | 73   |
|     | LC A, [N <sub>d</sub> [X2]]                  | A ← [N <sub>d</sub> [X2]]                              | 15     | 19     | 15     | 19     |        |        | 4        | *     |    |    |  | 73   |
| 508 | LC A, N <sup>16</sup> [DP]                   | A ← N <sup>16</sup> [DP]                               | 15     | —      | 15     | —      |        |        | 4        | *     |    |    |  | 74   |
|     | LC A, N <sup>16</sup> [X1]                   | A ← N <sup>16</sup> [X1]                               | 15     | —      | 15     | —      |        |        | 4        | *     |    |    |  | 74   |
|     | LC A, N <sup>16</sup> [X2]                   | A ← N <sup>16</sup> [X2]                               | 15     | —      | 15     | —      |        |        | 4        | *     |    |    |  | 74   |
|     | LC A, N <sup>16</sup> [USP]                  | A ← N <sup>16</sup> [USP]                              | 15     | —      | 15     | —      |        |        | 4        | *     |    |    |  | 74   |
|     | LC A, N <sup>16</sup> [off N <sub>d</sub> ]  | A ← N <sup>16</sup> [off N <sub>d</sub> ]              | 17     | 22     | 17     | 22     |        |        | 5        | *     |    |    |  | 74   |
|     | LC A, N <sup>16</sup> [N <sub>d</sub> ]      | A ← N <sup>16</sup> [N <sub>d</sub> ]                  | 17     | —      | 17     | —      |        |        | 5        | *     |    |    |  | 74   |
| 514 | LCB A, N <sup>16</sup>                       | A <sub>L</sub> ← N <sup>16</sup> (byte)                | 13     |        | 13     |        |        |        | 4        | *     |    |    |  | 82   |
| 515 | LCB A, [eN]                                  | A <sub>L</sub> ← [eN]                                  | 9      | 11     | 9      | 11     |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [DP]                                  | A <sub>L</sub> ← [DP]                                  | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [X1]                                  | A <sub>L</sub> ← [X1]                                  | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [X2]                                  | A <sub>L</sub> ← [X2]                                  | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [USP]                                 | A <sub>L</sub> ← [USP]                                 | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [SSP]                                 | A <sub>L</sub> ← [SSP]                                 | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [LBB]                                 | A <sub>L</sub> ← [LBB]                                 | 9      | —      | 9      | —      |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [off N <sub>d</sub> ]                 | A <sub>L</sub> ← [off N <sub>d</sub> ]                 | 11     | 16     | 11     | 16     |        |        | 3        | *     |    |    |  | 75   |
|     | LCB A, [N <sub>d</sub> ]                     | A <sub>L</sub> ← [N <sub>d</sub> ]                     | 11     | —      | 11     | —      |        |        | 3        | *     |    |    |  | 75   |
|     | LCB A, [DP]                                  | A <sub>L</sub> ← [DP]                                  | 11     | 15     | 11     | 15     |        |        | 2        | *     |    |    |  | 75   |
|     | LCB A, [N <sub>d</sub> [USP]]                | A <sub>L</sub> ← [N <sub>d</sub> [USP]]                | 12     | 16     | 12     | 16     |        |        | 3        | *     |    |    |  | 75   |
|     | LCB A, [N <sub>d</sub> [X1]]                 | A <sub>L</sub> ← [N <sub>d</sub> [X1]]                 | 13     | 17     | 13     | 17     |        |        | 4        | *     |    |    |  | 75   |
|     | LCB A, [N <sub>d</sub> [X2]]                 | A <sub>L</sub> ← [N <sub>d</sub> [X2]]                 | 13     | 17     | 13     | 17     |        |        | 4        | *     |    |    |  | 75   |
| 528 | LCB A, N <sup>16</sup> [DP]                  | A <sub>L</sub> ← N <sup>16</sup> [DP]                  | 13     | —      | 13     | —      |        |        | 4        | *     |    |    |  | 77   |
|     | LCB A, N <sup>16</sup> [X1]                  | A <sub>L</sub> ← N <sup>16</sup> [X1]                  | 13     | —      | 13     | —      |        |        | 4        | *     |    |    |  | 77   |
|     | LCB A, N <sup>16</sup> [X2]                  | A <sub>L</sub> ← N <sup>16</sup> [X2]                  | 13     | —      | 13     | —      |        |        | 4        | *     |    |    |  | 77   |
|     | LCB A, N <sup>16</sup> [USP]                 | A <sub>L</sub> ← N <sup>16</sup> [USP]                 | 13     | —      | 13     | —      |        |        | 4        | *     |    |    |  | 77   |
|     | LCB A, N <sup>16</sup> [off N <sub>d</sub> ] | A <sub>L</sub> ← N <sup>16</sup> [off N <sub>d</sub> ] | 17     | 22     | 17     | 22     |        |        | 5        | *     |    |    |  | 77   |
|     | LCB A, N <sup>16</sup> [N <sub>d</sub> ]     | A <sub>L</sub> ← N <sup>16</sup> [N <sub>d</sub> ]     | 17     | —      | 17     | —      |        |        | 5        | *     |    |    |  | 77   |
| 534 | CMPC A, N <sup>16</sup>                      | A - N <sup>16</sup> (word)                             | 15     |        | 15     |        |        |        | 4        | *     |    |    |  | 50   |
| 535 | CMPC A, [eN]                                 | A - [eN]                                               | 11     | 15     | 11     | 15     |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [DP]                                 | A - [DP]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [X1]                                 | A - [X1]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [X2]                                 | A - [X2]                                               | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [USP]                                | A - [USP]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [SSP]                                | A - [SSP]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [LBB]                                | A - [LBB]                                              | 11     | —      | 11     | —      |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [off N <sub>d</sub> ]                | A - [off N <sub>d</sub> ]                              | 13     | 18     | 13     | 18     |        |        | 3        | *     |    |    |  | 44   |
|     | CMPC A, [N <sub>d</sub> ]                    | A - [N <sub>d</sub> ]                                  | 13     | —      | 13     | —      |        |        | 3        | *     |    |    |  | 44   |
|     | CMPC A, [DP]                                 | A - [DP]                                               | 13     | 17     | 13     | 17     |        |        | 2        | *     |    |    |  | 44   |
|     | CMPC A, [N <sub>d</sub> [USP]]               | A - [N <sub>d</sub> [USP]]                             | 14     | 18     | 14     | 18     |        |        | 3        | *     |    |    |  | 44   |
|     | CMPC A, [N <sub>d</sub> [X1]]                | A - [N <sub>d</sub> [X1]]                              | 15     | 19     | 15     | 19     |        |        | 4        | *     |    |    |  | 44   |
|     | CMPC A, [N <sub>d</sub> [X2]]                | A - [N <sub>d</sub> [X2]]                              | 15     | 19     | 15     | 19     |        |        | 4        | *     |    |    |  | 44   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-13. ROM Table Reference Instructions (2)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                      | Operation                                              | Int *1 | Int *1 | Ext *1 | Ext *1 | Byte no. | Flags |    |    | Page |
|-----|------------------------------------------------|--------------------------------------------------------|--------|--------|--------|--------|----------|-------|----|----|------|
|     |                                                |                                                        | Int *2 | Ext *2 | Int *2 | Ext *2 |          | ZF    | CF | HC |      |
| 546 | CMPC A, N <sup>16</sup> [DP]                   | A - N <sup>16</sup> [DP]                               | 15     | —      | 15     | —      | 4        | •     | •  | •  | 6    |
|     | CMPC A, N <sup>16</sup> [X1]                   | A - N <sup>16</sup> [X1]                               | 15     | —      | 15     | —      | 4        | •     | •  | •  | 6    |
|     | CMPC A, N <sup>16</sup> [X2]                   | A - N <sup>16</sup> [X2]                               | 15     | —      | 15     | —      | 4        | •     | •  | •  | 6    |
|     | CMPC A, N <sup>16</sup> [USP]                  | A - N <sup>16</sup> [USP]                              | 15     | —      | 15     | —      | 4        | •     | •  | •  | 6    |
|     | CMPC A, N <sup>16</sup> [off N <sub>d</sub> ]  | A - N <sup>16</sup> [off N <sub>d</sub> ]              | 17     | 22     | 17     | 22     | 5        | •     | •  | •  | 6    |
|     | CMPC A, N <sup>16</sup> [N <sub>d</sub> ]      | A - N <sup>16</sup> [N <sub>d</sub> ]                  | 17     | —      | 17     | —      | 5        | •     | •  | •  | 6    |
| 554 | CMPCB A, N <sup>16</sup>                       | A <sub>L</sub> - N <sup>16</sup> (byte)                | 13     | —      | 13     | —      | 4        | •     | •  | •  | 6    |
| 555 | CMPCB A, [eN]                                  | A <sub>L</sub> - [eN]                                  | 9      | 11     | 9      | 11     | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [DP]                                  | A <sub>L</sub> - [DP]                                  | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [X1]                                  | A <sub>L</sub> - [X1]                                  | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [X2]                                  | A <sub>L</sub> - [X2]                                  | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [USP]                                 | A <sub>L</sub> - [USP]                                 | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [SSP]                                 | A <sub>L</sub> - [SSP]                                 | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [LRB]                                 | A <sub>L</sub> - [LRB]                                 | 9      | —      | 9      | —      | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [off N <sub>d</sub> ]                 | A <sub>L</sub> - [off N <sub>d</sub> ]                 | 11     | 15     | 11     | 15     | 3        | •     | •  | •  | 6    |
|     | CMPCB A, [N <sub>d</sub> ]                     | A <sub>L</sub> - [N <sub>d</sub> ]                     | 11     | —      | 11     | —      | 3        | •     | •  | •  | 6    |
|     | CMPCB A, [[DP]]                                | A <sub>L</sub> - [[DP]]                                | 11     | 15     | 11     | 15     | 2        | •     | •  | •  | 6    |
|     | CMPCB A, [±N <sub>d</sub> [USP]]               | A <sub>L</sub> - [±N <sub>d</sub> [USP]]               | 12     | 16     | 12     | 16     | 3        | •     | •  | •  | 6    |
|     | CMPCB A, [N <sup>16</sup> [X1]]                | A <sub>L</sub> - [N <sup>16</sup> [X1]]                | 13     | 17     | 13     | 17     | 4        | •     | •  | •  | 6    |
|     | CMPCB A, [N <sup>16</sup> [X2]]                | A <sub>L</sub> - [N <sup>16</sup> [X2]]                | 13     | 17     | 13     | 17     | 4        | •     | •  | •  | 6    |
| 568 | CMPCB A, N <sup>16</sup> [DP]                  | A <sub>L</sub> - N <sup>16</sup> [DP]                  | 13     | —      | 13     | —      | 4        | •     | •  | •  | 6    |
|     | CMPCB A, N <sup>16</sup> [X1]                  | A <sub>L</sub> - N <sup>16</sup> [X1]                  | 13     | —      | 13     | —      | 4        | •     | •  | •  | 6    |
|     | CMPCB A, N <sup>16</sup> [X2]                  | A <sub>L</sub> - N <sup>16</sup> [X2]                  | 13     | —      | 13     | —      | 4        | •     | •  | •  | 6    |
|     | CMPCB A, N <sup>16</sup> [USP]                 | A <sub>L</sub> - N <sup>16</sup> [USP]                 | 13     | —      | 13     | —      | 4        | •     | •  | •  | 6    |
|     | CMPCB A, N <sup>16</sup> [off N <sub>d</sub> ] | A <sub>L</sub> - N <sup>16</sup> [off N <sub>d</sub> ] | 17     | 22     | 17     | 22     | 5        | •     | •  | •  | 6    |
|     | CMPCB A, N <sup>16</sup> [N <sub>d</sub> ]     | A <sub>L</sub> - N <sup>16</sup> [N <sub>d</sub> ]     | 17     | —      | 17     | —      | 5        | •     | •  | •  | 6    |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-14. Arithmetic Calculation Instructions (1)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                     | Operation                                                          | Int *1<br>Int *2<br>Cyc | Ext *1<br>Ext *2<br>Cyc | Ext *1<br>Ext *2<br>Cyc | Ext *1<br>Ext *2<br>Cyc | Byte no. | Flags |    |    |    | Page |
|-----|-----------------------------------------------|--------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|-------------------------|----------|-------|----|----|----|------|
|     |                                               |                                                                    |                         |                         |                         |                         |          | ZF    | CF | HC | DD |      |
| 574 | MUL                                           | (er1,A) ← A × er0                                                  | 27                      |                         | 36                      |                         | 2        | *     |    |    |    | 101  |
| 575 | MULB                                          | A ← A <sub>b</sub> × r0                                            | 19                      |                         | 21                      |                         | 2        | *     |    |    |    | 102  |
| 576 | DIV                                           | (er0,A) ← (er0,A) ÷ er2<br>er1 ← (er0,A) MOD er2                   | 40                      |                         | 63                      |                         | 2        | *     | *  |    |    | 57   |
| 577 | DIVB                                          | A ← A ÷ r0<br>r1 ← A MOD r0                                        | 29                      |                         | 33                      |                         | 2        | *     | *  |    |    | 59   |
| 578 | ADD A, #N <sub>16</sub>                       | A ← A + #N <sub>16</sub>                                           | 6                       | —                       |                         |                         | 3        | *     | *  | *  | *  | 13   |
|     | ADD A, erN                                    | A ← A + erN                                                        | 3                       | 7                       |                         |                         | 1        | *     | *  | *  | *  | 13   |
|     | ADD A, DP                                     | A ← A + DP                                                         | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, X1                                     | A ← A + X1                                                         | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, X2                                     | A ← A + X2                                                         | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, USP                                    | A ← A + USP                                                        | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, SSP                                    | A ← A + SSP                                                        | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, LRB                                    | A ← A + LRB                                                        | 4                       | —                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, off N <sub>8</sub>                     | A ← A + off N <sub>8</sub>                                         | 4                       | 9                       |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, N <sub>8</sub>                         | A ← A + N <sub>8</sub>                                             | 6                       | —                       |                         |                         | 3        | *     | *  | *  | *  | 13   |
|     | ADD A, [DP]                                   | A ← A + [DP]                                                       | 6                       | 10                      |                         |                         | 2        | *     | *  | *  | *  | 13   |
|     | ADD A, ±N <sub>8</sub> [USP]                  | A ← A + ±N <sub>8</sub> [USP]                                      | 7                       | 11                      |                         |                         | 3        | *     | *  | *  | *  | 13   |
|     | ADD A, N <sub>16</sub> [X1]                   | A ← A + N <sub>16</sub> [X1]                                       | 8                       | 12                      |                         |                         | 4        | *     | *  | *  | *  | 13   |
|     | ADD A, N <sub>16</sub> [X2]                   | A ← A + N <sub>16</sub> [X2]                                       | 8                       | 12                      |                         |                         | 4        | *     | *  | *  | *  | 13   |
| 605 | ADD erN, off N <sub>8</sub>                   | erN ← erN + off N <sub>8</sub>                                     | 7                       | —                       | —                       | 20                      | 3        | *     | *  | *  |    | 14   |
|     | ADD DP, off N <sub>8</sub>                    | DP ← DP + off N <sub>8</sub>                                       | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD X1, off N <sub>8</sub>                    | X1 ← X1 + off N <sub>8</sub>                                       | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD X2, off N <sub>8</sub>                    | X2 ← X2 + off N <sub>8</sub>                                       | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD USP, off N <sub>8</sub>                   | USP ← USP + off N <sub>8</sub>                                     | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD SSP, off N <sub>8</sub>                   | SSP ← SSP + off N <sub>8</sub>                                     | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD LRB, off N <sub>8</sub>                   | LRB ← LRB + off N <sub>8</sub>                                     | 7                       | 13                      | —                       | —                       | 3        | *     | *  | *  |    | 14   |
|     | ADD off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> + off N <sub>8</sub>       | 9                       | —                       | —                       | 23                      | 4        | *     | *  | *  |    | 14   |
|     | ADD N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> + off N <sub>8</sub>               | 9                       | 16                      | —                       | —                       | 4        | *     | *  | *  |    | 14   |
|     | ADD [DP], off N <sub>8</sub>                  | [DP] ← [DP] + off N <sub>8</sub>                                   | 9                       | 16                      | 13                      | 22                      | 3        | *     | *  | *  |    | 14   |
|     | ADD ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + off N <sub>8</sub> | 10                      | 19                      | 14                      | 23                      | 4        | *     | *  | *  |    | 14   |
|     | ADD N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] + off N <sub>8</sub>   | 11                      | 20                      | 15                      | 24                      | 5        | *     | *  | *  |    | 14   |
|     | ADD N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] + off N <sub>8</sub>   | 11                      | 20                      | 15                      | 24                      | 5        | *     | *  | *  |    | 14   |
| 618 | ADD erN, #N <sub>16</sub>                     | erN ← erN + #N <sub>16</sub>                                       | 8                       |                         | 17                      |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD DP, #N <sub>16</sub>                      | DP ← DP + #N <sub>16</sub>                                         | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD X1, #N <sub>16</sub>                      | X1 ← X1 + #N <sub>16</sub>                                         | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD X2, #N <sub>16</sub>                      | X2 ← X2 + #N <sub>16</sub>                                         | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD USP, #N <sub>16</sub>                     | USP ← USP + #N <sub>16</sub>                                       | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD SSP, #N <sub>16</sub>                     | SSP ← SSP + #N <sub>16</sub>                                       | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |
|     | ADD LRB, #N <sub>16</sub>                     | LRB ← LRB + #N <sub>16</sub>                                       | 8                       | —                       |                         |                         | 4        | *     | *  | *  |    | 15   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-15. Arithmetic Calculation Instructions (2)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                      | Operation                                                          | Int <sup>*1</sup>        | Int <sup>*1</sup>        | Ext <sup>*1</sup>        | Ext <sup>*1</sup>        | Byte no. | Flags |    |    |    | Page |
|-----|------------------------------------------------|--------------------------------------------------------------------|--------------------------|--------------------------|--------------------------|--------------------------|----------|-------|----|----|----|------|
|     |                                                |                                                                    | Int <sup>*2</sup><br>Cyc | Ext <sup>*2</sup><br>Cyc | Int <sup>*2</sup><br>Cyc | Ext <sup>*2</sup><br>Cyc |          | ZF    | CF | HC | DD |      |
| 625 | ADD off N <sub>8</sub> , #N <sub>16</sub>      | off N <sub>8</sub> ← off N <sub>8</sub> + #N <sub>16</sub>         | 10                       | —                        | 20                       | —                        | 5        | *     | *  | *  | *  | 15   |
|     | ADD N <sub>8</sub> , #N <sub>16</sub>          | N <sub>8</sub> ← N <sub>8</sub> + #N <sub>16</sub>                 | 10                       | —                        | —                        | —                        | 5        | *     | *  | *  | *  | 15   |
|     | ADD [DP], #N <sub>16</sub>                     | [DP] ← [DP] + #N <sub>16</sub>                                     | 10                       | —                        | 19                       | —                        | 4        | *     | *  | *  | *  | 15   |
|     | ADD ±N <sub>8</sub> [USP], #N <sub>16</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + #N <sub>16</sub>   | 11                       | —                        | 20                       | —                        | 5        | *     | *  | *  | *  | 15   |
|     | ADD N <sub>16</sub> [X1], #N <sub>16</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] + #N <sub>16</sub>     | 12                       | —                        | 21                       | —                        | 6        | *     | *  | *  | *  | 15   |
|     | ADD N <sub>16</sub> [X2], #N <sub>16</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] + #N <sub>16</sub>     | 12                       | —                        | 21                       | —                        | 6        | *     | *  | *  | *  | 15   |
| 631 | ADDB A, #N <sub>8</sub>                        | A <sub>L</sub> ← A <sub>L</sub> + #N <sub>8</sub>                  | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 16   |
|     | ADDB A, rN                                     | A <sub>L</sub> ← A <sub>L</sub> + rN                               | 3                        | 5                        | —                        | —                        | 1        | *     | *  | *  | *  | 16   |
|     | ADDB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> + PSWH                             | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 16   |
|     | ADDB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> + PSWL                             | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 16   |
|     | ADDB A, off N <sub>8</sub>                     | A <sub>L</sub> ← A <sub>L</sub> + off N <sub>8</sub>               | 4                        | 7                        | —                        | —                        | 2        | *     | *  | *  | *  | 16   |
|     | ADDB A, N <sub>8</sub>                         | A <sub>L</sub> ← A <sub>L</sub> + N <sub>8</sub>                   | 6                        | —                        | —                        | —                        | 3        | *     | *  | *  | *  | 16   |
|     | ADDB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> + [DP]                             | 6                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 16   |
|     | ADDB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> + ±N <sub>8</sub> [USP]            | 7                        | 8                        | —                        | —                        | 3        | *     | *  | *  | *  | 16   |
|     | ADDB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> + N <sub>16</sub> [X1]             | 8                        | 10                       | —                        | —                        | 4        | *     | *  | *  | *  | 16   |
|     | ADDB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> + N <sub>16</sub> [X2]             | 8                        | 10                       | —                        | —                        | 4        | *     | *  | *  | *  | 16   |
| 641 | ADDB rN, A                                     | rN ← rN + A <sub>L</sub>                                           | 5                        | —                        | 9                        | —                        | 2        | *     | *  | *  | *  | 17   |
|     | ADDB PSWH, A                                   | PSWH ← PSWH + A <sub>L</sub>                                       | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 17   |
|     | ADDB PSWL, A                                   | PSWL ← PSWL + A <sub>L</sub>                                       | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | *  | 17   |
|     | ADDB off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> + A <sub>L</sub>           | 7                        | —                        | 12                       | —                        | 3        | *     | *  | *  | *  | 17   |
|     | ADDB N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> + A <sub>L</sub>                   | 7                        | —                        | —                        | —                        | 3        | *     | *  | *  | *  | 17   |
|     | ADDB [DP], A                                   | [DP] ← [DP] + A <sub>L</sub>                                       | 7                        | —                        | 11                       | —                        | 2        | *     | *  | *  | *  | 17   |
|     | ADDB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + A <sub>L</sub>     | 8                        | —                        | 12                       | —                        | 3        | *     | *  | *  | *  | 17   |
|     | ADDB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] + A <sub>L</sub>       | 9                        | —                        | 13                       | —                        | 4        | *     | *  | *  | *  | 17   |
|     | ADDB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] + A <sub>L</sub>       | 9                        | —                        | 13                       | —                        | 4        | *     | *  | *  | *  | 17   |
|     | ADDB rN, off N <sub>8</sub>                    | rN ← rN + off N <sub>8</sub>                                       | 7                        | —                        | —                        | 14                       | 3        | *     | *  | *  | *  | 18   |
| 650 | ADDB PSWH, off N <sub>8</sub>                  | PSWH ← PSWH + off N <sub>8</sub>                                   | 7                        | 12                       | —                        | —                        | 3        | *     | *  | *  | *  | 18   |
|     | ADDB PSWL, off N <sub>8</sub>                  | PSWL ← PSWL + off N <sub>8</sub>                                   | 7                        | 12                       | —                        | —                        | 3        | *     | *  | *  | *  | 18   |
|     | ADDB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> + off N <sub>8</sub>       | 9                        | —                        | —                        | 17                       | 4        | *     | *  | *  | *  | 18   |
|     | ADDB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> + off N <sub>8</sub>               | 9                        | 14                       | —                        | —                        | 4        | *     | *  | *  | *  | 18   |
|     | ADDB [DP], off N <sub>8</sub>                  | [DP] ← [DP] + off N <sub>8</sub>                                   | 9                        | 14                       | 11                       | 13                       | 3        | *     | *  | *  | *  | 18   |
|     | ADDB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + off N <sub>8</sub> | 10                       | 15                       | 12                       | 17                       | 4        | *     | *  | *  | *  | 18   |
|     | ADDB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] + off N <sub>8</sub>   | 11                       | 13                       | 13                       | 18                       | 5        | *     | *  | *  | *  | 18   |
|     | ADDB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] + off N <sub>8</sub>   | 11                       | 13                       | 13                       | 18                       | 5        | *     | *  | *  | *  | 18   |
|     | ADDB rN, #N <sub>8</sub>                       | rN ← rN + #N <sub>8</sub>                                          | 6                        | —                        | 11                       | —                        | 3        | *     | *  | *  | *  | 19   |
|     | ADDB PSWH, #N <sub>8</sub>                     | PSWH ← PSWH + #N <sub>8</sub>                                      | 6                        | —                        | —                        | —                        | 3        | *     | *  | *  | *  | 19   |
| 659 | ADDB PSWL, #N <sub>8</sub>                     | PSWL ← PSWL + #N <sub>8</sub>                                      | 6                        | —                        | —                        | —                        | 3        | *     | *  | *  | *  | 19   |
|     | ADDB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> ← off N <sub>8</sub> + #N <sub>8</sub>          | 8                        | —                        | 14                       | —                        | 4        | *     | *  | *  | *  | 19   |
|     | ADDB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> ← N <sub>8</sub> + #N <sub>8</sub>                  | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | *  | 19   |
|     | ADDB [DP], #N <sub>8</sub>                     | [DP] ← [DP] + #N <sub>8</sub>                                      | 8                        | —                        | 13                       | —                        | 3        | *     | *  | *  | *  | 19   |
|     | ADDB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + #N <sub>8</sub>    | 9                        | —                        | 14                       | —                        | 4        | *     | *  | *  | *  | 19   |
|     | ADDB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] + #N <sub>8</sub>      | 10                       | —                        | 15                       | —                        | 5        | *     | *  | *  | *  | 19   |
|     | ADDB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] + #N <sub>8</sub>      | 10                       | —                        | 15                       | —                        | 5        | *     | *  | *  | *  | 19   |

## **Chapter 3 Details of Instructions**

### **Instruction List**

**TABLE 3-16. Arithmetic Calculation Instructions (3)**

| No. | Mnemonics                                     | Operation                                                              | Int <sup>-1</sup> | Int <sup>-1</sup> | Ext <sup>-1</sup> | Ext <sup>-1</sup> | Byte no. | Flags |    |    | Page |
|-----|-----------------------------------------------|------------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|----------|-------|----|----|------|
|     |                                               |                                                                        | Int <sup>-2</sup> | Ext <sup>-2</sup> | Int <sup>-2</sup> | Ext <sup>-2</sup> |          | ZF    | CF | HC |      |
| 688 | ADC A, #N <sub>16</sub>                       | A ← A + #N <sub>16</sub> + C                                           | 6                 | —                 |                   |                   | 3        | •     | •  | •  | 5    |
|     | ADC A, #N                                     | A ← A + #N + C                                                         | 3                 | 7                 |                   |                   | 1        | •     | •  | •  | 5    |
|     | ADC A, DP                                     | A ← A + DP + C                                                         | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, X1                                     | A ← A + X1 + C                                                         | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, X2                                     | A ← A + X2 + C                                                         | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, USP                                    | A ← A + USP + C                                                        | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, SSP                                    | A ← A + SSP + C                                                        | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, LRB                                    | A ← A + LRB + C                                                        | 4                 | —                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, off N <sub>8</sub>                     | A ← A + off N <sub>8</sub> + C                                         | 4                 | 9                 |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, N <sub>8</sub>                         | A ← A + N <sub>8</sub> + C                                             | 6                 | —                 |                   |                   | 3        | •     | •  | •  | 5    |
|     | ADC A, [DP]                                   | A ← A + [DP] + C                                                       | 6                 | 10                |                   |                   | 2        | •     | •  | •  | 5    |
|     | ADC A, ±N <sub>8</sub> [USP]                  | A ← A + ±N <sub>8</sub> [USP] + C                                      | 7                 | 11                |                   |                   | 3        | •     | •  | •  | 5    |
| 682 | ADC #N, A                                     | #N ← #N + A + C                                                        | 5                 | —                 | 13                |                   | 2        | •     | •  | •  | 6    |
|     | ADC DP, A                                     | DP ← DP + A + C                                                        | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC X1, A                                     | X1 ← X1 + A + C                                                        | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC X2, A                                     | X2 ← X2 + A + C                                                        | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC USP, A                                    | USP ← USP + A + C                                                      | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC SSP, A                                    | SSP ← SSP + A + C                                                      | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC LRB, A                                    | LRB ← LRB + A + C                                                      | 5                 | —                 | —                 |                   | 2        | •     | •  | •  | 6    |
|     | ADC off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> + A + C                        | 7                 | —                 | 13                |                   | 3        | •     | •  | •  | 6    |
|     | ADC N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> + A + C                                | 7                 | —                 | —                 |                   | 3        | •     | •  | •  | 6    |
|     | ADC [DP], A                                   | [DP] ← [DP] + A + C                                                    | 7                 | 15                |                   |                   | 2        | •     | •  | •  | 6    |
|     | ADC ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + A + C                  | 8                 | 13                |                   |                   | 3        | •     | •  | •  | 6    |
| 695 | ADC #N, off N <sub>8</sub>                    | #N ← #N + off N <sub>8</sub> + C                                       | 7                 | —                 | —                 | 20                | 3        | •     | •  | •  | 7    |
|     | ADC DP, off N <sub>8</sub>                    | DP ← DP + off N <sub>8</sub> + C                                       | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC X1, off N <sub>8</sub>                    | X1 ← X1 + off N <sub>8</sub> + C                                       | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC X2, off N <sub>8</sub>                    | X2 ← X2 + off N <sub>8</sub> + C                                       | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC USP, off N <sub>8</sub>                   | USP ← USP + off N <sub>8</sub> + C                                     | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC SSP, off N <sub>8</sub>                   | SSP ← SSP + off N <sub>8</sub> + C                                     | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC LRB, off N <sub>8</sub>                   | LRB ← LRB + off N <sub>8</sub> + C                                     | 7                 | 13                | —                 | —                 | 3        | •     | •  | •  | 7    |
|     | ADC off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> + off N <sub>8</sub> + C       | 9                 | —                 | —                 | 23                | 4        | •     | •  | •  | 7    |
|     | ADC N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> + off N <sub>8</sub> + C               | 9                 | 18                | —                 | —                 | 4        | •     | •  | •  | 7    |
|     | ADC [DP], off N <sub>8</sub>                  | [DP] ← [DP] + off N <sub>8</sub> + C                                   | 9                 | 18                | 13                | 22                | 3        | •     | •  | •  | 7    |
|     | ADC ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + off N <sub>8</sub> + C | 10                | 19                | 14                | 23                | 4        | •     | •  | •  | 7    |
| 708 | ADC #N, #N <sub>16</sub>                      | #N ← #N + #N <sub>16</sub> + C                                         | 8                 | —                 | 17                |                   | 4        | •     | •  | •  | 8    |
|     | ADC DP, #N <sub>16</sub>                      | DP ← DP + #N <sub>16</sub> + C                                         | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC X1, #N <sub>16</sub>                      | X1 ← X1 + #N <sub>16</sub> + C                                         | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC X2, #N <sub>16</sub>                      | X2 ← X2 + #N <sub>16</sub> + C                                         | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC USP, #N <sub>16</sub>                     | USP ← USP + #N <sub>16</sub> + C                                       | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC SSP, #N <sub>16</sub>                     | SSP ← SSP + #N <sub>16</sub> + C                                       | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC LRB, #N <sub>16</sub>                     | LRB ← LRB + #N <sub>16</sub> + C                                       | 8                 | —                 | —                 |                   | 4        | •     | •  | •  | 8    |
|     | ADC off N <sub>8</sub> , #N <sub>16</sub>     | off N <sub>8</sub> ← off N <sub>8</sub> + #N <sub>16</sub> + C         | 10                | —                 | 20                |                   | 5        | •     | •  | •  | 8    |
|     | ADC N <sub>8</sub> , #N <sub>16</sub>         | N <sub>8</sub> ← N <sub>8</sub> + #N <sub>16</sub> + C                 | 10                | —                 | —                 |                   | 5        | •     | •  | •  | 8    |
|     | ADC [DP], #N <sub>16</sub>                    | [DP] ← [DP] + #N <sub>16</sub> + C                                     | 10                | 19                |                   |                   | 4        | •     | •  | •  | 8    |
|     | ADC ±N <sub>8</sub> [USP], #N <sub>16</sub>   | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] + #N <sub>16</sub> + C   | 11                | 20                |                   |                   | 5        | •     | •  | •  | 8    |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-17. Arithmetic Calculation Instructions (4)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                                                                                                                                                                                      | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Int *1                                         | Int *1                                           | Ext *1                                         | Ext *1                                         | Byte no. | Flags |    |    |                                              | Page |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------|------------------------------------------------|------------------------------------------------|----------|-------|----|----|----------------------------------------------|------|
|     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Int *2                                         | Ext *2                                           | Int *2                                         | Ext *2                                         |          | ZF    | CF | HC | DD                                           |      |
| 719 | ADC N'16[X1], #N <sub>16</sub>                                                                                                                                                                                                                                                                                                                                                 | N'16[X1] ← N'16[X1]<br>+ #N <sub>16</sub> + C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 12                                             | —                                                | 21                                             | —                                              | 6        | *     | *  | *  | *                                            | 8    |
|     | ADC N'16[X2], #N <sub>16</sub>                                                                                                                                                                                                                                                                                                                                                 | N'16[X2] ← N'16[X2]<br>+ #N <sub>16</sub> + C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 12                                             | —                                                | 21                                             | —                                              | 6        | *     | *  | *  | *                                            | 8    |
| 721 | ADCB A, #N <sub>8</sub><br>ADCB A, IN<br>ADCB A, PSWH<br>ADCB A, PSWL<br>ADCB A, off N <sub>8</sub><br>ADCB A, N <sub>8</sub><br>ADCB A, [DP]<br>ADCB A, ±N <sub>8</sub> [USP]<br>ADCB A, N <sub>16</sub> [X1]<br>ADCB A, N <sub>16</sub> [X2]                                                                                                                                 | A <sub>L</sub> ← A <sub>L</sub> + #N <sub>8</sub> + C<br>A <sub>L</sub> ← A <sub>L</sub> + IN + C<br>A <sub>L</sub> ← A <sub>L</sub> + PSWH + C<br>A <sub>L</sub> ← A <sub>L</sub> + PSWL + C<br>A <sub>L</sub> ← A <sub>L</sub> + off N <sub>8</sub> + C<br>A <sub>L</sub> ← A <sub>L</sub> + N <sub>8</sub> + C<br>A <sub>L</sub> ← A <sub>L</sub> + [DP] + C<br>A <sub>L</sub> ← A <sub>L</sub> + ±N <sub>8</sub> [USP] + C<br>A <sub>L</sub> ← A <sub>L</sub> + N <sub>16</sub> [X1] + C<br>A <sub>L</sub> ← A <sub>L</sub> + N <sub>16</sub> [X2] + C | 4<br>3<br>4<br>4<br>4<br>6<br>6<br>7<br>8<br>8 | —<br>5<br>—<br>—<br>7<br>—<br>—<br>9<br>10<br>10 | —<br>2<br>1<br>2<br>2<br>3<br>2<br>3<br>4<br>4 | 2<br>1<br>2<br>2<br>2<br>3<br>2<br>3<br>4<br>4 | —<br>*   | *     | *  | *  | 9                                            |      |
| 731 | ADCB rN, A<br>ADCB PSWH, A<br>ADCB PSWL, A<br>ADCB off N <sub>8</sub> , A<br>ADCB N <sub>8</sub> , A<br>ADCB [DP], A<br>ADCB ±N <sub>8</sub> [USP], A<br>ADCB N <sub>16</sub> [X1], A<br>ADCB N <sub>16</sub> [X2], A                                                                                                                                                          | rN ← rN+A <sub>L</sub> +C<br>PSWH ← PSWH+A <sub>L</sub> +C<br>PSWL ← PSWL+A <sub>L</sub> +C<br>off N <sub>8</sub> ← off N <sub>8</sub> -A <sub>L</sub> +C<br>N <sub>8</sub> ← N <sub>8</sub> -A <sub>L</sub> +C<br>[DP] ← [DP]+A <sub>L</sub> +C<br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP]+A <sub>L</sub> +C<br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]-A <sub>L</sub> +C<br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]-A <sub>L</sub> +C                                                                                                      | 5<br>5<br>5<br>7<br>7<br>7<br>7<br>9<br>9      | —<br>—<br>—<br>12<br>—<br>11<br>—<br>13<br>13    | 9<br>—<br>—<br>3<br>3<br>2<br>3<br>4<br>4      | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4      | —<br>*   | *     | *  | *  | 13<br>10<br>10<br>10<br>10<br>10<br>10<br>10 |      |
| 740 | ADCB rN, off N <sub>8</sub><br>ADCB PSWH, off N <sub>8</sub><br>ADCB PSWL, off N <sub>8</sub><br>ADCB off N <sub>8</sub> , off N <sub>8</sub><br>ADCB N <sub>8</sub> , off N <sub>8</sub><br>ADCB [DP], off N <sub>8</sub><br>ADCB ±N <sub>8</sub> [USP], off N <sub>8</sub><br>ADCB N <sub>16</sub> [X1], off N <sub>8</sub><br>ADCB N <sub>16</sub> [X2], off N <sub>8</sub> | rN ← rN-off N <sub>8</sub> +C<br>PSWH ← PSWH-off N <sub>8</sub> +C<br>PSWL ← PSWL-off N <sub>8</sub> +C<br>off N <sub>8</sub> ← off N <sub>8</sub> +off N <sub>8</sub> +C<br>N <sub>8</sub> ← N <sub>8</sub> , off N <sub>8</sub> +C<br>[DP] ← [DP]+off N <sub>8</sub> +C<br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP]+off N <sub>8</sub> +C<br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>+ off N <sub>8</sub> +C<br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>+ off N <sub>8</sub> +C                                                       | 7<br>7<br>7<br>9<br>9<br>9<br>10<br>11<br>11   | —<br>12<br>12<br>—<br>—<br>14<br>15<br>13<br>13  | 14<br>—<br>—<br>17<br>—<br>—<br>12<br>18<br>18 | 3<br>3<br>3<br>4<br>4<br>3<br>4<br>5<br>5      | —<br>*   | *     | *  | *  | 11                                           |      |
| 743 | ADCB rN, #N <sub>8</sub><br>ADCB PSWH, #N <sub>8</sub><br>ADCB PSWL, #N <sub>8</sub><br>ADCB off N <sub>8</sub> , #N <sub>8</sub><br>ADCB N <sub>8</sub> , #N <sub>8</sub><br>ADCB [DP], #N <sub>8</sub><br>ADCB ±N <sub>8</sub> [USP], #N <sub>8</sub><br>ADCB N <sub>16</sub> [X1], #N <sub>8</sub><br>ADCB N <sub>16</sub> [X2], #N <sub>8</sub>                            | rN ← rN+#N <sub>8</sub> +C<br>PSWH ← PSWH+#N <sub>8</sub> +C<br>PSWL ← PSWL+#N <sub>8</sub> +C<br>off N <sub>8</sub> ← off N <sub>8</sub> +#N <sub>8</sub> +C<br>N <sub>8</sub> ← N <sub>8</sub> , #N <sub>8</sub> +C<br>[DP] ← [DP]+#N <sub>8</sub> +C<br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP]+#N <sub>8</sub> +C<br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>+ #N <sub>8</sub> +C<br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>+ #N <sub>8</sub> +C                                                                                  | 6<br>6<br>6<br>8<br>8<br>8<br>9<br>10<br>10    | —<br>—<br>—<br>14<br>—<br>13<br>14<br>15<br>15   | 11<br>—<br>—<br>4<br>—<br>3<br>4<br>5<br>5     | 3<br>3<br>3<br>4<br>4<br>3<br>4<br>5<br>5      | —<br>*   | *     | *  | *  | 11                                           |      |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-18. Arithmetic Calculation Instructions (5)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Int <sup>*1</sup>                                               | Int <sup>*1</sup>                                                        | Ext <sup>*1</sup>                                                | Ext <sup>*1</sup>                                                | Byte no.                                                      | Flags                                                         |                                                               |                                                                    | Page                                                                                    |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Int <sup>*2</sup><br>Cyc                                        | Ext <sup>*2</sup><br>Cyc                                                 | Int <sup>*2</sup><br>Cyc                                         | Ext <sup>*2</sup><br>Cyc                                         |                                                               | ZF                                                            | CF                                                            | HC                                                                 |                                                                                         |
| 758 | SUB A, #N <sub>16</sub><br>SUB A, erN<br>SUB A, DP<br>SUB A, X1<br>SUB A, X2<br>SUB A, USP<br>SUB A, SSP<br>SUB A, LRB<br>SUB A, off N <sub>8</sub><br>SUB A, N <sub>8</sub><br>SUB A, [DP]<br>SUB A, ±N <sub>8</sub> [USP]<br>SUB A, N <sub>16</sub> [X1]<br>SUB A, N <sub>16</sub> [X2]                                                                                                                                                                                                     | A ← A - #N <sub>16</sub><br>A ← A - erN<br>A ← A - DP<br>A ← A - X1<br>A ← A - X2<br>A ← A - USP<br>A ← A - SSP<br>A ← A - LRB<br>A ← A - off N <sub>8</sub><br>A ← A - N <sub>8</sub><br>A ← A - [DP]<br>A ← A - ±N <sub>8</sub> [USP]<br>A ← A - N <sub>16</sub> [X1]<br>A ← A - N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                        | 6<br>3<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>5<br>7<br>8   | —<br>7<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>10<br>11<br>12         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>13<br>13<br>13 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>20<br>22<br>24 | 3<br>1<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>4      | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•      | 157<br>157<br>157<br>157<br>157<br>157<br>157<br>157<br>157<br>157<br>157<br>157<br>157 |
| 772 | SUB erN, A<br>SUB DP, A<br>SUB X1, A<br>SUB X2, A<br>SUB USP, A<br>SUB SSP, A<br>SUB LRB, A<br>SUB off N <sub>8</sub> , A<br>SUB N <sub>8</sub> , A<br>SUB [DP], A<br>SUB ±N <sub>8</sub> [USP], A<br>SUB N <sub>16</sub> [X1], A<br>SUB N <sub>16</sub> [X2], A                                                                                                                                                                                                                              | erN ← erN - A<br>DP ← DP - A<br>X1 ← X1 - A<br>X2 ← X2 - A<br>USP ← USP - A<br>SSP ← SSP - A<br>LRB ← LRB - A<br>off N <sub>8</sub> ← off N <sub>8</sub> - A<br>N <sub>8</sub> ← N <sub>8</sub> - A<br>[DP] ← [DP] - A<br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - A<br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - A<br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - A                                                                                                                                                                                                                              | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>7<br>7<br>7<br>8<br>9<br>9   | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>13<br>13<br>17         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>13<br>—<br>15<br>13<br>17     | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>20<br>22<br>24 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>3<br>3<br>4      | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•      | 158<br>158<br>158<br>158<br>158<br>158<br>158<br>158<br>158<br>158<br>158<br>158        |
| 785 | SUB erN, off N <sub>8</sub><br>SUB DP, off N <sub>8</sub><br>SUB X1, off N <sub>8</sub><br>SUB X2, off N <sub>8</sub><br>SUB USP, off N <sub>8</sub><br>SUB SSP, off N <sub>8</sub><br>SUB LRB, off N <sub>8</sub><br>SUB off N <sub>8</sub> , off N <sub>8</sub><br>SUB N <sub>8</sub> , off N <sub>8</sub><br>SUB [DP], off N <sub>8</sub><br>SUB ±N <sub>8</sub> [USP], off N <sub>8</sub><br>SUB N <sub>16</sub> [X1], off N <sub>8</sub><br>SUB N <sub>16</sub> [X2], off N <sub>8</sub> | erN ← erN - off N <sub>8</sub><br>DP ← DP - off N <sub>8</sub><br>X1 ← X1 - off N <sub>8</sub><br>X2 ← X2 - off N <sub>8</sub><br>USP ← USP - off N <sub>8</sub><br>SSP ← SSP - off N <sub>8</sub><br>LRB ← LRB - off N <sub>8</sub><br>off N <sub>8</sub> ← off N <sub>8</sub> - off N <sub>8</sub><br>N <sub>8</sub> ← N <sub>8</sub> - off N <sub>8</sub><br>[DP] ← [DP] - off N <sub>8</sub><br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - off N <sub>8</sub><br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - off N <sub>8</sub><br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - off N <sub>8</sub> | 7<br>7<br>7<br>7<br>7<br>7<br>7<br>9<br>9<br>9<br>9<br>11<br>11 | —<br>13<br>13<br>13<br>13<br>13<br>13<br>—<br>18<br>18<br>19<br>20<br>20 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>15  | —<br>—<br>—<br>—<br>—<br>—<br>—<br>23<br>—<br>22<br>23<br>24     | 3<br>3<br>3<br>3<br>3<br>3<br>3<br>4<br>4<br>3<br>5           | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•      | 159<br>159<br>159<br>159<br>159<br>159<br>159<br>159<br>159<br>159<br>159<br>159        |
| 798 | SUB erN, #N <sub>16</sub><br>SUB DP, #N <sub>16</sub><br>SUB X1, #N <sub>16</sub><br>SUB X2, #N <sub>16</sub><br>SUB USP, #N <sub>16</sub><br>SUB SSP, #N <sub>16</sub><br>SUB LRB, #N <sub>16</sub><br>SUB off N <sub>8</sub> , #N <sub>16</sub><br>SUB N <sub>8</sub> , #N <sub>16</sub><br>SUB [DP], #N <sub>16</sub><br>SUB ±N <sub>8</sub> [USP], #N <sub>16</sub>                                                                                                                       | erN ← erN - #N <sub>16</sub><br>DP ← DP - #N <sub>16</sub><br>X1 ← X1 - #N <sub>16</sub><br>X2 ← X2 - #N <sub>16</sub><br>USP ← USP - #N <sub>16</sub><br>SSP ← SSP - #N <sub>16</sub><br>LRB ← LRB - #N <sub>16</sub><br>off N <sub>8</sub> ← off N <sub>8</sub> - #N <sub>16</sub><br>N <sub>8</sub> ← N <sub>8</sub> - #N <sub>16</sub><br>[DP] ← [DP] - #N <sub>16</sub><br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - #N <sub>16</sub>                                                                                                                                                               | 8<br>8<br>8<br>8<br>8<br>8<br>8<br>10<br>10<br>10<br>10         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>20<br>—<br>20                         | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>17<br>19<br>20 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>4<br>4<br>5    | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | 160<br>160<br>160<br>160<br>160<br>160<br>160<br>160<br>160<br>160 |                                                                                         |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-19. Arithmetic Calculation Instructions (6)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                      | Operation                                                          | Int *1 | Int *1 | Ext *1 | Ext *1 | Byte no. | Flags |    |    | Page |
|-----|------------------------------------------------|--------------------------------------------------------------------|--------|--------|--------|--------|----------|-------|----|----|------|
|     |                                                |                                                                    | Int *2 | Ext *2 | Int *2 | Ext *2 |          | ZF    | CF | HC |      |
| 809 | SUB N <sub>16</sub> [X1], #N <sub>16</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - #N <sub>16</sub>     | 12     | —      | 21     | —      | 6        | •     | •  | •  | 160  |
|     | SUB N <sub>16</sub> [X2], #N <sub>16</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - #N <sub>16</sub>     | 12     | —      | 21     | —      | 6        | •     | •  | •  | 160  |
| 811 | SUBB A, #N <sub>8</sub>                        | A <sub>L</sub> ← A <sub>L</sub> - #N <sub>8</sub>                  | 4      | —      | —      | —      | 2        | •     | •  | •  | 161  |
|     | SUBB A, rN                                     | A <sub>L</sub> ← A <sub>L</sub> - rN                               | 3      | 5      | —      | —      | 1        | •     | •  | •  | 161  |
|     | SUBB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> - PSWH                             | 4      | —      | —      | —      | 2        | •     | •  | •  | 161  |
|     | SUBB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> - PSWL                             | 4      | —      | —      | —      | 2        | •     | •  | •  | 161  |
|     | SUBB A, off N <sub>8</sub>                     | A <sub>L</sub> ← A <sub>L</sub> - off N <sub>8</sub>               | 4      | 7      | —      | —      | 2        | •     | •  | •  | 161  |
|     | SUBB A, N <sub>8</sub>                         | A <sub>L</sub> ← A <sub>L</sub> - N <sub>8</sub>                   | 6      | —      | —      | —      | 3        | •     | •  | •  | 161  |
|     | SUBB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> - [DP]                             | 6      | —      | —      | —      | 3        | •     | •  | •  | 161  |
|     | SUBB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> - ±N <sub>8</sub> [USP]            | 7      | 9      | —      | —      | 3        | •     | •  | •  | 161  |
|     | SUBB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> - N <sub>16</sub> [X1]             | 8      | 10     | —      | —      | 4        | •     | •  | •  | 161  |
|     | SUBB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> - N <sub>16</sub> [X2]             | 8      | 10     | —      | —      | 4        | •     | •  | •  | 161  |
| 821 | SUBB rN, A                                     | rN ← rN - A <sub>L</sub>                                           | 5      | —      | 9      | —      | 2        | •     | •  | •  | 162  |
|     | SUBB PSWH, A                                   | PSWH ← PSWH - A <sub>L</sub>                                       | 5      | —      | —      | —      | 2        | •     | •  | •  | 162  |
|     | SUBB PSWL, A                                   | PSWL ← PSWL - A <sub>L</sub>                                       | 5      | —      | —      | —      | 2        | •     | •  | •  | 162  |
|     | SUBB off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> - A <sub>L</sub>           | 7      | —      | 12     | —      | 3        | •     | •  | •  | 162  |
|     | SUBB N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> - A <sub>L</sub>                   | 7      | —      | —      | —      | 3        | •     | •  | •  | 162  |
|     | SUBB [DP], A                                   | [DP] ← [DP] - A <sub>L</sub>                                       | 7      | —      | 11     | —      | 2        | •     | •  | •  | 162  |
|     | SUBB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - A <sub>L</sub>     | 8      | —      | 12     | —      | 3        | •     | •  | •  | 162  |
|     | SUBB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - A <sub>L</sub>       | 9      | —      | 13     | —      | 4        | •     | •  | •  | 162  |
|     | SUBB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - A <sub>L</sub>       | 9      | —      | 13     | —      | 4        | •     | •  | •  | 162  |
| 830 | SUBB rN, off N <sub>8</sub>                    | rN ← rN - off N <sub>8</sub>                                       | 7      | —      | —      | 14     | 3        | •     | •  | •  | 163  |
|     | SUBB PSWH, off N <sub>8</sub>                  | PSWH ← PSWH - off N <sub>8</sub>                                   | 7      | 12     | —      | —      | 3        | •     | •  | •  | 163  |
|     | SUBB PSWL, off N <sub>8</sub>                  | PSWL ← PSWL - off N <sub>8</sub>                                   | 7      | 12     | —      | —      | 3        | •     | •  | •  | 163  |
|     | SUBB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> - off N <sub>8</sub>       | 9      | —      | —      | 17     | 4        | •     | •  | •  | 163  |
|     | SUBB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> - off N <sub>8</sub>               | 9      | 14     | —      | —      | 4        | •     | •  | •  | 163  |
|     | SUBB [DP], off N <sub>8</sub>                  | [DP] ← [DP] - off N <sub>8</sub>                                   | 9      | 14     | 11     | 13     | 3        | •     | •  | •  | 163  |
|     | SUBB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - off N <sub>8</sub> | 10     | 15     | 12     | 17     | 4        | •     | •  | •  | 163  |
|     | SUBB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - off N <sub>8</sub>   | 11     | 13     | 13     | 18     | 5        | •     | •  | •  | 163  |
|     | SUBB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - off N <sub>8</sub>   | 11     | 13     | 13     | 18     | 5        | •     | •  | •  | 163  |
| 839 | SUBB rN, #N <sub>8</sub>                       | rN ← rN - #N <sub>8</sub>                                          | 6      | —      | 11     | —      | 3        | •     | •  | •  | 164  |
|     | SUBB PSWH, #N <sub>8</sub>                     | PSWH ← PSWH - #N <sub>8</sub>                                      | 6      | —      | —      | —      | 3        | •     | •  | •  | 164  |
|     | SUBB PSWL, #N <sub>8</sub>                     | PSWL ← PSWL - #N <sub>8</sub>                                      | 6      | —      | —      | —      | 3        | •     | •  | •  | 164  |
|     | SUBB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> ← off N <sub>8</sub> - #N <sub>8</sub>          | 8      | —      | 14     | —      | 4        | •     | •  | •  | 164  |
|     | SUBB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> ← N <sub>8</sub> - #N <sub>8</sub>                  | 8      | —      | —      | —      | 4        | •     | •  | •  | 164  |
|     | SUBB [DP], #N <sub>8</sub>                     | [DP] ← [DP] - #N <sub>8</sub>                                      | 8      | —      | 13     | —      | 3        | •     | •  | •  | 164  |
|     | SUBB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - #N <sub>8</sub>    | 9      | —      | 14     | —      | 4        | •     | •  | •  | 164  |
|     | SUBB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - #N <sub>8</sub>      | 10     | —      | 15     | —      | 5        | •     | •  | •  | 164  |
|     | SUBB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - #N <sub>8</sub>      | 10     | —      | 15     | —      | 5        | •     | •  | •  | 164  |
| 848 | SBC A, #N <sub>16</sub>                        | A ← A - #N <sub>16</sub> - C                                       | 6      | —      | —      | —      | 3        | •     | •  | •  | 129  |
|     | SBC A, rN                                      | A ← A - rN - C                                                     | 3      | 7      | —      | —      | 1        | •     | •  | •  | 129  |
|     | SBC A, DP                                      | A ← A - DP - C                                                     | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |
|     | SBC A, X1                                      | A ← A - X1 - C                                                     | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |
|     | SBC A, X2                                      | A ← A - X2 - C                                                     | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |
|     | SBC A, USP                                     | A ← A - USP - C                                                    | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |
|     | SBC A, SSP                                     | A ← A - SSP - C                                                    | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |
|     | SBC A, LBS                                     | A ← A - LBS - C                                                    | 4      | —      | —      | —      | 2        | •     | •  | •  | 129  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-20. Arithmetic Calculation Instructions (7)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                     | Operation                                                              | Int '1 | Int '1 | Ext '1 | Ext '1 | Ext '1 | Ext '1 | Byte no. | Flags |    |    |   | Page |
|-----|-----------------------------------------------|------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|----------|-------|----|----|---|------|
|     |                                               |                                                                        | Int '2 | Ext '2 | Int '2 | Ext '2 | Cyc    | ZF     |          | CF    | HC | DD |   |      |
| 856 | SBC A, off N <sub>8</sub>                     | A ← A - off N <sub>8</sub> - C                                         | 4      | 9      |        |        |        |        | 2        | •     | •  | •  | • | 129  |
|     | SBC A, N <sub>8</sub>                         | A ← A - N <sub>8</sub> - C                                             | 6      | —      |        |        |        |        |          | 3     | •  | •  | • |      |
|     | SBC A, [DP]                                   | A ← A - [DP] - C                                                       | 6      | 10     |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC A, ±N <sub>8</sub> [USP]                  | A ← A - ±N <sub>8</sub> [USP] - C                                      | 7      | 11     |        |        |        |        |          | 3     | •  | •  | • |      |
|     | SBC A, N <sub>16</sub> [X1]                   | A ← A - N <sub>16</sub> [X1] - C                                       | 8      | 12     |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC A, N <sub>16</sub> [X2]                   | A ← A - N <sub>16</sub> [X2] - C                                       | 8      | 12     |        |        |        |        |          | 4     | •  | •  | • |      |
| 862 | SBC #N, A                                     | #N ← #N - A - C                                                        | 5      | —      |        | 13     |        |        | 2        | •     | •  | •  | • | 130  |
|     | SBC DP, A                                     | DP ← DP - A - C                                                        | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC X1, A                                     | X1 ← X1 - A - C                                                        | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC X2, A                                     | X2 ← X2 - A - C                                                        | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC USP, A                                    | USP ← USP - A - C                                                      | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC SSP, A                                    | SSP ← SSP - A - C                                                      | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC LRB, A                                    | LRB ← LRB - A - C                                                      | 5      | —      |        |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> - A - C                        | 7      | —      | 13     |        |        |        |          | 3     | •  | •  | • |      |
|     | SBC N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> - A - C                                | 7      | —      | —      |        |        |        |          | 3     | •  | •  | • |      |
|     | SBC [DP], A                                   | [DP] ← [DP] - A - C                                                    | 7      | —      | 15     |        |        |        |          | 2     | •  | •  | • |      |
|     | SBC ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - A - C                  | 8      | —      | 13     |        |        |        |          | 3     | •  | •  | • |      |
| 876 | SBC N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - A - C                    | 9      | —      | 17     |        |        |        | 4        | •     | •  | •  | • | 130  |
|     | SBC N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - A - C                    | 9      | —      | 17     |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC #N, off N <sub>8</sub>                    | #N ← #N - off N <sub>8</sub> - C                                       | 7      | —      | —      | 20     |        |        |          | 3     | •  | •  | • |      |
|     | SBC DP, off N <sub>8</sub>                    | DP ← DP - off N <sub>8</sub> - C                                       | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC X1, off N <sub>8</sub>                    | X1 ← X1 - off N <sub>8</sub> - C                                       | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC X2, off N <sub>8</sub>                    | X2 ← X2 - off N <sub>8</sub> - C                                       | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC USP, off N <sub>8</sub>                   | USP ← USP - off N <sub>8</sub> - C                                     | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC SSP, off N <sub>8</sub>                   | SSP ← SSP - off N <sub>8</sub> - C                                     | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC LRB, off N <sub>8</sub>                   | LRB ← LRB - off N <sub>8</sub> - C                                     | 7      | 13     | —      | —      |        |        |          | 3     | •  | •  | • |      |
|     | SBC off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> - off N <sub>8</sub> - C       | 9      | —      | —      | 23     |        |        |          | 4     | •  | •  | • |      |
|     | SBC N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> - off N <sub>8</sub> - C               | 9      | 18     | —      | —      |        |        |          | 4     | •  | •  | • |      |
|     | SBC [DP], off N <sub>8</sub>                  | [DP] ← [DP] - off N <sub>8</sub> - C                                   | 9      | 18     | 13     | 22     |        |        |          | 3     | •  | •  | • |      |
| 888 | SBC ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - off N <sub>8</sub> - C | 10     | 19     | 14     | 23     |        |        | 4        | •     | •  | •  | • | 131  |
|     | SBC N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - off N <sub>8</sub> - C   | 11     | 20     | 15     | 24     |        |        |          | 5     | •  | •  | • |      |
|     | SBC N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - off N <sub>8</sub> - C   | 11     | 20     | 15     | 24     |        |        |          | 5     | •  | •  | • |      |
|     | SBC #N, #N <sub>16</sub>                      | #N ← #N - #N <sub>16</sub> - C                                         | 8      | —      | 17     |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC DP, #N <sub>16</sub>                      | DP ← DP - #N <sub>16</sub> - C                                         | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC X1, #N <sub>16</sub>                      | X1 ← X1 - #N <sub>16</sub> - C                                         | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC X2, #N <sub>16</sub>                      | X2 ← X2 - #N <sub>16</sub> - C                                         | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC USP, #N <sub>16</sub>                     | USP ← USP - #N <sub>16</sub> - C                                       | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC SSP, #N <sub>16</sub>                     | SSP ← SSP - #N <sub>16</sub> - C                                       | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC LRB, #N <sub>16</sub>                     | LRB ← LRB - #N <sub>16</sub> - C                                       | 8      | —      |        |        |        |        |          | 4     | •  | •  | • |      |
|     | SBC off N <sub>8</sub> , #N <sub>16</sub>     | off N <sub>8</sub> ← off N <sub>8</sub> - #N <sub>16</sub> - C         | 10     | —      | 20     |        |        |        |          | 5     | •  | •  | • |      |
|     | SBC N <sub>8</sub> , #N <sub>16</sub>         | N <sub>8</sub> ← N <sub>8</sub> - #N <sub>16</sub> - C                 | 10     | —      |        |        |        |        |          | 5     | •  | •  | • |      |
| 888 | SBC [DP], #N <sub>16</sub>                    | [DP] ← [DP] - #N <sub>16</sub> - C                                     | 10     | —      | 19     |        |        |        | 4        | •     | •  | •  | • | 132  |
|     | SBC ±N <sub>8</sub> [USP], #N <sub>16</sub>   | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - #N <sub>16</sub> - C   | 11     | 20     | 20     |        |        |        |          | 5     | •  | •  | • |      |
|     | SBC N <sub>16</sub> [X1], #N <sub>16</sub>    | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - #N <sub>16</sub> - C     | 12     | —      | 21     |        |        |        |          | 6     | •  | •  | • |      |
|     | SBC N <sub>16</sub> [X2], #N <sub>16</sub>    | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - #N <sub>16</sub> - C     | 12     | —      | 21     |        |        |        |          | 6     | •  | •  | • |      |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-21. Arithmetic Calculation Instructions (8)** \*1 - the first operand  
\*2 - the second operand

| No. | Mnemonics                                      | Operation                                                              | Int *1 | Int *1 | Ext *1 | Ext *1 | Ext *1 | Byte no. | Flags |    |    | Page |
|-----|------------------------------------------------|------------------------------------------------------------------------|--------|--------|--------|--------|--------|----------|-------|----|----|------|
|     |                                                |                                                                        | Int *2 | Ext *2 | Int *2 | Ext *2 | Ext *2 |          | ZF    | CF | HC |      |
| 901 | SBCB A, #N <sub>8</sub>                        | A <sub>L</sub> ← A <sub>L</sub> - #N <sub>8</sub> - C                  | 4      | —      | —      | —      | —      | 2        | *     | *  | *  | 133  |
|     | SBCB A, rN                                     | A <sub>L</sub> ← A <sub>L</sub> - rN - C                               | 3      | 5      | —      | —      | —      | 1        | *     | *  | *  | 133  |
|     | SBCB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> - PSWH - C                             | 4      | —      | —      | —      | —      | 2        | *     | *  | *  | 133  |
|     | SBCB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> - PSWL - C                             | 4      | —      | —      | —      | —      | 2        | *     | *  | *  | 133  |
|     | SBCB A, off N <sub>8</sub>                     | A <sub>L</sub> ← A <sub>L</sub> - off N <sub>8</sub> - C               | 4      | 7      | —      | —      | —      | 2        | *     | *  | *  | 133  |
|     | SBCB A, N <sub>8</sub>                         | A <sub>L</sub> ← A <sub>L</sub> - N <sub>8</sub> - C                   | 6      | —      | —      | —      | —      | 3        | *     | *  | *  | 133  |
|     | SBCB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> - [DP] - C                             | 6      | —      | —      | —      | —      | 2        | *     | *  | *  | 133  |
|     | SBCB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> - ±N <sub>8</sub> [USP] - C            | 7      | 9      | —      | —      | —      | 3        | *     | *  | *  | 133  |
|     | SBCB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> - N <sub>16</sub> [X1] - C             | 8      | 10     | —      | —      | —      | 4        | *     | *  | *  | 133  |
|     | SBCB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> - N <sub>16</sub> [X2] - C             | 8      | 10     | —      | —      | —      | 4        | *     | *  | *  | 133  |
| 911 | SBCB rN, A                                     | rN ← rN - A <sub>L</sub> - C                                           | 5      | —      | 9      | —      | —      | 2        | *     | *  | *  | 134  |
|     | SBCB PSWH, A                                   | PSWH ← PSWH - A <sub>L</sub> - C                                       | 5      | —      | —      | —      | —      | 2        | *     | *  | *  | 134  |
|     | SBCB PSWL, A                                   | PSWL ← PSWL - A <sub>L</sub> - C                                       | 5      | —      | —      | —      | —      | 2        | *     | *  | *  | 134  |
|     | SBCB off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> - A <sub>L</sub> - C           | 7      | —      | 12     | —      | —      | 3        | *     | *  | *  | 134  |
|     | SBCB N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> - A <sub>L</sub> - C                   | 7      | —      | —      | —      | —      | 3        | *     | *  | *  | 134  |
|     | SBCB [DP], A                                   | [DP] ← [DP] - A <sub>L</sub> - C                                       | 7      | —      | 11     | —      | —      | 2        | *     | *  | *  | 134  |
|     | SBCB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - A <sub>L</sub> - C     | —      | —      | 12     | —      | —      | 3        | *     | *  | *  | 134  |
|     | SBCB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - A <sub>L</sub> - C       | 9      | —      | 13     | —      | —      | 4        | *     | *  | *  | 134  |
|     | SBCB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - A <sub>L</sub> - C       | 9      | —      | 13     | —      | —      | 4        | *     | *  | *  | 134  |
|     | SBCB rN, off N <sub>8</sub>                    | rN ← rN - off N <sub>8</sub> - C                                       | 7      | —      | —      | —      | 14     | 3        | *     | *  | *  | 135  |
| 920 | SBCB PSWH, off N <sub>8</sub>                  | PSWH ← PSWH - off N <sub>8</sub> - C                                   | 7      | 12     | —      | —      | —      | 3        | *     | *  | *  | 135  |
|     | SBCB PSWL, off N <sub>8</sub>                  | PSWL ← PSWL - off N <sub>8</sub> - C                                   | 7      | 12     | —      | —      | —      | 3        | *     | *  | *  | 135  |
|     | SBCB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> - off N <sub>8</sub> - C       | 9      | —      | —      | —      | 17     | 4        | *     | *  | *  | 135  |
|     | SBCB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> - off N <sub>8</sub> - C               | 9      | 14     | —      | —      | —      | 4        | *     | *  | *  | 135  |
|     | SBCB [DP], off N <sub>8</sub>                  | [DP] ← [DP] - off N <sub>8</sub> - C                                   | 9      | 14     | 11     | —      | 13     | 3        | *     | *  | *  | 135  |
|     | SBCB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - off N <sub>8</sub> - C | 10     | 15     | 12     | —      | 17     | 4        | *     | *  | *  | 135  |
|     | SBCB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - off N <sub>8</sub> - C   | 11     | 13     | 13     | 18     | 5      | *        | *     | *  | *  | 135  |
|     | SBCB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - off N <sub>8</sub> - C   | 11     | 13     | 13     | 18     | 5      | *        | *     | *  | *  | 135  |
|     | SBCB rN, #N <sub>8</sub>                       | rN ← rN - #N <sub>8</sub> - C                                          | 6      | —      | 11     | —      | —      | 3        | *     | *  | *  | 136  |
|     | SBCB PSWH, #N <sub>8</sub>                     | PSWH ← PSWH - #N <sub>8</sub> - C                                      | 6      | —      | —      | —      | —      | 3        | *     | *  | *  | 136  |
| 929 | SBCB PSWL, #N <sub>8</sub>                     | PSWL ← PSWL - #N <sub>8</sub> - C                                      | 6      | —      | —      | —      | —      | 3        | *     | *  | *  | 136  |
|     | SBCB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> ← off N <sub>8</sub> - #N <sub>8</sub> - C          | 9      | —      | 14     | —      | —      | 4        | *     | *  | *  | 136  |
|     | SBCB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> ← N <sub>8</sub> - #N <sub>8</sub> - C                  | 8      | —      | —      | —      | —      | 4        | *     | *  | *  | 136  |
|     | SBCB [DP], #N <sub>8</sub>                     | [DP] ← [DP] - #N <sub>8</sub> - C                                      | 8      | —      | 13     | —      | —      | 3        | *     | *  | *  | 136  |
|     | SBCB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] - #N <sub>8</sub> - C    | 9      | —      | 14     | —      | —      | 4        | *     | *  | *  | 136  |
|     | SBCB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] - #N <sub>8</sub> - C      | 10     | —      | 15     | —      | —      | 5        | *     | *  | *  | 136  |
|     | SBCB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] - #N <sub>8</sub> - C      | 10     | —      | 15     | —      | —      | 5        | *     | *  | *  | 136  |

## **Chapter 3 Details of Instructions**

**TABLE 3-22. Logical Calculation Instructions (1)**

| No. | Mnemonics                                     | Operation                                                           | Int <sup>-1</sup>        | Int <sup>-1</sup>        | Ext <sup>-1</sup>        | Ext <sup>-1</sup>        | Byte no. | Flags |    |    | Page |
|-----|-----------------------------------------------|---------------------------------------------------------------------|--------------------------|--------------------------|--------------------------|--------------------------|----------|-------|----|----|------|
|     |                                               |                                                                     | Int <sup>-2</sup><br>Cyc | Ext <sup>-2</sup><br>Cyc | Int <sup>-2</sup><br>Cyc | Ext <sup>-2</sup><br>Cyc |          | ZF    | CF | HC |      |
| 938 | AND A, #N <sub>16</sub>                       | A ← A ∧ N <sub>16</sub>                                             | 6                        | —                        | —                        | —                        | 3        | *     | *  | *  | 23   |
|     | AND A, #N                                     | A ← A ∧ #N                                                          | 3                        | 7                        | —                        | —                        | 1        | *     | *  | *  | 23   |
|     | AND A, DP                                     | A ← A ∧ DP                                                          | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, X1                                     | A ← A ∧ X1                                                          | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, X2                                     | A ← A ∧ X2                                                          | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, USP                                    | A ← A ∧ USP                                                         | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, SSP                                    | A ← A ∧ SSP                                                         | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, LRB                                    | A ← A ∧ LRB                                                         | 4                        | —                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, off N <sub>8</sub>                     | A ← A ∧ off N <sub>8</sub>                                          | 4                        | 9                        | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, N <sub>8</sub>                         | A ← A ∧ N <sub>8</sub>                                              | 6                        | —                        | —                        | —                        | 3        | *     | *  | *  | 23   |
|     | AND A, [DP]                                   | A ← A ∧ [DP]                                                        | 6                        | 10                       | —                        | —                        | 2        | *     | *  | *  | 23   |
|     | AND A, ±N <sub>8</sub> [USP]                  | A ← A ∧ N <sub>8</sub> [USP]                                        | 7                        | 11                       | —                        | —                        | 3        | *     | *  | *  | 23   |
|     | AND A, N <sub>16</sub> [X1]                   | A ← A ∧ N <sub>16</sub> [X1]                                        | 8                        | 12                       | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND A, N <sub>16</sub> [X2]                   | A ← A ∧ N <sub>16</sub> [X2]                                        | 8                        | 12                       | —                        | —                        | 4        | *     | *  | *  | 23   |
| 952 | AND #N, A                                     | #N ← #N ∧ A                                                         | 5                        | —                        | —                        | 13                       | 2        | *     | *  | *  | 21   |
|     | AND DP, A                                     | DP ← DP ∧ A                                                         | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND X1, A                                     | X1 ← X1 ∧ A                                                         | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND X2, A                                     | X2 ← X2 ∧ A                                                         | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND USP, A                                    | USP ← USP ∧ A                                                       | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND SSP, A                                    | SSP ← SSP ∧ A                                                       | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND LRB, A                                    | LRB ← LRB ∧ A                                                       | 5                        | —                        | —                        | —                        | 2        | *     | *  | *  | 21   |
|     | AND off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> ∧ A                         | 7                        | —                        | 13                       | —                        | 3        | *     | *  | *  | 21   |
|     | AND N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> ∧ A                                 | 7                        | —                        | —                        | —                        | 3        | *     | *  | *  | 21   |
|     | AND [DP], A                                   | [DP] ← [DP] ∧ A                                                     | 7                        | —                        | 15                       | —                        | 2        | *     | *  | *  | 21   |
|     | AND ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∧ A                   | 8                        | —                        | 13                       | —                        | 3        | *     | *  | *  | 21   |
|     | AND N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] ∧ A                     | 9                        | —                        | 17                       | —                        | 4        | *     | *  | *  | 21   |
|     | AND N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] ∧ A                     | 9                        | —                        | 17                       | —                        | 4        | *     | *  | *  | 21   |
| 955 | AND #N, off N <sub>8</sub>                    | #N ← #N ∧ off N <sub>8</sub>                                        | 7                        | —                        | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND DP, off N <sub>8</sub>                    | DP ← DP ∧ off N <sub>8</sub>                                        | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND X1, off N <sub>8</sub>                    | X1 ← X1 ∧ off N <sub>8</sub>                                        | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND X2, off N <sub>8</sub>                    | X2 ← X2 ∧ off N <sub>8</sub>                                        | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND USP, off N <sub>8</sub>                   | USP ← USP ∧ off N <sub>8</sub>                                      | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND SSP, off N <sub>8</sub>                   | SSP ← SSP ∧ off N <sub>8</sub>                                      | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND LRB, off N <sub>8</sub>                   | LRB ← LRB ∧ off N <sub>8</sub>                                      | 7                        | 13                       | —                        | —                        | 3        | *     | *  | *  | 22   |
|     | AND off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> ∧ off N <sub>8</sub>        | 9                        | —                        | —                        | —                        | 4        | *     | *  | *  | 22   |
|     | AND N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> ∧ off N <sub>8</sub>                | 9                        | —                        | 16                       | —                        | 4        | *     | *  | *  | 22   |
|     | AND [DP], off N <sub>8</sub>                  | [DP] ← [DP] ∧ off N <sub>8</sub>                                    | 9                        | —                        | 16                       | —                        | 3        | *     | *  | *  | 22   |
|     | AND ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∧ off N <sub>8</sub>  | 10                       | —                        | 14                       | —                        | 4        | *     | *  | *  | 22   |
|     | AND N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>∧ off N <sub>8</sub> | 11                       | 20                       | 15                       | 26                       | 5        | *     | *  | *  | 22   |
|     | AND N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>∧ off N <sub>8</sub> | 11                       | 20                       | 15                       | 26                       | 5        | *     | *  | *  | 22   |
| 978 | AND #N, #N <sub>16</sub>                      | #N ← #N ∧ #N <sub>16</sub>                                          | 8                        | —                        | 17                       | —                        | 4        | *     | *  | *  | 23   |
|     | AND DP, #N <sub>16</sub>                      | DP ← DP ∧ #N <sub>16</sub>                                          | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND X1, #N <sub>16</sub>                      | X1 ← X1 ∧ #N <sub>16</sub>                                          | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND X2, #N <sub>16</sub>                      | X2 ← X2 ∧ #N <sub>16</sub>                                          | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND USP, #N <sub>16</sub>                     | USP ← USP ∧ #N <sub>16</sub>                                        | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND SSP, #N <sub>16</sub>                     | SSP ← SSP ∧ #N <sub>16</sub>                                        | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND LRB, #N <sub>16</sub>                     | LRB ← LRB ∧ #N <sub>16</sub>                                        | 8                        | —                        | —                        | —                        | 4        | *     | *  | *  | 23   |
|     | AND off N <sub>8</sub> , #N <sub>16</sub>     | off N <sub>8</sub> ← off N <sub>8</sub> ∧ #N <sub>16</sub>          | 10                       | —                        | —                        | —                        | 5        | *     | *  | *  | 23   |
|     | AND N <sub>8</sub> , #N <sub>16</sub>         | N <sub>8</sub> ← N <sub>8</sub> ∧ #N <sub>16</sub>                  | 10                       | —                        | —                        | —                        | 5        | *     | *  | *  | 23   |
|     | AND [DP], #N <sub>16</sub>                    | [DP] ← [DP] ∧ #N <sub>16</sub>                                      | 10                       | —                        | 19                       | —                        | 4        | *     | *  | *  | 23   |
|     | AND ±N <sub>8</sub> [USP], #N <sub>16</sub>   | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∧ #N <sub>16</sub>    | 11                       | —                        | 20                       | —                        | 5        | *     | *  | *  | 23   |

## **Chapter 3 Details of Instructions**

**TABLE 3-23. Logical Calculation Instructions (2)**

| No.  | Mnemonics                                      | Operation                                                          | Int <sup>-1</sup>        | Int <sup>-1</sup>        | Ext <sup>-1</sup>        | Ext <sup>-1</sup>        | Byte no. | Flags |    |    | Page |
|------|------------------------------------------------|--------------------------------------------------------------------|--------------------------|--------------------------|--------------------------|--------------------------|----------|-------|----|----|------|
|      |                                                |                                                                    | Int <sup>-2</sup><br>Cyc | Ext <sup>-2</sup><br>Cyc | Int <sup>-2</sup><br>Cyc | Ext <sup>-2</sup><br>Cyc |          | ZF    | CF | HC |      |
| 989  | AND N <sub>16</sub> [X1], #N <sub>16</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>^#N <sub>16</sub>   | 12                       | —                        | 21                       | —                        | 6        | •     |    |    | 23   |
|      | AND N <sub>16</sub> [X2], #N <sub>16</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>^#N <sub>16</sub>   | 12                       | —                        | 21                       | —                        | 6        | •     |    |    | 23   |
| 991  | ANDB A, #N <sub>8</sub>                        | A <sub>L</sub> ← A <sub>L</sub> ^#N <sub>8</sub>                   | 4                        | —                        | —                        | —                        | 2        | •     |    |    | 24   |
|      | ANDB A, rN                                     | A <sub>L</sub> ← A <sub>L</sub> ^rN                                | 3                        | 5                        | —                        | —                        | 1        | •     |    |    | 24   |
|      | ANDB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> ^PSWH                              | 4                        | —                        | —                        | —                        | 2        | •     |    |    | 24   |
|      | ANDB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> ^PSWL                              | 4                        | —                        | —                        | —                        | 2        | •     |    |    | 24   |
|      | ANDB A, off N <sub>8</sub>                     | A <sub>L</sub> ← A <sub>L</sub> ^off N <sub>8</sub>                | 4                        | 7                        | —                        | —                        | 2        | •     |    |    | 24   |
|      | ANDB A, N <sub>8</sub>                         | A <sub>L</sub> ← A <sub>L</sub> ^N <sub>8</sub>                    | 6                        | —                        | —                        | —                        | 3        | •     |    |    | 24   |
|      | ANDB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> ^[DP]                              | 6                        | —                        | —                        | —                        | 2        | •     |    |    | 24   |
|      | ANDB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> ^±N <sub>8</sub> [USP]             | 7                        | 9                        | —                        | —                        | 3        | •     |    |    | 24   |
|      | ANDB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> ^N <sub>16</sub> [X1]              | 8                        | 10                       | —                        | —                        | 4        | •     |    |    | 24   |
|      | ANDB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> ^N <sub>16</sub> [X2]              | 8                        | 10                       | —                        | —                        | 4        | •     |    |    | 24   |
| 1001 | ANDB rN, A                                     | rN ← rN ^A <sub>L</sub>                                            | 5                        | —                        | 9                        | —                        | 2        | •     |    |    | 25   |
|      | ANDB PSWH, A                                   | PSWH ← PSWH ^A <sub>L</sub>                                        | 5                        | —                        | —                        | —                        | 2        | •     |    |    | 25   |
|      | ANDB PSWL, A                                   | PSWL ← PSWL ^A <sub>L</sub>                                        | 5                        | —                        | —                        | —                        | 2        | •     |    |    | 25   |
|      | ANDB off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> ^A <sub>L</sub>            | 7                        | —                        | 12                       | —                        | 3        | •     |    |    | 25   |
|      | ANDB N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> ^A <sub>L</sub>                    | 7                        | —                        | —                        | —                        | 3        | •     |    |    | 25   |
|      | ANDB [DP], A                                   | [DP] ← [DP] ^A <sub>L</sub>                                        | 7                        | —                        | 11                       | —                        | 2        | •     |    |    | 25   |
|      | ANDB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ^A <sub>L</sub>      | 8                        | —                        | 12                       | —                        | 3        | •     |    |    | 25   |
|      | ANDB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] ^A <sub>L</sub>        | 9                        | —                        | 13                       | —                        | 4        | •     |    |    | 25   |
|      | ANDB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] ^A <sub>L</sub>        | 9                        | —                        | 13                       | —                        | 4        | •     |    |    | 25   |
|      | ANDB rN, off N <sub>8</sub>                    | rN ← rN ^off N <sub>8</sub>                                        | 7                        | —                        | —                        | 14                       | 3        | •     |    |    | 26   |
| 1010 | ANDB PSWH, off N <sub>8</sub>                  | PSWH ← PSWH ^off N <sub>8</sub>                                    | 7                        | 12                       | —                        | —                        | 3        | •     |    |    | 26   |
|      | ANDB PSWL, off N <sub>8</sub>                  | PSWL ← PSWL ^off N <sub>8</sub>                                    | 7                        | 12                       | —                        | —                        | 3        | •     |    |    | 26   |
|      | ANDB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> ^off N <sub>8</sub>        | 9                        | —                        | —                        | 17                       | 4        | •     |    |    | 26   |
|      | ANDB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> ^off N <sub>8</sub>                | 9                        | 14                       | —                        | —                        | 4        | •     |    |    | 26   |
|      | ANDB [DP], off N <sub>8</sub>                  | [DP] ← [DP] ^off N <sub>8</sub>                                    | 9                        | 14                       | 11                       | 13                       | 3        | •     |    |    | 26   |
|      | ANDB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ^off N <sub>8</sub>  | 10                       | 15                       | 12                       | 17                       | 4        | •     |    |    | 26   |
|      | ANDB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>^off N <sub>8</sub> | 11                       | 13                       | 13                       | 18                       | 5        | •     |    |    | 26   |
|      | ANDB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>^off N <sub>8</sub> | 11                       | 13                       | 13                       | 18                       | 5        | •     |    |    | 26   |
|      | ANDB rN, #N <sub>8</sub>                       | rN ← rN ^#N <sub>8</sub>                                           | 6                        | —                        | 11                       | —                        | 3        | •     |    |    | 27   |
|      | ANDB PSWH, #N <sub>8</sub>                     | PSWH ← PSWH ^#N <sub>8</sub>                                       | 6                        | —                        | —                        | —                        | 3        | •     |    |    | 27   |
| 1019 | ANDB PSWL, #N <sub>8</sub>                     | PSWL ← PSWL ^#N <sub>8</sub>                                       | 6                        | —                        | —                        | —                        | 3        | •     |    |    | 27   |
|      | ANDB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> ← off N <sub>8</sub> ^#N <sub>8</sub>           | 6                        | —                        | 14                       | —                        | 4        | •     |    |    | 27   |
|      | ANDB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> ← N <sub>8</sub> ^#N <sub>8</sub>                   | 8                        | —                        | —                        | —                        | 4        | •     |    |    | 27   |
|      | ANDB [DP], #N <sub>8</sub>                     | [DP] ← [DP] ^#N <sub>8</sub>                                       | 8                        | —                        | 13                       | —                        | 3        | •     |    |    | 27   |
|      | ANDB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ^#N <sub>8</sub>     | 9                        | —                        | 14                       | —                        | 4        | •     |    |    | 27   |
|      | ANDB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>^#N <sub>8</sub>    | 10                       | —                        | 15                       | —                        | 5        | •     |    |    | 27   |
|      | ANDB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>^#N <sub>8</sub>    | 10                       | —                        | 15                       | —                        | 5        | •     |    |    | 27   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-24. Logical Calculation Instructions (3)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                    | Operation                                                          | Int <sup>*1</sup> | Int <sup>*1</sup> | Ext <sup>*1</sup> | Ext <sup>*1</sup> | Byte no. | Flags |    |    |    | Page |
|------|----------------------------------------------|--------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|----------|-------|----|----|----|------|
|      |                                              |                                                                    | Int <sup>*2</sup> | Ext <sup>*2</sup> | Int <sup>*2</sup> | Ext <sup>*2</sup> |          | ZF    | CF | HC | DD |      |
| 1028 | OR A, #N <sub>16</sub>                       | A ← A VN <sub>16</sub>                                             | 6                 | —                 |                   |                   | 3        | •     |    |    |    | 104  |
|      | OR A, #rN                                    | A ← A V#rN                                                         | 3                 | 7                 |                   |                   | 1        | •     |    |    |    | 104  |
|      | OR A, DP                                     | A ← A VDP                                                          | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, X1                                     | A ← A VX1                                                          | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, X2                                     | A ← A VX2                                                          | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, USP                                    | A ← A VUSP                                                         | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, SSP                                    | A ← A VSSP                                                         | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, LRB                                    | A ← A VL RB                                                        | 4                 | —                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, off N <sub>8</sub>                     | A ← A V off N <sub>8</sub>                                         | 4                 | 9                 |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, N <sub>8</sub>                         | A ← A VN <sub>8</sub>                                              | 6                 | —                 |                   |                   | 3        | •     |    |    |    | 104  |
|      | OR A, [DP]                                   | A ← A V[DP]                                                        | 6                 | 10                |                   |                   | 2        | •     |    |    |    | 104  |
|      | OR A, ±N <sub>8</sub> [USP]                  | A ← A V±N <sub>8</sub> [USP]                                       | 7                 | 11                |                   |                   | 3        | •     |    |    |    | 104  |
| 1042 | OR erN, A                                    | erN ← erN VA                                                       | 5                 | —                 | 13                |                   | 2        | •     |    |    |    | 105  |
|      | OR DP, A                                     | DP ← DP VA                                                         | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR X1, A                                     | X1 ← X1 VA                                                         | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR X2, A                                     | X2 ← X2 VA                                                         | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR USP, A                                    | USP ← USP VA                                                       | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR SSP, A                                    | SSP ← SSP VA                                                       | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR LRB, A                                    | LRB ← LRB VA                                                       | 5                 | —                 | —                 |                   | 2        | •     |    |    |    | 105  |
|      | OR off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> VA                         | 7                 | —                 | 13                |                   | 3        | •     |    |    |    | 105  |
|      | OR N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> VA                                 | 7                 | —                 | —                 |                   | 3        | •     |    |    |    | 105  |
|      | OR [DP], A                                   | [DP] ← [DP] VA                                                     | 7                 | —                 | 15                |                   | 2        | •     |    |    |    | 105  |
|      | OR ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] VA                   | 8                 | —                 | 13                |                   | 3        | •     |    |    |    | 105  |
| 1055 | OR erN, off N <sub>8</sub>                   | erN ← erN V off N <sub>8</sub>                                     | 7                 | —                 | —                 | 20                | 3        | •     |    |    |    | 106  |
|      | OR DP, off N <sub>8</sub>                    | DP ← DP V off N <sub>8</sub>                                       | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR X1, off N <sub>8</sub>                    | X1 ← X1 V off N <sub>8</sub>                                       | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR X2, off N <sub>8</sub>                    | X2 ← X2 V off N <sub>8</sub>                                       | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR USP, off N <sub>8</sub>                   | USP ← USP V off N <sub>8</sub>                                     | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR SSP, off N <sub>8</sub>                   | SSP ← SSP V off N <sub>8</sub>                                     | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR LRB, off N <sub>8</sub>                   | LRB ← LRB V off N <sub>8</sub>                                     | 7                 | 13                | —                 | —                 | 3        | •     |    |    |    | 106  |
|      | OR off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> V off N <sub>8</sub>       | 9                 | —                 | —                 | 23                | 4        | •     |    |    |    | 106  |
|      | OR N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> V off N <sub>8</sub>               | 9                 | 18                | —                 | —                 | 4        | •     |    |    |    | 106  |
|      | OR [DP], off N <sub>8</sub>                  | [DP] ← [DP] V off N <sub>8</sub>                                   | 9                 | 18                | 13                | 22                | 3        | •     |    |    |    | 106  |
|      | OR ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] V off N <sub>8</sub> | 10                | 19                | 14                | 23                | 4        | •     |    |    |    | 106  |
| 1068 | OR erN, #N <sub>16</sub>                     | erN ← erN V #N <sub>16</sub>                                       | 8                 | —                 | 17                |                   | 4        | •     |    |    |    | 107  |
|      | OR DP, #N <sub>16</sub>                      | DP ← DP V #N <sub>16</sub>                                         | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR X1, #N <sub>16</sub>                      | X1 ← X1 V #N <sub>16</sub>                                         | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR X2, #N <sub>16</sub>                      | X2 ← X2 V #N <sub>16</sub>                                         | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR USP, #N <sub>16</sub>                     | USP ← USP V #N <sub>16</sub>                                       | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR SSP, #N <sub>16</sub>                     | SSP ← SSP V #N <sub>16</sub>                                       | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR LRB, #N <sub>16</sub>                     | LRB ← LRB V #N <sub>16</sub>                                       | 8                 | —                 | —                 |                   | 4        | •     |    |    |    | 107  |
|      | OR off N <sub>8</sub> , #N <sub>16</sub>     | off N <sub>8</sub> ← off N <sub>8</sub> V #N <sub>16</sub>         | 10                | —                 | 20                |                   | 5        | •     |    |    |    | 107  |
|      | OR N <sub>8</sub> , #N <sub>16</sub>         | N <sub>8</sub> ← N <sub>8</sub> V #N <sub>16</sub>                 | 10                | —                 | —                 |                   | 5        | •     |    |    |    | 107  |
|      | OR [DP], #N <sub>16</sub>                    | [DP] ← [DP] V #N <sub>16</sub>                                     | 10                | —                 | 19                |                   | 4        | •     |    |    |    | 107  |
|      | OR ±N <sub>8</sub> [USP], #N <sub>16</sub>   | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] V #N <sub>16</sub>   | 11                | —                 | 20                |                   | 5        | •     |    |    |    | 107  |

## **Chapter 3 Details of Instructions**

---

**TABLE 3-25. Logical Calculation Instructions (4)**

- \*1 - the first operand
- \*2 - the second operand

| No.  | Mnemonics                                     | Operation                                                          | Int <sup>1</sup> | Int <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Byte no. | Flags |    |    | Page |
|------|-----------------------------------------------|--------------------------------------------------------------------|------------------|------------------|------------------|------------------|----------|-------|----|----|------|
|      |                                               |                                                                    | Int <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> |          | ZF    | CF | HC |      |
| 1079 | OR N <sub>1g</sub> [X1], #N <sub>1g</sub>     | N <sub>1g</sub> [X1] ← N <sub>1g</sub> [X1]<br>∨ #N <sub>1g</sub>  | 12               | —                | 21               | —                | 6        | •     | •  | •  | 107  |
|      | OR N <sub>1g</sub> [X2], #N <sub>1g</sub>     | N <sub>1g</sub> [X2] ← N <sub>1g</sub> [X2]<br>∨ #N <sub>1g</sub>  | 12               | —                | 21               | —                | 6        | •     | •  | •  | 107  |
| 1081 | ORB A, #N <sub>g</sub>                        | A <sub>L</sub> ← A <sub>L</sub> ∨ #N <sub>g</sub>                  | 4                | —                | —                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, rN                                     | A <sub>L</sub> ← A <sub>L</sub> VN                                 | 3                | —                | 5                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> VPSWH                              | 4                | —                | —                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> VPSWL                              | 4                | —                | —                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, off N <sub>g</sub>                     | A <sub>L</sub> ← A <sub>L</sub> Voff N <sub>g</sub>                | 4                | —                | 7                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, N <sub>g</sub>                         | A <sub>L</sub> ← A <sub>L</sub> VN <sub>g</sub>                    | 5                | —                | —                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> V[DP]                              | 6                | —                | —                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, ±N <sub>g</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> V±N <sub>g</sub> [USP]             | 7                | —                | 9                | —                | —        | •     | •  | •  | 108  |
|      | ORB A, N <sub>1g</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> VN <sub>1g</sub> [X1]              | 8                | —                | 10               | —                | —        | •     | •  | •  | 108  |
|      | ORB A, N <sub>1g</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> VN <sub>1g</sub> [X2]              | 8                | —                | 10               | —                | —        | •     | •  | •  | 108  |
| 1091 | ORB rN, A                                     | rN ← rN VA <sub>L</sub>                                            | 5                | —                | 9                | —                | 2        | •     | •  | •  | 109  |
|      | ORB PSWH, A                                   | PSWH ← PSWH VA <sub>L</sub>                                        | 5                | —                | —                | —                | 2        | •     | •  | •  | 109  |
|      | ORB PSWL, A                                   | PSWL ← PSWL VA <sub>L</sub>                                        | 5                | —                | —                | —                | 2        | •     | •  | •  | 109  |
|      | ORB off N <sub>g</sub> , A                    | off N <sub>g</sub> ← off N <sub>g</sub> VA <sub>L</sub>            | 7                | —                | 12               | —                | 3        | •     | •  | •  | 109  |
|      | ORB N <sub>g</sub> , A                        | N <sub>g</sub> ← N <sub>g</sub> VA <sub>L</sub>                    | 7                | —                | —                | —                | 3        | •     | •  | •  | 109  |
|      | ORB [DP], A                                   | [DP] ← [DP] VA <sub>L</sub>                                        | 7                | —                | 11               | —                | 2        | •     | •  | •  | 109  |
|      | ORB ±N <sub>g</sub> [USP], A                  | ±N <sub>g</sub> [USP] ←                                            | 8                | —                | 12               | —                | 3        | •     | •  | •  | 109  |
|      |                                               | ±N <sub>g</sub> [USP] VA <sub>L</sub>                              | —                | —                | —                | —                | —        | •     | •  | •  | 109  |
|      | ORB N <sub>1g</sub> [X1], A                   | N <sub>1g</sub> [X1] ← N <sub>1g</sub> [X1] VA <sub>L</sub>        | 9                | —                | 13               | —                | 4        | •     | •  | •  | 109  |
|      | ORB N <sub>1g</sub> [X2], A                   | N <sub>1g</sub> [X2] ← N <sub>1g</sub> [X2] VA <sub>L</sub>        | 9                | —                | 13               | —                | 4        | •     | •  | •  | 109  |
| 1100 | ORB rN, off N <sub>g</sub>                    | rN ← rN Voff N <sub>g</sub>                                        | 7                | —                | —                | —                | 14       | 3     | •  | •  | 110  |
|      | ORB PSWH, off N <sub>g</sub>                  | PSWH ← PSWH Voff N <sub>g</sub>                                    | 7                | —                | 12               | —                | —        | 3     | •  | •  | 110  |
|      | ORB PSWL, off N <sub>g</sub>                  | PSWL ← PSWL Voff N <sub>g</sub>                                    | 7                | —                | 12               | —                | —        | 3     | •  | •  | 110  |
|      | ORB off N <sub>g</sub> , off N <sub>g</sub>   | off N <sub>g</sub> ←                                               | 9                | —                | —                | —                | 17       | 4     | •  | •  | 110  |
|      | ORB N <sub>g</sub> , off N <sub>g</sub>       | N <sub>g</sub> ← N <sub>g</sub> Voff N <sub>g</sub>                | 9                | —                | 14               | —                | —        | 4     | •  | •  | 110  |
|      | ORB [DP], off N <sub>g</sub>                  | [DP] ← [DP] Voff N <sub>g</sub>                                    | 9                | —                | 14               | —                | 13       | 3     | •  | •  | 110  |
|      | ORB ±N <sub>g</sub> [USP], off N <sub>g</sub> | ±N <sub>g</sub> [USP] ←                                            | 10               | —                | 15               | —                | 12       | 17    | 4  | •  | 110  |
|      |                                               | ±N <sub>g</sub> [USP] Voff N <sub>g</sub>                          | —                | —                | —                | —                | —        | —     | •  | •  | 110  |
|      | ORB N <sub>1g</sub> [X1], off N <sub>g</sub>  | N <sub>1g</sub> [X1] ← N <sub>1g</sub> [X1]<br>Voff N <sub>g</sub> | 11               | —                | 13               | —                | 16       | 5     | •  | •  | 110  |
|      | ORB N <sub>1g</sub> [X2], off N <sub>g</sub>  | N <sub>1g</sub> [X2] ← N <sub>1g</sub> [X2]<br>Voff N <sub>g</sub> | 11               | —                | 13               | —                | 16       | 5     | •  | •  | 110  |
| 1109 | ORB rN, #N <sub>g</sub>                       | rN ← rN V#N <sub>g</sub>                                           | 5                | —                | 9                | —                | 2        | •     | •  | •  | 111  |
|      | ORB PSWH, #N <sub>g</sub>                     | PSWH ← PSWH V#N <sub>g</sub>                                       | 5                | —                | —                | —                | 2        | •     | •  | •  | 111  |
|      | ORB PSWL, #N <sub>g</sub>                     | PSWL ← PSWL V#N <sub>g</sub>                                       | 5                | —                | —                | —                | 2        | •     | •  | •  | 111  |
|      | ORB off N <sub>g</sub> , #N <sub>g</sub>      | off N <sub>g</sub> ←                                               | 7                | —                | 12               | —                | 3        | •     | •  | •  | 111  |
|      | ORB N <sub>g</sub> , #N <sub>g</sub>          | N <sub>g</sub> ← N <sub>g</sub> V#N <sub>g</sub>                   | 7                | —                | —                | —                | 3        | •     | •  | •  | 111  |
|      | ORB [DP], #N <sub>g</sub>                     | [DP] ← [DP] V#N <sub>g</sub>                                       | 7                | —                | 11               | —                | 2        | •     | •  | •  | 111  |
|      | ORB ±N <sub>g</sub> [USP], #N <sub>g</sub>    | ±N <sub>g</sub> [USP] ←                                            | 8                | —                | 13               | —                | 3        | •     | •  | •  | 111  |
|      |                                               | ±N <sub>g</sub> [USP] V#N <sub>g</sub>                             | —                | —                | —                | —                | —        | •     | •  | •  | 111  |
|      | ORB N <sub>1g</sub> [X1], #N <sub>g</sub>     | N <sub>1g</sub> [X1] ← N <sub>1g</sub> [X1]<br>V#N <sub>g</sub>    | 9                | —                | 13               | —                | 4        | •     | •  | •  | 111  |
|      | ORB N <sub>1g</sub> [X2], #N <sub>g</sub>     | N <sub>1g</sub> [X2] ← N <sub>1g</sub> [X2]<br>V#N <sub>g</sub>    | 9                | —                | 13               | —                | 4        | •     | •  | •  | 111  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-26. Logical Calculation Instructions (5)**

\*1 - the first operand

\*2 - the second operand

| No.  | Mnemonics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Int *1                                                                           | Int *1                                                                                           | Ext *1                                                                                                                                                                      | Ext *1                                                                            | Byte no.                                                                                         | Flags                                                                                            |                                                                                                                            |                                                                                                       |    | Page |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----|------|
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Int *2                                                                           | Ext *2                                                                                           | Int *2                                                                                                                                                                      | Ext *2                                                                            |                                                                                                  | ZF                                                                                               | CF                                                                                                                         | HC                                                                                                    | DD |      |
| 1118 | XOR A, #N <sub>16</sub><br>XOR A, #H<br>XOR A, DP<br>XOR A, X1<br>XOR A, X2<br>XOR A, USP<br>XOR A, SSP<br>XOR A, LRB<br>XOR A, off N <sub>8</sub><br>XOR A, N <sub>8</sub><br>XOR A, [DP]<br>XOR A, ±N <sub>8</sub> [USP]<br>XOR A, N <sub>16</sub> [X1]<br>XOR A, N <sub>16</sub> [X2]                                                                                                                                                                                                         | A ← A ∨ N <sub>16</sub><br>A ← A ∨ #H<br>A ← A ∨ DP<br>A ← A ∨ X1<br>A ← A ∨ X2<br>A ← A ∨ USP<br>A ← A ∨ SSP<br>A ← A ∨ LRB<br>A ← A ∨ off N <sub>8</sub><br>A ← A ∨ N <sub>8</sub><br>A ← A ∨ [DP]<br>A ← A ∨ ±N <sub>8</sub> [USP]<br>A ← A ∨ N <sub>16</sub> [X1]<br>A ← A ∨ N <sub>16</sub> [X2]                                                                                                                                                                                                                                                                                                            | 6<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8               | —<br>8<br>—<br>—<br>—<br>—<br>—<br>—<br>8<br>—<br>10<br>11<br>12<br>12                           | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—                                                                                                     | —<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4                | 3<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4                               | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                          | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                                                    | 172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172<br>172 |    |      |
| 1132 | XOR #N, A<br>XOR DP, A<br>XOR X1, A<br>XOR X2, A<br>XOR USP, A<br>XOR SSP, A<br>XOR LRB, A<br>XOR off N <sub>8</sub> , A<br>XOR N <sub>8</sub> , A<br>XOR [DP], A<br>XOR ±N <sub>8</sub> [USP], A<br>XOR N <sub>16</sub> [X1], A<br>XOR N <sub>16</sub> [X2], A                                                                                                                                                                                                                                  | #N ← #N ∨ A<br>DP ← DP ∨ A<br>X1 ← X1 ∨ A<br>X2 ← X2 ∨ A<br>USP ← USP ∨ A<br>SSP ← SSP ∨ A<br>LRB ← LRB ∨ A<br>off N <sub>8</sub> ← off N <sub>8</sub> ∨ A<br>N <sub>8</sub> ← N <sub>8</sub> ∨ A<br>[DP] ← [DP] ∨ A<br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ A<br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] ∨ A<br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] ∨ A                                                                                                                                                                                                                                  | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>7<br>7<br>7<br>8<br>9<br>9                    | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>13<br>15<br>13                                 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>2<br>2<br>3<br>3<br>2<br>3                                                                                                | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>4                                    | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                                                   | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                                                   | 173<br>173<br>173<br>173<br>173<br>173<br>173<br>173<br>173<br>173                                                         |                                                                                                       |    |      |
| 1145 | XOR #N, off N <sub>8</sub><br>XOR DP, off N <sub>8</sub><br>XOR X1, off N <sub>8</sub><br>XOR X2, off N <sub>8</sub><br>XOR USP, off N <sub>8</sub><br>XOR SSP, off N <sub>8</sub><br>XOR LRB, off N <sub>8</sub><br>XOR off N <sub>8</sub> , off N <sub>8</sub><br><br>XOR N <sub>8</sub> , off N <sub>8</sub><br>XOR [DP], off N <sub>8</sub><br>XOR ±N <sub>8</sub> [USP], off N <sub>8</sub><br>XOR N <sub>16</sub> [X1], off N <sub>8</sub><br>XOR N <sub>16</sub> [X2], off N <sub>8</sub> | #N ← #N ∨ off N <sub>8</sub><br>DP ← DP ∨ off N <sub>8</sub><br>X1 ← X1 ∨ off N <sub>8</sub><br>X2 ← X2 ∨ off N <sub>8</sub><br>USP ← USP ∨ off N <sub>8</sub><br>SSP ← SSP ∨ off N <sub>8</sub><br>LRB ← LRB ∨ off N <sub>8</sub><br>off N <sub>8</sub> ← off N <sub>8</sub> ∨ off N <sub>8</sub><br><br>N <sub>8</sub> ← N <sub>8</sub> ∨ off N <sub>8</sub><br>[DP] ← [DP] ∨ off N <sub>8</sub><br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ off N <sub>8</sub><br>N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] ∨ off N <sub>8</sub><br>N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] ∨ off N <sub>8</sub> | 7<br>7<br>7<br>7<br>7<br>7<br>7<br>9<br>9<br>9<br>10<br>9<br>9<br>10<br>11<br>11 | —<br>13<br>13<br>13<br>13<br>13<br>13<br>—<br>18<br>18<br>13<br>13<br>13<br>20<br>15<br>15<br>20 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>20<br>22<br>23<br>23<br>23<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>5<br>5 | 3<br>3<br>3<br>3<br>3<br>3<br>3<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>5<br>5<br>5 | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· | 174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174<br>174 |                                                                                                       |    |      |
| 1158 | XOR #N, #N <sub>16</sub><br>XOR DP, #N <sub>16</sub><br>XOR X1, #N <sub>16</sub><br>XOR X2, #N <sub>16</sub><br>XOR USP, #N <sub>16</sub><br>XOR SSP, #N <sub>16</sub><br>XOR LRB, #N <sub>16</sub><br>XOR off N <sub>8</sub> , #N <sub>16</sub><br><br>XOR N <sub>8</sub> , #N <sub>16</sub><br>XOR [DP], #N <sub>16</sub><br>XOR ±N <sub>8</sub> [USP], #N <sub>16</sub>                                                                                                                       | #N ← #N ∨ #N <sub>16</sub><br>DP ← DP ∨ #N <sub>16</sub><br>X1 ← X1 ∨ #N <sub>16</sub><br>X2 ← X2 ∨ #N <sub>16</sub><br>USP ← USP ∨ #N <sub>16</sub><br>SSP ← SSP ∨ #N <sub>16</sub><br>LRB ← LRB ∨ #N <sub>16</sub><br>off N <sub>8</sub> ← off N <sub>8</sub> ∨ #N <sub>16</sub><br><br>N <sub>8</sub> ← N <sub>8</sub> ∨ #N <sub>16</sub><br>[DP] ← [DP] ∨ #N <sub>16</sub><br>±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ #N <sub>16</sub>                                                                                                                                                               | 6<br>8<br>8<br>8<br>8<br>8<br>8<br>10<br>10<br>10<br>10<br>10<br>10<br>11        | —<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>—                               | 17<br>—<br>—<br>—<br>—<br>—<br>—<br>20<br>—<br>19<br>20                                                                                                                     | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>5<br>5<br>4<br>5                               | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                                    | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·                                    | 175<br>175<br>175<br>175<br>175<br>175<br>175<br>175<br>175<br>175<br>175<br>175<br>175                                    |                                                                                                       |    |      |

## **Chapter 3 Details of Instructions**

**TABLE 3-27. Logical Calculation Instructions (6)**

| No.  | Mnemonics                                      | Operation                                                           | int '1 | int '1 | Ext '1 | Ext '1 | Byte no. | Flags |    |    |    | Page |
|------|------------------------------------------------|---------------------------------------------------------------------|--------|--------|--------|--------|----------|-------|----|----|----|------|
|      |                                                |                                                                     | int '2 | Ext '2 | int '2 | Ext '2 |          | ZF    | CF | HC | DD |      |
| 1169 | XOR N <sub>16</sub> [X1], #N <sub>16</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>∨ #N <sub>16</sub>   | 12     | —      | 21     | —      | 6        | *     |    |    |    | 175  |
|      | XOR N <sub>16</sub> [X2], #N <sub>16</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>∨ #N <sub>16</sub>   | 12     | —      | 21     | —      |          | *     |    |    |    | 175  |
| 1171 | XORB A, #N <sub>8</sub>                        | A <sub>L</sub> ← A <sub>L</sub> ∨ #N <sub>8</sub>                   | 4      | —      | —      | —      | —        | *     |    |    |    | 176  |
|      | XORB A, #N                                     | A <sub>L</sub> ← A <sub>L</sub> ∨ #N                                | 4      | —      | 6      | —      |          | *     |    |    |    | 176  |
|      | XORB A, PSWH                                   | A <sub>L</sub> ← A <sub>L</sub> ∨ PSWH                              | 4      | —      | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, PSWL                                   | A <sub>L</sub> ← A <sub>L</sub> ∨ PSWL                              | 4      | —      | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, off N <sub>8</sub>                     | A <sub>L</sub> ← A <sub>L</sub> ∨ off N <sub>8</sub>                | 4      | —      | 7      | —      |          | *     |    |    |    | 176  |
|      | XORB A, N <sub>8</sub>                         | A <sub>L</sub> ← A <sub>L</sub> ∨ N <sub>8</sub>                    | 6      | —      | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, [DP]                                   | A <sub>L</sub> ← A <sub>L</sub> ∨ [DP]                              | 6      | —      | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> ← A <sub>L</sub> ∨ ±N <sub>8</sub> [USP]             | 7      | 9      | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> ← A <sub>L</sub> ∨ N <sub>16</sub> [X1]              | 8      | 10     | —      | —      |          | *     |    |    |    | 176  |
|      | XORB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> ← A <sub>L</sub> ∨ N <sub>16</sub> [X2]              | 8      | 10     | —      | —      |          | *     |    |    |    | 176  |
| 1181 | XORB rN, A                                     | rN ← rN ∨ A <sub>L</sub>                                            | 5      | —      | 9      | —      | 2        | *     |    |    |    | 177  |
|      | XORB PSWH, A                                   | PSWH ← PSWH ∨ A <sub>L</sub>                                        | 5      | —      | —      | —      |          | *     |    |    |    | 177  |
|      | XORB PSWL, A                                   | PSWL ← PSWL ∨ A <sub>L</sub>                                        | 5      | —      | —      | —      |          | *     |    |    |    | 177  |
|      | XORB off N <sub>8</sub> , A                    | off N <sub>8</sub> ← off N <sub>8</sub> ∨ A <sub>L</sub>            | 7      | —      | 12     | —      |          | *     |    |    |    | 177  |
|      | XORB N <sub>8</sub> , A                        | N <sub>8</sub> ← N <sub>8</sub> ∨ A <sub>L</sub>                    | 7      | —      | —      | —      |          | *     |    |    |    | 177  |
|      | XORB [DP], A                                   | [DP] ← [DP] ∨ A <sub>L</sub>                                        | 7      | —      | 11     | —      |          | *     |    |    |    | 177  |
|      | XORB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ A <sub>L</sub>      | 8      | 12     | —      | —      |          | *     |    |    |    | 177  |
|      | XORB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1] ∨ A <sub>L</sub>        | 9      | —      | 13     | —      |          | *     |    |    |    | 177  |
|      | XORB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2] ∨ A <sub>L</sub>        | 9      | —      | 13     | —      |          | *     |    |    |    | 177  |
|      | XORB rN, off N <sub>8</sub>                    | rN ← rN ∨ off N <sub>8</sub>                                        | 7      | —      | —      | —      |          | *     |    |    |    | 178  |
| 1190 | XORB PSWH, off N <sub>8</sub>                  | PSWH ← PSWH ∨ off N <sub>8</sub>                                    | 7      | 12     | —      | —      | 3        | *     |    |    |    | 178  |
|      | XORB PSWL, off N <sub>8</sub>                  | PSWL ← PSWL ∨ off N <sub>8</sub>                                    | 7      | 12     | —      | —      |          | *     |    |    |    | 178  |
|      | XORB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> ← off N <sub>8</sub> ∨ off N <sub>8</sub>        | 8      | —      | —      | —      |          | *     |    |    |    | 178  |
|      | XORB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> ← N <sub>8</sub> ∨ off N <sub>8</sub>                | 9      | 14     | —      | —      |          | *     |    |    |    | 178  |
|      | XORB [DP], off N <sub>8</sub>                  | [DP] ← [DP] ∨ off N <sub>8</sub>                                    | 9      | 14     | 11     | 13     |          | *     |    |    |    | 178  |
|      | XORB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ off N <sub>8</sub>  | 10     | 15     | 12     | 17     |          | *     |    |    |    | 178  |
|      | XORB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>∨ off N <sub>8</sub> | 11     | 13     | 13     | 16     |          | *     |    |    |    | 178  |
|      | XORB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>∨ off N <sub>8</sub> | 11     | 13     | 13     | 16     |          | *     |    |    |    | 178  |
|      | XORB rN, #N <sub>8</sub>                       | rN ← rN ∨ #N <sub>8</sub>                                           | 6      | —      | 11     | —      | 3        | *     |    |    |    | 179  |
|      | XORB PSWH, #N <sub>8</sub>                     | PSWH ← PSWH ∨ #N <sub>8</sub>                                       | 6      | —      | —      | —      |          | *     |    |    |    | 179  |
| 1199 | XORB PSWL, #N <sub>8</sub>                     | PSWL ← PSWL ∨ #N <sub>8</sub>                                       | 6      | —      | —      | —      |          | *     |    |    |    | 179  |
|      | XORB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> ← #N <sub>8</sub>                                | 8      | —      | 14     | —      |          | *     |    |    |    | 179  |
|      | XORB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> ← N <sub>8</sub> ∨ #N <sub>8</sub>                   | 8      | —      | —      | —      |          | *     |    |    |    | 179  |
|      | XORB [DP], #N <sub>8</sub>                     | [DP] ← [DP] ∨ #N <sub>8</sub>                                       | 8      | —      | 13     | —      |          | *     |    |    |    | 179  |
|      | XORB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] ← ±N <sub>8</sub> [USP] ∨ #N <sub>8</sub>     | 9      | —      | 14     | —      |          | *     |    |    |    | 179  |
|      | XORB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] ← N <sub>16</sub> [X1]<br>∨ #N <sub>8</sub>    | 10     | —      | 15     | —      |          | *     |    |    |    | 179  |
|      | XORB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] ← N <sub>16</sub> [X2]<br>∨ #N <sub>8</sub>    | 10     | —      | 15     | —      |          | *     |    |    |    | 179  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-28. Comparison Instructions (1)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                     | Operation                                  | Int <sup>*1</sup> | Int <sup>*1</sup> | Ext <sup>*1</sup> | Ext <sup>*1</sup> | Byte no. | Flags |    |    |    | Page |
|------|-----------------------------------------------|--------------------------------------------|-------------------|-------------------|-------------------|-------------------|----------|-------|----|----|----|------|
|      |                                               |                                            | Int <sup>*2</sup> | Ext <sup>*2</sup> | Int <sup>*2</sup> | Ext <sup>*2</sup> |          | ZF    | CF | HC | DD |      |
| 1288 | CMP A, #N <sub>16</sub>                       | A - #N <sub>16</sub>                       | 6                 | —                 | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP A, #N                                     | A - #N                                     | 3                 | 7                 | —                 | —                 | 1        | •     | •  | •  | •  | 35   |
|      | CMP A, DP                                     | A - DP                                     | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, X1                                     | A - X1                                     | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, X2                                     | A - X2                                     | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, USP                                    | A - USP                                    | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, SSP                                    | A - SSP                                    | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, LRB                                    | A - LRB                                    | 4                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, off N <sub>8</sub>                     | A - off N <sub>8</sub>                     | 4                 | 9                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, N <sub>8</sub>                         | A - N <sub>8</sub>                         | 6                 | —                 | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP A, [DP]                                   | A - [DP]                                   | 6                 | 10                | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP A, ±N <sub>8</sub> [USP]                  | A - ±N <sub>8</sub> [USP]                  | 7                 | 11                | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP A, N <sub>16</sub> [X1]                   | A - N <sub>16</sub> [X1]                   | 8                 | 12                | —                 | —                 | 4        | •     | •  | •  | •  | 35   |
|      | CMP A, N <sub>16</sub> [X2]                   | A - N <sub>16</sub> [X2]                   | 8                 | 12                | —                 | —                 | 4        | •     | •  | •  | •  | 35   |
| 1222 | CMP #N, A                                     | #N - A                                     | 5                 | —                 | 13                | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP DP, A                                     | DP - A                                     | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP X1, A                                     | X1 - A                                     | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP X2, A                                     | X2 - A                                     | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP USP, A                                    | USP - A                                    | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP SSP, A                                    | SSP - A                                    | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP LRB, A                                    | LRB - A                                    | 5                 | —                 | —                 | —                 | 2        | •     | •  | •  | •  | 35   |
|      | CMP off N <sub>8</sub> , A                    | off N <sub>8</sub> - A                     | 7                 | —                 | 13                | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP N <sub>8</sub> , A                        | N <sub>8</sub> - A                         | 7                 | —                 | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP [DP], A                                   | [DP] - A                                   | 7                 | —                 | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] - A                  | 8                 | 13                | —                 | —                 | 3        | •     | •  | •  | •  | 35   |
|      | CMP N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] - A                   | 9                 | —                 | 17                | —                 | 4        | •     | •  | •  | •  | 35   |
|      | CMP N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] - A                   | 9                 | —                 | 17                | —                 | 4        | •     | •  | •  | •  | 35   |
| 1235 | CMP #N, off N <sub>8</sub>                    | #N - off N <sub>8</sub>                    | 7                 | —                 | —                 | —                 | 20       | 3     | •  | •  | •  | 37   |
|      | CMP DP, off N <sub>8</sub>                    | DP - off N <sub>8</sub>                    | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP X1, off N <sub>8</sub>                    | X1 - off N <sub>8</sub>                    | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP X2, off N <sub>8</sub>                    | X2 - off N <sub>8</sub>                    | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP USP, off N <sub>8</sub>                   | USP - off N <sub>8</sub>                   | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP SSP, off N <sub>8</sub>                   | SSP - off N <sub>8</sub>                   | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP LRB, off N <sub>8</sub>                   | LRB - off N <sub>8</sub>                   | 7                 | 13                | —                 | —                 | —        | 3     | •  | •  | •  | 37   |
|      | CMP off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> - off N <sub>8</sub>    | 9                 | —                 | —                 | —                 | 23       | 4     | •  | •  | •  | 37   |
|      | CMP N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> - off N <sub>8</sub>        | 9                 | 18                | —                 | —                 | —        | 4     | •  | •  | •  | 37   |
|      | CMP [DP], off N <sub>8</sub>                  | [DP] - off N <sub>8</sub>                  | 9                 | 18                | 13                | 22                | 3        | •     | •  | •  | •  | 37   |
|      | CMP ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] - off N <sub>8</sub> | 10                | 19                | 14                | 23                | 4        | •     | •  | •  | •  | 37   |
|      | CMP N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] - off N <sub>8</sub>  | 11                | 20                | 15                | 24                | 5        | •     | •  | •  | •  | 37   |
|      | CMP N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] - off N <sub>8</sub>  | 11                | 20                | 15                | 24                | 5        | •     | •  | •  | •  | 37   |
| 1248 | CMP #N, #N <sub>16</sub>                      | #N - #N <sub>16</sub>                      | 8                 | —                 | 17                | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP DP, #N <sub>16</sub>                      | DP - #N <sub>16</sub>                      | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP X1, #N <sub>16</sub>                      | X1 - #N <sub>16</sub>                      | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP X2, #N <sub>16</sub>                      | X2 - #N <sub>16</sub>                      | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP USP, #N <sub>16</sub>                     | USP - #N <sub>16</sub>                     | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP SSP, #N <sub>16</sub>                     | SSP - #N <sub>16</sub>                     | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP LRB, #N <sub>16</sub>                     | LRB - #N <sub>16</sub>                     | 8                 | —                 | —                 | —                 | 4        | •     | •  | •  | •  | 39   |
|      | CMP off N <sub>8</sub> , #N <sub>16</sub>     | off N <sub>8</sub> - #N <sub>16</sub>      | 10                | 20                | —                 | —                 | 5        | •     | •  | •  | •  | 39   |
|      | CMP N <sub>8</sub> , #N <sub>16</sub>         | N <sub>8</sub> - #N <sub>16</sub>          | 10                | —                 | —                 | —                 | 5        | •     | •  | •  | •  | 39   |
|      | CMP [DP], #N <sub>16</sub>                    | [DP] - #N <sub>16</sub>                    | 10                | 19                | —                 | —                 | 5        | •     | •  | •  | •  | 39   |
|      | CMP ±N <sub>8</sub> [USP], #N <sub>16</sub>   | ±N <sub>8</sub> [USP] - #N <sub>16</sub>   | 11                | 20                | —                 | —                 | 5        | •     | •  | •  | •  | 39   |
|      | CMP N <sub>16</sub> [X1], #N <sub>16</sub>    | N <sub>16</sub> [X1] - #N <sub>16</sub>    | 12                | 21                | —                 | —                 | 5        | •     | •  | •  | •  | 39   |
|      | CMP N <sub>16</sub> [X2], #N <sub>16</sub>    | N <sub>16</sub> [X2] - #N <sub>16</sub>    | 12                | 21                | —                 | —                 | 5        | •     | •  | •  | •  | 39   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-29. Comparison Instructions (2)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                      | Operation                                  | Int '1 | Int '1 | Ext '1 | Ext '1 | Byte no. | Flags |    |    | Page |
|------|------------------------------------------------|--------------------------------------------|--------|--------|--------|--------|----------|-------|----|----|------|
|      |                                                |                                            | Int '2 | Ext '2 | Int '2 | Ext '2 |          | ZF    | CF | HC |      |
| 1261 | CMPB A, #N <sub>8</sub>                        | A <sub>L</sub> - #N <sub>8</sub>           | 4      | —      |        |        | 2        | •     | •  | •  | 39   |
|      | CMPB A, rN                                     | A <sub>L</sub> - rN                        | 3      | 5      |        |        | 1        | •     | •  | •  | 39   |
|      | CMPB A, PSWH                                   | A <sub>L</sub> - PSWH                      | 4      | —      |        |        | 2        | •     | •  | •  | 39   |
|      | CMPB A, PSWL                                   | A <sub>L</sub> - PSWL                      | 4      | —      |        |        | 2        | •     | •  | •  | 39   |
|      | CMPB A, off N <sub>8</sub>                     | A <sub>L</sub> - off N <sub>8</sub>        | 4      | 7      |        |        | 2        | •     | •  | •  | 39   |
|      | CMPB A, N <sub>8</sub>                         | A <sub>L</sub> - N <sub>8</sub>            | 6      | —      |        |        | 3        | •     | •  | •  | 39   |
|      | CMPB A, [DP]                                   | A <sub>L</sub> - [DP]                      | 6      | —      |        |        | 2        | •     | •  | •  | 39   |
|      | CMPB A, ±N <sub>8</sub> [USP]                  | A <sub>L</sub> - ±N <sub>8</sub> [USP]     | 7      | 9      |        |        | 3        | •     | •  | •  | 39   |
|      | CMPB A, N <sub>16</sub> [X1]                   | A <sub>L</sub> - N <sub>16</sub> [X1]      | 8      | 10     |        |        | 4        | •     | •  | •  | 39   |
|      | CMPB A, N <sub>16</sub> [X2]                   | A <sub>L</sub> - N <sub>16</sub> [X2]      | 8      | 10     |        |        | 4        | •     | •  | •  | 39   |
| 1271 | CMPB rN, A                                     | rN - A <sub>L</sub>                        | 5      | —      | 9      |        | 2        | •     | •  | •  | 40   |
|      | CMPB PSWH, A                                   | PSWH - A <sub>L</sub>                      | 5      | —      | —      |        | 2        | •     | •  | •  | 40   |
|      | CMPB PSWL, A                                   | PSWL - A <sub>L</sub>                      | 5      | —      | —      |        | 2        | •     | •  | •  | 40   |
|      | CMPB off N <sub>8</sub> , A                    | off N <sub>8</sub> - A <sub>L</sub>        | 7      | —      | 12     |        | 3        | •     | •  | •  | 40   |
|      | CMPB N <sub>8</sub> , A                        | N <sub>8</sub> - A <sub>L</sub>            | 7      | —      | —      |        | 3        | •     | •  | •  | 40   |
|      | CMPB [DP], A                                   | [DP] - A <sub>L</sub>                      | 7      | —      | 11     |        | 2        | •     | •  | •  | 40   |
|      | CMPB ±N <sub>8</sub> [USP], A                  | ±N <sub>8</sub> [USP] - A <sub>L</sub>     | 8      | —      | 12     |        | 3        | •     | •  | •  | 40   |
|      | CMPB N <sub>16</sub> [X1], A                   | N <sub>16</sub> [X1] - A <sub>L</sub>      | 9      | —      | 13     |        | 4        | •     | •  | •  | 40   |
|      | CMPB N <sub>16</sub> [X2], A                   | N <sub>16</sub> [X2] - A <sub>L</sub>      | 9      | —      | 13     |        | 4        | •     | •  | •  | 40   |
| 1280 | CMPB rN, off N <sub>8</sub>                    | rN - off N <sub>8</sub>                    | 7      | —      | —      | 14     | 3        | •     | •  | •  | 41   |
|      | CMPB PSWH, off N <sub>8</sub>                  | PSWH-off N <sub>8</sub>                    | 7      | 12     | —      | —      | 3        | •     | •  | •  | 41   |
|      | CMPB PSWL, off N <sub>8</sub>                  | PSWL-off N <sub>8</sub>                    | 7      | 12     | —      | —      | 3        | •     | •  | •  | 41   |
|      | CMPB off N <sub>8</sub> , off N <sub>8</sub>   | off N <sub>8</sub> - off N <sub>8</sub>    | 9      | —      | —      | 17     | 4        | •     | •  | •  | 41   |
|      | CMPB N <sub>8</sub> , off N <sub>8</sub>       | N <sub>8</sub> - off N <sub>8</sub>        | 9      | 14     | —      | —      | 4        | •     | •  | •  | 41   |
|      | CMPB [DP], off N <sub>8</sub>                  | [DP] - off N <sub>8</sub>                  | 9      | 14     | 11     | 13     | 3        | •     | •  | •  | 41   |
|      | CMPB ±N <sub>8</sub> [USP], off N <sub>8</sub> | ±N <sub>8</sub> [USP] - off N <sub>8</sub> | 10     | 15     | 12     | 17     | 4        | •     | •  | •  | 41   |
|      | CMPB N <sub>16</sub> [X1], off N <sub>8</sub>  | N <sub>16</sub> [X1] - off N <sub>8</sub>  | 11     | 13     | 13     | 18     | 5        | •     | •  | •  | 41   |
|      | CMPB N <sub>16</sub> [X2], off N <sub>8</sub>  | N <sub>16</sub> [X2] - off N <sub>8</sub>  | 11     | 13     | 13     | 18     | 5        | •     | •  | •  | 41   |
| 1288 | CMPB rN, #N <sub>8</sub>                       | rN - #N <sub>8</sub>                       | 6      | —      | 11     |        | 3        | •     | •  | •  | 42   |
|      | CMPB PSWH, #N <sub>8</sub>                     | PSWH - #N <sub>8</sub>                     | 6      | —      | —      |        | 3        | •     | •  | •  | 42   |
|      | CMPB PSWL, #N <sub>8</sub>                     | PSWL - #N <sub>8</sub>                     | 6      | —      | —      |        | 3        | •     | •  | •  | 42   |
|      | CMPB off N <sub>8</sub> , #N <sub>8</sub>      | off N <sub>8</sub> - #N <sub>8</sub>       | 8      | —      | 14     |        | 4        | •     | •  | •  | 42   |
|      | CMPB N <sub>8</sub> , #N <sub>8</sub>          | N <sub>8</sub> - #N <sub>8</sub>           | 8      | —      | —      |        | 3        | •     | •  | •  | 42   |
|      | CMPB [DP], #N <sub>8</sub>                     | [DP] - #N <sub>8</sub>                     | 8      | —      | 13     |        | 4        | •     | •  | •  | 42   |
|      | CMPB ±N <sub>8</sub> [USP], #N <sub>8</sub>    | ±N <sub>8</sub> [USP] - #N <sub>8</sub>    | 9      | —      | 14     |        | 5        | •     | •  | •  | 42   |
|      | CMPB N <sub>16</sub> [X1], #N <sub>8</sub>     | N <sub>16</sub> [X1] - #N <sub>8</sub>     | 10     | —      | 15     |        | 5        | •     | •  | •  | 42   |
|      | CMPB N <sub>16</sub> [X2], #N <sub>8</sub>     | N <sub>16</sub> [X2] - #N <sub>8</sub>     | 10     | —      | 15     |        | 5        | •     | •  | •  | 42   |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-30. Decimal Adjust Instructions**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics | Operation                                                                                                                                                                                   | Int <sup>1</sup> | Int <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Byte no. | Flags |    |    |    | Page |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|----------|-------|----|----|----|------|
|      |           |                                                                                                                                                                                             | Int <sup>2</sup> | Ext <sup>2</sup> | Int <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> |          | ZF    | CF | HC | DD |      |
| 1298 | DAA       | IF ( $A_{L3:0} \geq 10$ )<br>OR (HC = 1)<br>THEN $A_L \leftarrow A_L + 6$<br><br>IF ( $A_{L7:4} \geq 10$ )<br>OR (C = 1)<br>THEN<br>$A_{L7:4} \leftarrow A_{L7:4} + 6$                      | 6                |                  |                  |                  |                  |                  | 1        |       | *  | *  |    | 49   |
| 1299 | DAS       | IF ( $A_{L3:0} \geq 10$ )<br>OR (HC = 1)<br>THEN $A_L \leftarrow A_L - 6$<br><br>IF ( $A_{L7:4} \geq 10$ )<br>OR (C = 1)<br>THEN<br>$A_{L7:4} \leftarrow A_{L7:4} - 6$<br>HC $\leftarrow 0$ | 6                |                  |                  |                  |                  |                  | 1        |       | *  | *  |    | 50   |

**TABLE 3-31. Sign Extend Instructions**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics | Operation                                      | Int <sup>1</sup> | Int <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Ext <sup>1</sup> | Byte no. | Flags |    |    |    | Page |
|------|-----------|------------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|----------|-------|----|----|----|------|
|      |           |                                                | Int <sup>2</sup> | Ext <sup>2</sup> | Int <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> | Ext <sup>2</sup> |          | ZF    | CF | HC | DD |      |
| 1300 | EXTNO     | $A_{15:8} \leftarrow A_7$<br>DD $\leftarrow 1$ | 2                |                  |                  |                  |                  |                  | 1        |       |    |    |    | 1 59 |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-32. Bit Operation Instructions (1)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                                                                                                                                                                                    | Operation                                                                                           | Int *1                                             | Int *1                                        | Ext *1                                         | Ext *1                                    | Byte no.                                  | Flags |    |     | Page |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|------------------------------------------------|-------------------------------------------|-------------------------------------------|-------|----|-----|------|
|      |                                                                                                                                                                                                              |                                                                                                     | Int *2                                             | Ext *2                                        | Int *2                                         | Ext *2                                    |                                           | ZF    | CF | IHC |      |
| 1301 | SBR rN<br>SBR PSWH<br>SBR PSWL<br>SBR off N <sub>8</sub><br>SBR N <sub>8</sub><br>SBR [DP]<br>SBR ±N <sub>8</sub> [USP]<br>SBR N <sub>16</sub> [X1]<br>SBR N <sub>16</sub> [X2]                              | IF obj.bit(A <sub>2-0</sub> ) = 0<br>THEN Z ← 1<br>ELSE Z ← 0<br><br>obj.bit(A <sub>2-0</sub> ) ← 1 | 7<br>7<br>7<br>9<br>9<br>9<br>10<br>11<br>11       | —<br>—<br>—<br>16<br>—<br>—<br>16<br>17<br>17 | 13<br>—<br>—<br>2<br>3<br>2<br>3<br>4<br>4     | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 137  |
| 1310 | RBR rN<br>RBR PSWH<br>RBR PSWL<br>RBR off N <sub>8</sub><br>RBR N <sub>8</sub><br>RBR [DP]<br>RBR ±N <sub>8</sub> [USP]<br>RBR N <sub>16</sub> [X1]<br>RBR N <sub>16</sub> [X2]                              | IF obj.bit(A <sub>2-0</sub> ) = 0<br>THEN Z ← 1<br>ELSE Z ← 0<br><br>obj.bit(A <sub>2-0</sub> ) ← 0 | 7<br>7<br>7<br>9<br>9<br>9<br>10<br>11<br>11       | —<br>—<br>—<br>16<br>—<br>—<br>16<br>17<br>17 | 13<br>—<br>—<br>2<br>3<br>2<br>3<br>4<br>4     | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 116  |
| 1319 | TBR rN<br>TBR PSWH<br>TBR PSWL<br>TBR off N <sub>8</sub><br>TBR N <sub>8</sub><br>TBR [DP]<br>TBR ±N <sub>8</sub> [USP]<br>TBR N <sub>16</sub> [X1]<br>TBR N <sub>16</sub> [X2]                              | IF obj.bit(A <sub>2-0</sub> ) = 0<br>THEN Z ← 1<br>ELSE Z ← 0                                       | 4<br>4<br>4<br>6<br>6<br>6<br>7<br>8<br>8          | —<br>—<br>—<br>—<br>—<br>8<br>9<br>9<br>10    | 6<br>—<br>—<br>3<br>3<br>2<br>3<br>4<br>4      | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 167  |
| 1328 | MBR C, rN<br>MBR C, PSWH<br>MBR C, PSWL<br>MBR C, off N <sub>8</sub><br>MBR C, N <sub>8</sub><br>MBR C, [DP]<br>MBR C, ±N <sub>8</sub> [USP]<br>MBR C, N <sub>16</sub> [X1]<br>MBR C, N <sub>16</sub> [X2]   | C ← obj.bit(A <sub>2-0</sub> )                                                                      | 5<br>5<br>5<br>7<br>7<br>7<br>7<br>10<br>10        | —<br>—<br>—<br>—<br>—<br>—<br>9<br>—<br>—     | 7<br>—<br>—<br>10<br>—<br>—<br>9<br>3<br>—     | 2<br>2<br>2<br>3<br>3<br>2<br>2<br>3<br>3 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 80   |
| 1337 | MBR rN, C<br>MBR PSWH, C<br>MBR PSWL, C<br>MBR off N <sub>8</sub> , C<br>MBR N <sub>8</sub> , C<br>MBR [DP], C<br>MBR ±N <sub>8</sub> [USP], C<br>MBR N <sub>16</sub> [X1], C<br>MBR N <sub>16</sub> [X2], C | obj.bit(A <sub>2-0</sub> ) ← C                                                                      | 10<br>10<br>10<br>12<br>12<br>12<br>12<br>13<br>13 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>19<br>19   | 16<br>—<br>—<br>19<br>—<br>—<br>19<br>19<br>19 | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 81   |
| 1346 | SB rN.bit<br>SB PSWH.bit<br>SB PSWL.bit<br>SB off N <sub>8</sub> .bit<br>SB N <sub>8</sub> .bit<br>SB [DP].bit<br>SB ±N <sub>8</sub> [USP].bit<br>SB N <sub>16</sub> [X1].bit<br>SB N <sub>16</sub> [X2].bit | IF obj.bit = 0<br>THEN Z ← 1<br>ELSE Z ← 0<br><br>obj.bit ← 1                                       | 7<br>7<br>7<br>9<br>9<br>9<br>9<br>10<br>11        | —<br>—<br>—<br>16<br>—<br>—<br>15<br>16<br>17 | 13<br>—<br>—<br>2<br>3<br>2<br>3<br>3<br>4     | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>3<br>4 | •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• |       |    |     | 128  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-33. Bit Manipulation Instructions (2)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                                                                                                                                                                                                               | Operation                                                 | Int '1                                             | Int '1                                         | Ext '1                                     | Ext '1                                    | Byte no.                                  | Flags |    |    |    | Page                                                        |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|-------------------------------------------|-------|----|----|----|-------------------------------------------------------------|
|      |                                                                                                                                                                                                                                         |                                                           | Int '2                                             | Ext '2                                         | Int '2                                     | Ext '2                                    |                                           | ZF    | CF | HC | DD |                                                             |
| 1355 | RB rN.bit<br>RB PSWH.bit<br>RB PSWL.bit<br>RB off N <sub>8</sub> .bit<br>RB N <sub>8</sub> .bit<br>RB [DP].bit<br>RB ±N <sub>8</sub> [USP].bit<br>RB N <sub>16</sub> [X1].bit<br>RB N <sub>16</sub> [X2].bit                            | IF obj.bit = 0<br>THEN Z ← 1<br>ELSE Z ← 0<br>obj.bit ← 0 | 7<br>7<br>7<br>9<br>9<br>9<br>10<br>11<br>11       | —<br>—<br>—<br>16<br>—<br>15<br>16<br>17<br>17 | —<br>—<br>—<br>3<br>3<br>2<br>3<br>4<br>4  | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· |       |    |    |    | 115<br>115<br>115<br>115<br>115<br>115<br>115<br>115<br>115 |
| 1364 | MB C, rN.bit<br>MB C, PSWH.bit<br>MB C, PSWL.bit<br>MB C, off N <sub>8</sub> .bit<br>MB C, N <sub>8</sub> .bit<br>MB C, [DP].bit<br>MB C, ±N <sub>8</sub> [USP].bit<br>MB C, N <sub>16</sub> [X1].bit<br>MB C, N <sub>16</sub> [X2].bit | C ← obj.bit                                               | 5<br>5<br>5<br>7<br>7<br>7<br>8<br>9<br>9          | 7<br>—<br>—<br>10<br>—<br>9<br>10<br>9<br>11   | —<br>—<br>—<br>3<br>3<br>2<br>3<br>4<br>4  | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· |       |    |    |    | 28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28          |
| 1373 | MB rN.bit, C<br>MB PSWH.bit, C<br>MB PSWL.bit, C<br>MB off N <sub>8</sub> .bit, C<br>MB N <sub>8</sub> .bit, C<br>MB [DP].bit, C<br>MB ±N <sub>8</sub> [USP].bit, C<br>MB N <sub>16</sub> [X1].bit, C<br>MB N <sub>16</sub> [X2].bit, C | obj.bit ← C                                               | 10<br>10<br>10<br>12<br>12<br>12<br>13<br>14<br>14 | —<br>—<br>—<br>19<br>—<br>18<br>19<br>20<br>20 | 16<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>— | 2<br>2<br>2<br>3<br>3<br>2<br>3<br>4<br>4 | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· |       |    |    |    | 29<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>29          |

**TABLE 3-34. Jump Call Instructions (1)**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics                                                                                                                           | Operation                                                                                                                                                                                | Int '1                                         | Int '1                                           | Ext '1                                          | Ext '1                                         | Byte no.                                       | Flags |    |    |    | Page                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------|-------------------------------------------------|------------------------------------------------|------------------------------------------------|-------|----|----|----|----------------------------------------------------------|
|      |                                                                                                                                     |                                                                                                                                                                                          | Int '2                                         | Ext '2                                           | Int '2                                          | Ext '2                                         |                                                | ZF    | CF | HC | DD |                                                          |
| 1382 | SJ address                                                                                                                          | PC ← address<br>where<br>PC*+128 ≤ address<br>≤ PC*+127<br>PC* = Head address of<br>the instruction after<br>the SJ instruction<br>= (address of first<br>byte of SJ<br>instruction) + 2 | 8                                              | —                                                | —                                               | —                                              | 2                                              |       |    |    |    | 141                                                      |
| 1383 | J address                                                                                                                           | PC ← address<br>(16 bits)                                                                                                                                                                | 7                                              | —                                                | —                                               | —                                              | 3                                              |       |    |    |    | 62                                                       |
| 1384 | J [enN]<br>J [DP]<br>J [X1]<br>J [X2]<br>J [USP]<br>J [SSP]<br>J [LRB]<br>J [off N <sub>8</sub> ]<br>J [N <sub>8</sub> ]<br>J [DPI] | PC ← [enN]<br>PC ← [DP]<br>PC ← [X1]<br>PC ← [X2]<br>PC ← [USP]<br>PC ← [SSP]<br>PC ← [LRB]<br>PC ← [off N <sub>8</sub> ]<br>PC ← [N <sub>8</sub> ]<br>PC ← [DPI]                        | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>8<br>8<br>8 | —<br>—<br>—<br>—<br>—<br>—<br>—<br>13<br>—<br>12 | 10<br>—<br>—<br>—<br>—<br>—<br>—<br>3<br>—<br>2 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>—<br>2 | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· |       |    |    |    | 63<br>63<br>63<br>63<br>63<br>63<br>63<br>63<br>63<br>63 |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-35. Jump Call Instructions (2)**

\*1 - the first operand

\*2 - the second operand

| No.  | Mnemonics                                                                                                | Operation                                                                                                                                                                                                                                                                               | Int '1                         | Int '1                         | Ext '1         | Ext '1 | Ext '2 | Ext '2 | Byte no.                   | Flags |    |    |    | Page                             |
|------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------|----------------|--------|--------|--------|----------------------------|-------|----|----|----|----------------------------------|
|      |                                                                                                          |                                                                                                                                                                                                                                                                                         | Int '2                         | Ext '2                         | Int '2         | Ext '2 | Ext '2 | Ext '2 |                            | ZF    | CF | HC | DD |                                  |
| 1395 | J [ $\pm N_8$ [USP]]<br>J [N <sub>16</sub> [X1]]<br>J [N <sub>16</sub> [X2]]                             | PC $\leftarrow$ [ $\pm N_8$ [USP]]<br>PC $\leftarrow$ [N <sub>16</sub> [X1]]<br>PC $\leftarrow$ [N <sub>16</sub> [X2]]                                                                                                                                                                  | 9<br>10<br>10                  |                                | 13<br>14<br>14 |        |        |        | 3<br>4<br>4                |       |    |    |    | 63<br>63<br>63                   |
| 1397 | JC EQ, address<br>JC NE, address<br>JC LT, address<br>JC LE, address<br>JC GT, address<br>JC GE, address | IF Z = 1<br>THEN PC $\leftarrow$ address<br>IF Z = 0<br>THEN PC $\leftarrow$ address<br>IF C = 1<br>THEN PC $\leftarrow$ address<br>IF Z = 1 or C = 1<br>THEN PC $\leftarrow$ address<br>IF Z = 0 and C = 0<br>THEN PC $\leftarrow$ address<br>IF C = 0<br>THEN PC $\leftarrow$ address | true<br>8<br>8<br>8<br>8<br>8  | false<br>4<br>4<br>4<br>4<br>4 |                |        |        |        | 2<br>2<br>2<br>2<br>2<br>2 |       |    |    |    | 65<br>65<br>65<br>65<br>65<br>65 |
|      |                                                                                                          | where<br>PC* - 128 $\leq$ address<br>$\leq$ PC* + 127<br>PC* = Head address of the instruction after the JC instruction<br>= (address of first byte of JC instruction) + 2                                                                                                              |                                |                                |                |        |        |        |                            |       |    |    |    |                                  |
| 1403 | JBR off N <sub>8</sub> bit, address                                                                      | IF (off N <sub>8</sub> bit = 0)<br>THEN PC $\leftarrow$ address                                                                                                                                                                                                                         | true<br>10                     |                                | false<br>13    |        |        |        | 3                          |       |    |    |    | 64                               |
|      |                                                                                                          | where<br>PC* - 128 $\leq$ address<br>$\leq$ PC* + 127<br>PC* = Head address of the instruction after the JBR instruction<br>= (address of first byte of JBR instruction) + 3                                                                                                            | true<br>6                      |                                | false<br>9     |        |        |        |                            |       |    |    |    |                                  |
| 1404 | JBS off N <sub>8</sub> bit, address                                                                      | IF (off N <sub>8</sub> bit = 1)<br>THEN PC $\leftarrow$ address                                                                                                                                                                                                                         | true<br>10                     |                                | false<br>13    |        |        |        | 3                          |       |    |    |    | 65                               |
|      |                                                                                                          | where<br>PC* - 128 $\leq$ address<br>$\leq$ PC* + 127<br>PC* = Head address of the instruction after the JBS instruction<br>= (address of first byte of JBS instruction) + 3                                                                                                            | true<br>6                      |                                | false<br>9     |        |        |        |                            |       |    |    |    |                                  |
| 1405 | JRNZ DP, address                                                                                         | DPL $\leftarrow$ DP <sub>L</sub> - 1<br>IF DP <sub>L</sub> $\neq$ 0<br>THEN PC $\leftarrow$ address                                                                                                                                                                                     | 11<br>DP <sub>L</sub> $\neq$ 0 |                                |                |        |        |        | 2                          |       |    |    |    | 65                               |
|      |                                                                                                          | where<br>PC* - 128 $\leq$ address<br>$\leq$ PC* + 127<br>PC* = Head address of the instruction after the JRNZ instruction<br>= (address of first byte of JRNZ instruction) + 2                                                                                                          | 7<br>DP <sub>L</sub> $\neq$ 0  |                                |                |        |        |        |                            |       |    |    |    |                                  |

**Chapter 3 Details of Instructions**  
**Instruction List**

**TABLE 3-36. Jump Call Instructions (3)**

\*1 - the first operand

\*2 - the second operand

| No.  | Mnemonics                                                                                                                                                                                          | Operation                                                                                                                                                                                                                                                                                                                                 | Int *1                                                             | Int *1                                                                     | Ext *1                                                        | Ext *1                                                        | Byte no.                                                      | Flags                                                         |    |    |    | Page |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|----|----|----|------|
|      |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                           | Int *2                                                             | Ext *2                                                                     | Int *2                                                        | Ext *2                                                        |                                                               | ZF                                                            | CF | HC | DD |      |
| 1406 | SCAL address                                                                                                                                                                                       | (SSP) $\leftarrow$ PC + 2<br>SSP $\leftarrow$ SSP - 2<br>SF $\leftarrow$ 0<br>PC $\leftarrow$ address<br><br>where<br>PC <sup>*</sup> -128 $\leq$ address<br>$\leq$ PC <sup>*</sup> +127<br>PC <sup>*</sup> = Head address<br>of the instruction after<br>the SCAL instruction<br>= (address of first<br>byte of SCAL<br>instruction) + 2 | 9                                                                  |                                                                            | 13                                                            |                                                               | 2                                                             |                                                               |    |    |    | 139  |
| 1407 | CAL address                                                                                                                                                                                        | (SSP) $\leftarrow$ PC + 3<br>SSP $\leftarrow$ SSP - 2<br>SF $\leftarrow$ 0<br>PC $\leftarrow$ address (16 bits)                                                                                                                                                                                                                           | 9                                                                  |                                                                            | 13                                                            |                                                               | 3                                                             |                                                               |    |    |    | 29   |
| 1408 | CAL [erN]<br>CAL [DP]<br>CAL [X1]<br>CAL [X2]<br>CAL [USP]<br>CAL [SSP]<br>CAL [LRB]<br>CAL [off N]<br>AL [N]<br>CAL [[DP]<br>CAL [[N]USP]<br>CAL [N <sub>1</sub> ;X1]<br>CAL [N <sub>1</sub> ;X2] | (SSP) $\leftarrow$ PC + n<br>SSP $\leftarrow$ SSP - 2<br>SF $\leftarrow$ 0<br>PC $\leftarrow$ obj (16 bits)<br><br>n is the number of bytes<br>in the instruction and<br>varies with the<br>addressing objects.                                                                                                                           | 8<br>8<br>8<br>8<br>8<br>8<br>8<br>8<br>10<br>10<br>11<br>12<br>12 | 12<br>12<br>12<br>12<br>12<br>12<br>12<br>12<br>14<br>14<br>15<br>16<br>16 | 12<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>15<br>14<br>15<br>16 | 12<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>19<br>18<br>19<br>20 | 16<br>—<br>—<br>—<br>—<br>—<br>—<br>—<br>19<br>18<br>19<br>20 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>—<br>3<br>—<br>4 |    |    |    | 39   |
| 1421 | VCAL table-address                                                                                                                                                                                 | (SSP) $\leftarrow$ PC + 1<br>SSP $\leftarrow$ SSP - 2<br>SF $\leftarrow$ 0<br>PC $\leftarrow$ (table-address)<br><br>where<br>table-address must<br>be an even-numbered<br>address in the VCAL<br>table area (26 <sub>H</sub> -37 <sub>H</sub> )                                                                                          | 11                                                                 |                                                                            | 15                                                            |                                                               | 1                                                             |                                                               |    |    |    | 168  |
| 1422 | RT                                                                                                                                                                                                 | SSP $\leftarrow$ SSP + 2<br>PC $\leftarrow$ (SSP)<br>SF $\leftarrow$ 0                                                                                                                                                                                                                                                                    | 7                                                                  |                                                                            | 11                                                            |                                                               | 1                                                             |                                                               |    |    |    | 126  |
| 1423 | RTI                                                                                                                                                                                                | SSP $\leftarrow$ SSP + 2<br>PSW $\leftarrow$ (SSP)<br>SSP $\leftarrow$ SSP + 2<br>LRB $\leftarrow$ (SSP)<br>SSP $\leftarrow$ SSP + 2<br>A $\leftarrow$ (SSP)<br>SSP $\leftarrow$ SSP + 2<br>PC $\leftarrow$ (SSP)                                                                                                                         | 15                                                                 |                                                                            | 31                                                            |                                                               | 1                                                             |                                                               |    |    |    | 127  |

**Chapter 3 Details of Instructions**  
**Instruction List**

---

**TABLE 3-37. Other Instructions**

\*1 - the first operand  
 \*2 - the second operand

| No.  | Mnemonics | Operation                                   | Int '1 | Int '1 | Ext '1 | Ext '1 | Ext '1 | Byte | Flags |    |    |    | Page |
|------|-----------|---------------------------------------------|--------|--------|--------|--------|--------|------|-------|----|----|----|------|
|      |           |                                             | Int '2 | Ext '2 | Int '2 | Ext '2 | Cyc    | no.  | ZF    | CF | HC | DD |      |
| 1424 | SC        | C ← 1                                       | 2      |        |        |        |        | 1    | 1     |    |    |    | 138  |
| 1425 | RC        | C ← 0                                       | 2      |        |        |        |        | 1    |       | 0  |    |    | 117  |
| 1426 | BRK       | SYSTEM RESET<br>PC ← (vector<br>table 0024) | 13     |        |        |        |        | 1    |       |    |    |    | 28   |
| 1427 | NOP       |                                             | 2      |        |        |        |        | 1    |       |    |    |    | 103  |