FUJITSU SEMICONDUCTOR CONTROLLER MANUAL

# F<sup>2</sup>MC-16L 16-BIT MICROCONTROLLER MB90610A SERIES

HARDWARE MANUAL



## Preface

Thank you for purchasing a Fujitsu semiconductor product.

The MB90610A series has been developed as a general-purpose product in the  $F^2MC-16L$  series. The  $F^2MC-16L$  series are proprietary 16-bit single-chip microcontrollers that can be used as application specific ICs (ASICs).

This manual describes the functions and operation of the MB90610A series and is aimed at engineers who are using the chip to develop products. For details on the instruction set, see the " $F^2MC-16L$  Programming Manual".

\*: F<sup>2</sup>MC stands for Fujitsu Flexible Microcontroller.

This manual is organized as follows.

#### Chapter 1 General

Describes the MB90610A series features, product range, block diagram, pin assignment, and notes on device operation.

#### Chapter 2 Hardware

Describes the internal structure of the F<sup>2</sup>MC-16L series CPU and the internal hardware specifications of the MB90610A series.

#### **Chapter 3 Operation**

Describes the clock generator, reset, interrupts, memory access modes, low power modes, and other features of the MB90610A series.

#### **Chapter 4 Instructions**

Summarizes the F<sup>2</sup>MC-16L series instruction set.

- 1. The products described in this manual and the specifications thereof may be changed without prior notice. To obtain up-to-date information and/or specifications, contact your Fujitsu sales representative or Fujitsu authorized dealer.
- 2. Fujitsu will not be liable for infringement of copyright, industrial property right, or other rights of a third party caused by the use of information or drawings described in this manual.
- 3. The contents of this manual may not be transferred or copied without the express permission of Fujitsu.
- The products contained in this document are not intended for use with equipments which require extremely high reliability such as aerospace equipments, undersea repeaters, nuclear control systems or medical equipments for life support.
- 5. Some of the products described in this manual may be strategic materials (or special technology) as defined by the Foreign Exchange and Foreign Trade Control Law. In such cases, the products or portions thereof must not be exported without permission as defined under the Law.

© 1996 FUJITSU LIMITED Printed in Japan

## CONTENTS

| CHAPTER | <b>1</b><br>1.1<br>1.2<br>1.3<br>1.4<br>1.5<br>1.6<br>1.7 | General<br>Features<br>Product Range<br>Block Diagram<br>Pin Assignment<br>Package Dimensions<br>Pin Descriptions<br>Device Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1<br>3<br>4<br>5<br>7<br>9                                                   |
|---------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| CHAPTER | 2.13                                                      | Hardware         CPU         Map         Parallel Ports         UART 0/1/2 (SCI)         10-Bit 8-Input A/D Converter (With 8-Bit Resolution Mode)         PPG         16-Bit Reload Timer (With Event Count Function)         Chip Select Function         DTP/External Interrupts         Delay Interrupt Generation Module         Watchdog Timer and Timebase Timer Functions         Low Power Control Circuits (CPU Intermittent Operation Function,         Oscillation Stabilization Delay Time, and Clock Multiplier Function)         External Bus Pin Control Circuit         Interrupt Controller | 17<br>55<br>63<br>69<br>104<br>116<br>127<br>132<br>139<br>147<br>147<br>154 |
| CHAPTER | <b>3</b><br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6        | Operation<br>Clock Generator<br>Resets<br>Memory Access Modes<br>External Memory Access<br>Low Power Modes<br>Pin States During Sleep, Stop, Hold, and Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 165<br>166<br>169<br>174<br>181                                              |
| CHAPTER | <b>4</b><br>4.1<br>4.2<br>4.3                             | Instructions<br>Addressing<br>Instruction Set<br>Instruction Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 193<br>198                                                                   |

## Chapter 1: General

The MB90610A series are general-purpose, high performance 16-bit microcontrollers designed for applications requiring high speed real-time processing in industry, office equipment, process control, and other fields.

The instruction set follows the  $F^2MC-8$  series AT architecture with additional high level language instructions, enhanced addressing modes, improved multiplication and division instructions, and bit manipulation instructions. Furthermore, a 32-bit accumulator enables processing of long-word data.

The internal peripheral resources consist of a 3-channel serial port incorporating a UART function (and supporting I/O expansion serial mode), 8-channel 10-bit A/D converter, 2-channel PPG, 2-channel 16-bit reload timer, 8-channel chip select output, and eight external interrupts.

Also, multiplexed or non-multiplexed operation can be selected for the address/data bus.

### 1.1 Features

(1) Minimum instruction execution time (Standard F<sup>2</sup>MC-16 features):

62.5 nS at 16 MHz internal operation

Uses PLL clock multiplication

- (2) Instruction set optimized for controller applications (Standard F<sup>2</sup>MC-16 features)
- Wide range of data types (bit, byte, word, and long word)
- Wide range of addressing modes: 23 modes
- High code efficiency
- High accuracy operations are enhanced by use of a 32-bit accumulator.
- (3) Enhanced high level language (C) and multitasking support instructions

(Standard F<sup>2</sup>MC-16 features)

- Use of a system stack pointer
- Enhanced pointer indirect instructions
- Barrel shift instructions
- (4) Improved execution speed (Standard F<sup>2</sup>MC-16 features):

Four byte instruction queue

- (5) Powerful interrupt function from 24 sources in 8 levels (Standard F<sup>2</sup>MC-16 features)
- (6) Automatic data transfer that is independent of the CPU (Standard F<sup>2</sup>MC-16 features)

#### 1.1 Features

#### (7) Multiplexed or non-multiplexed operation can be selected for the address/data bus

#### (8) General-purpose ports

Non-multiplexed mode:36 ports max.Multiplexed mode:52 ports max.

#### (9) UART (SCI): 3ch

• For either asynchronous or clocked serial transfer (I/O expansion serial)

#### (10) A/D converter: 8ch (10-bit)

• 8-bit conversion mode also available

#### (11) PPG (programmable pulse generator): 2ch

- (12) 16-bit reload timer: 2ch
- (13) Chip select output: 8ch

#### (14) External interrupts: 8ch

#### (15) 18-bit timebase timer

- Watchdog timer function
- (16) PLL clock multiplier function

#### (17) CPU intermittent operation function

- (18) Various standby modes
- (19) SQFP-100 or QFP-100 package
- (20) CMOS technology

## 1.2 Product Range

Table 1.2.1 lists the MB90610A series product range. Features other than ROM and RAM size are the same for all products.

|          | MB90611A | MB90V610A         |
|----------|----------|-------------------|
| ROM size | -        |                   |
| RAM size | 1KB      | 4KB               |
| Other    | No ROM   | Evaluation device |

Table 1.2.1 MB90610A Series Product Range

\* At the time of writing this manual, actual product range details are still to be confirmed. The above product range is provisional and does not guarantee the future availability of products.

## 1.3 Block Diagram



Fig. 1.3.1 Block Diagram of the MB90610A Internal Structure

#### **1.4 Pin Assignment**

#### 1.4.1 SQFP-100 Pin Assignment



Fig. 1.4.1 SQFP-100 Pin Assignment

#### 1.4.2 QFP-100 Pin Assignment



Fig. 1.4.2 QFP-100 Pin Assignment

## 1.5 Package Dimensions

#### 1.5.1 SQFP-100 Package Dimensions



## Reference

## EIAJ Code: \*QFP100-P-1414-1



\* The above package dimensions are for reference only. Please confirm the actual dimensions separately.

#### Fig. 1.5.1 SQFP-100 Package Dimensions

### 1.5.2 QFP-100 Package Dimensions

## FPT-100P-

## Reference

## EIAJ Code: \*QFP100-P-1420-4



\* The above package dimensions are for reference only. Please confirm the actual dimensions separately.



## **1.6 Pin Descriptions**

| Pin No.              |                      | Din Nome     | Cinquit Turns                                                                                                                                                                                              | Function                                                                                                                                                                                                  |  |  |
|----------------------|----------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| QFP                  | SQFP                 | Pin Name     | Circuit Type                                                                                                                                                                                               | Function                                                                                                                                                                                                  |  |  |
| 82<br>83             | 80<br>81             | X0<br>X1     | A<br>(Oscillator)                                                                                                                                                                                          | Crystal oscillator pins                                                                                                                                                                                   |  |  |
| 85                   | 83                   | D00 to D07   | к                                                                                                                                                                                                          | In non-multiplex mode, the I/O pins for the lower 8 bits of the external data bus.                                                                                                                        |  |  |
| to<br>92             | to<br>90             | AD00 to AD07 | (TTL)                                                                                                                                                                                                      | In multiplexed mode, the I/O pins for the lower 8 bits of the external address/data bus.                                                                                                                  |  |  |
|                      |                      | P10 to P17   |                                                                                                                                                                                                            | General-purpose I/O ports. This applies in non-multiplexed mode with an 8-bit external data bus.                                                                                                          |  |  |
| 93<br>to<br>100      | 91<br>to<br>98       | D08 to D15   | K<br>(TTL)                                                                                                                                                                                                 | In non-multiplexed mode, the I/O pins for the upper 8 bits of the external data bus.<br>This applies when using a 16-bit external data bus.                                                               |  |  |
|                      |                      | AD08 to AD15 |                                                                                                                                                                                                            | In multiplexed mode, the I/O pins for the upper 8 bits of the external address/data bus.                                                                                                                  |  |  |
|                      | 99                   | P20 to P27   | в                                                                                                                                                                                                          | General-purpose I/O ports. This applies in multiplexed mode.                                                                                                                                              |  |  |
| 1 to 8               | 100<br>1 to 6        | A00 to A07   | (CMOS)                                                                                                                                                                                                     | In non-multiplexed mode, the output pins for the lower 8 bits of the external address bus.                                                                                                                |  |  |
| 9                    | 7                    | P30 to P37   |                                                                                                                                                                                                            | General-purpose I/O ports. This applies in multiplexed mode.                                                                                                                                              |  |  |
| 10<br>12<br>to<br>17 | 8<br>10<br>to<br>15  | A08 to A15   | B<br>(CMOS)                                                                                                                                                                                                | In non-multiplexed mode, the output pins for the upper 8 bits of the external address bus.                                                                                                                |  |  |
| 18<br>to             | 16<br>to             | P40 to P47   |                                                                                                                                                                                                            | General-purpose I/O ports. This applies when the upper address control register specifies port operation.                                                                                                 |  |  |
| 22<br>24<br>to<br>26 | 20<br>22<br>to<br>24 | A16 to A23   | B<br>(CMOS)                                                                                                                                                                                                | The output pins for A16 to 23 of the external address bus. This applies when the upper address control register specifies address operation.                                                              |  |  |
| 07                   | 05                   | P70 to P73   |                                                                                                                                                                                                            | General-purpose I/O ports. This applies in all cases.                                                                                                                                                     |  |  |
| 27<br>to<br>30       | 25<br>to<br>28       | INT0 to INT3 | H<br>(CMOS/H)                                                                                                                                                                                              | External interrupt request input pins. As the inputs operate continuously when exter-<br>nal interrupts are enabled, output to the pins from other functions must be stopped<br>unless doneintentionally. |  |  |
|                      |                      | P74 to P75   |                                                                                                                                                                                                            | General-purpose I/O ports. This applies when the waveform outputs for PPG timers 0 and 1 are disabled.                                                                                                    |  |  |
| 31<br>32             | 29<br>30             | INT4 to INT5 | H<br>(CMOS/H)                                                                                                                                                                                              | External interrupt request input pins. As the inputs operate continuously when exter-<br>nal interrupts are enabled, output to the pins from other functions must be stopped<br>unless doneintentionally. |  |  |
|                      |                      | PPG0 to PPG1 |                                                                                                                                                                                                            | Output pins for PPG timers 0 and 1. This applies when the waveform outputs for PPG timers 0 and 1 are enabled.                                                                                            |  |  |
|                      |                      | P76          |                                                                                                                                                                                                            | General-purpose I/O port. This applies in all cases.                                                                                                                                                      |  |  |
| 33                   | 31                   | INT6         | H<br>(CMOS/H)                                                                                                                                                                                              | External interrupt request input pin. As the input operates continuously when the external interrupt is enabled, output to the pin from other functions must be stopped unless doneintentionally.         |  |  |
|                      | ATGX                 | (000,)       | Trigger input pin for the A/D converter. As the input operates continuously when the A/D converter inputs are operating, output to the pin from other functions must be stopped unless done intentionally. |                                                                                                                                                                                                           |  |  |
| 34                   | 32                   | AVCC         | Power supply                                                                                                                                                                                               | Power supply for the analog circuits. Do not switch this power supply on or off unless a voltage greater than AVCC is applied to VCC.                                                                     |  |  |
| 35                   | 33                   | AVR+         | Power supply                                                                                                                                                                                               | Analog circuit reference voltage input. Do not switch the voltage to this pin on or off unless a voltage greater than AVR+ is applied to AVCC.                                                            |  |  |
| 36                   | 34                   | AVR-         | Power supply                                                                                                                                                                                               | Analog circuit reference voltage input                                                                                                                                                                    |  |  |
| 37                   | 35                   | AVSS         | Power supply                                                                                                                                                                                               | Ground level for the analog circuits                                                                                                                                                                      |  |  |

| Table 1.6.1 | MB90610A | <b>Pin Descriptions</b> | (1) |  |
|-------------|----------|-------------------------|-----|--|
|-------------|----------|-------------------------|-----|--|

| Table 1.6.1 | MB90610A Pin Descriptions (2) |  |
|-------------|-------------------------------|--|
|             |                               |  |

| Pin No.              |                      | Din Nome     | Cincuit Trunc | Function                                                                                                                                                                                                                                |  |  |
|----------------------|----------------------|--------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| QFP                  | SQFP                 | Pin Name     | Circuit Type  | Function                                                                                                                                                                                                                                |  |  |
| 38<br>to             | 36<br>to             | P60 to P67   | _             | Open-drain output ports. This applies when port operation is specified in the analog input enable register.                                                                                                                             |  |  |
| 41<br>43<br>to<br>46 | 39<br>41<br>to<br>44 | AN0 to AN7   | C<br>(AD)     | Analog input pins for the A/D converter. This applies when A/D operation is speci-<br>fied in the analog input enable register.                                                                                                         |  |  |
|                      |                      | P80          |               | General-purpose I/O port. This applies in all cases.                                                                                                                                                                                    |  |  |
| 47                   | 45                   | INT7         | H<br>(CMOS/H) | External interrupt request input pin. As the input operatescontinuously when the external interrupt is enabled, outputto the pin from other functions must be stopped unless doneintentionally.                                         |  |  |
|                      |                      | TINO         | (,            | Event input pin for reload timer 0. As the input operates continuously when the reload timer is set to input operation,output to the pin from other functions must be stopped unless done intentionally.                                |  |  |
|                      |                      | P81          |               | General-purpose I/O port. This applies in all cases.                                                                                                                                                                                    |  |  |
| 48                   | 46                   | TIN1         | D<br>(CMOS/H) | Event input pin for reload timer 1. As the input operates continuously when the reload timer is set to input operation,output to the pin from other functions must be stopped unless done intentionally.                                |  |  |
| 49<br>to<br>51       | 47<br>to<br>49       | MD0 to MD2   | E<br>(CMOS)   | Input pins for specifying the operation mode. Connect directly to VCC or VSS.                                                                                                                                                           |  |  |
| 52                   | 50                   | HSTX         | F<br>(CMOS/H) | Hardware standby input pin                                                                                                                                                                                                              |  |  |
| 53                   | 53 51                | P82 to P83   | D             | General-purpose I/O ports. This applies when output is disabled for reload timers 0 and 1.                                                                                                                                              |  |  |
| 54                   | 52                   | TOT0 to TOT1 | (CMOS/H)      | Output pins for reload timers 0 and 1. This applies when output is enabled for reload timers 0 and 1.                                                                                                                                   |  |  |
|                      |                      | P84          |               | General-purpose I/O port. This applies in all cases.                                                                                                                                                                                    |  |  |
| 55                   | 53                   | SIN0         | D<br>(CMOS/H) | Serial data input pin for UARTO. As the input operates continuously when UARTO is set to input operation, output to thepin from other functions must be stopped unless done intentionally.                                              |  |  |
| FC                   | 54                   | P85          | D             | General-purpose I/O port. This applies when serial data output is disabled for UART0.                                                                                                                                                   |  |  |
| 56                   | 54                   | SOT0         | (CMOS/H)      | Serial data output pin for UART0. This applies when serial data output is enabled for UART0.                                                                                                                                            |  |  |
|                      |                      | P86          |               | General-purpose I/O port. This applies when the UART0 clockoutput is disabled.                                                                                                                                                          |  |  |
| 57                   | 55                   | SCK0         | D<br>(CMOS/H) | Clock I/O pin for UART0. This applies when the UART0 clock output is enabled. As the input operates continuously when UART0 is set to input operation, output to the pin from otherfunctions must be stopped unless done intentionally. |  |  |
|                      |                      | P90          |               | General-purpose I/O port. This applies in all cases.                                                                                                                                                                                    |  |  |
| 58                   | 56                   | SIN1         | D<br>(CMOS/H) | Serial data input pin for UART1. As the input operates continuously when UART1 is set to input operation, output to thepin from other functions must be stopped unless done intentionally.                                              |  |  |
| FO                   | 57                   | P91          | D             | General-purpose I/O port. This applies when serial data output is disabled for UART1.                                                                                                                                                   |  |  |
| 59                   | 57                   | SOT1         | (CMOS/H)      | Serial data output pin for UART1. This applies when serial data output is enabled for UART1.                                                                                                                                            |  |  |
|                      |                      | P92          |               | General-purpose I/O port. This applies when the UART1 clockoutput is disabled.                                                                                                                                                          |  |  |
| 60                   | 58                   | SCK1         | D<br>(CMOS/H) | Clock I/O pin for UART1. This applies when the UART1 clock output is enabled. As the input operates continuously when UART1 is set to input operation, output to the pin from otherfunctions must be stopped unless done intentionally. |  |  |

| Pin            | No.           | Pin Name   | Circuit Type  | Function                                                                                                                                                                                                                                |  |  |
|----------------|---------------|------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| QFP            | SQFP          | Pin Name   | Circuit Type  |                                                                                                                                                                                                                                         |  |  |
|                |               | P93        |               | General-purpose I/O port. This applies in all cases.                                                                                                                                                                                    |  |  |
| 61             | 59 SIN2       |            | D<br>(CMOS/H) | Serial data input pin for UART2. As the input operates continuously when UART2 is set to input operation, output to thepin from other functions must be stopped unless done intentionally.                                              |  |  |
| 62             | 60            | P94        | D             | General-purpose I/O port. This applies when serial data output is disabled for UART2.                                                                                                                                                   |  |  |
| 02             | 00            | SOT2       | (CMOS/H)      | Serial data output pin for UART2. This applies when serial data output is enabled for UART2.                                                                                                                                            |  |  |
|                |               | P95        |               | General-purpose I/O port. This applies when the UART2 clockoutput is disabled.                                                                                                                                                          |  |  |
| 63             | 61            | SCK2       | D<br>(CMOS/H) | Clock I/O pin for UART2. This applies when the UART2 clock output is enabled. As the input operates continuously when UART2 is set to input operation, output to the pin from otherfunctions must be stopped unless done intentionally. |  |  |
| 64             | 62            | CS0        | J<br>(CMOS)   | Chip select pin for program ROM                                                                                                                                                                                                         |  |  |
| 65             | 63            | PA1 to PA7 | I             | General-purpose I/O ports. This applies for pins with chip select output disabled by the chip select control register.                                                                                                                  |  |  |
| to<br>71       | to<br>69      | CS1 to CS7 | (CMOS)        | Output pins for the chip select function. This applies for pins with chip select output enabled by the chip select control register.                                                                                                    |  |  |
| 70             | 70            | P50        | I             | General-purpose I/O port. This applies when CLK output is disabled.                                                                                                                                                                     |  |  |
| 72             | 70            | CLK        | (CMOS)        | CLK output pin. This applies when CLK output is enabled.                                                                                                                                                                                |  |  |
| 10             | - 4           | P51        | L             | General-purpose I/O port. This applies when the external ready function is disabled.                                                                                                                                                    |  |  |
| 73             | 71            | RDY        | (TTL)         | Ready input pin. This applies when the external ready function is enabled.                                                                                                                                                              |  |  |
| 74             | 70            | P52        | 1             | General-purpose I/O port. This applies when the hold function is disabled.                                                                                                                                                              |  |  |
| 74             | 72            | HAKX       | (CMOS)        | Hold acknowledge output pin. This applies when the hold function is enabled.                                                                                                                                                            |  |  |
| 75             | 70            | P53        | L             | General-purpose I/O port. This applies when the hold function is disabled.                                                                                                                                                              |  |  |
| 75             | 73            | HRQ        | (TTL)         | Hold request input pin. This applies when the hold functionis enabled.                                                                                                                                                                  |  |  |
| 76             | 74            | P54        | I             | General-purpose I/O port. This applies in 8-bit external bus mode or when output is disabled for the WR pin.                                                                                                                            |  |  |
| 76             | 74            | WRHX       | (CMOS)        | Write strobe output pin for the upper 8 bits of the data bus. This applies in 16-bit external bus mode and when output is enabled for the WR pin.                                                                                       |  |  |
| 77             | 75            | RSTX       | G<br>(CMOS/H) | External reset request input pin                                                                                                                                                                                                        |  |  |
|                |               | P55        |               | General-purpose I/O port. This applies when output is disabled for the WR pin.                                                                                                                                                          |  |  |
| 78             | 76            | WRLX       | I<br>(CMOS)   | Write strobe output pin for the lower 8 bits of the data bus. This applies when output is enabled for the WR pin.                                                                                                                       |  |  |
| 79             | 77            | RDX        | J<br>(CMOS)   | Read strobe output pin for the data bus                                                                                                                                                                                                 |  |  |
| 80             | 78            | ALE        | J<br>(CMOS)   | Address latch enable output pin                                                                                                                                                                                                         |  |  |
| 23<br>84       | 21<br>82      | VCC        | Power supply  | Power supply for the digital circuits                                                                                                                                                                                                   |  |  |
| 11<br>42<br>81 | 9<br>40<br>79 | VSS        | Power supply  | Ground level for the digital circuits                                                                                                                                                                                                   |  |  |

Table 1.6.1 MB90610A Pin Descriptions (3)



 Table 1.6.3
 I/O Circuit Configurations (1)



 Table 1.6.3
 I/O Circuit Configurations (2)



Table 1.6.3 I/O Circuit Configurations (3)

**Note:** For pins with pull-up resistors, the resistance is disconnected when the pin outputs the "L" level or when in the standby state.

#### **1.7 Device Operation** 14 Chapter 1: General

#### (1) Preventing latch-up

Latch-up occurs in a CMOS IC if a voltage greater than VCC or less than VSS is applied to an input or output pin or if the voltage applied across VCC and VSS exceeds the rating. If latch-up occurs, the power supply current increases rapidly resulting in thermal damage to circuit elements. Therefore, ensure that maximum ratings are not exceeded in circuit operation.

For the same reason, also ensure that the analog supply voltage does not exceed the digital supply voltage.

#### (2) Connecting unused pins

Leaving unused input pins unconnected can cause misoperation. Always pull-up or pull-down unused pins.

#### (3) Cautions when using an external clock

Drive the X0 pin only when using an external clock. Figure 1.7.1 shows an example of how to use an external clock.



Fig. 1.7.1 Example of Using an External Clock

#### (4) Power supply pins

When multiple VCC and VSS pins are provided, connect all VCC and VSS pins to supply or ground externally. Although pins at the same potential are connected together in the internal device design so as to prevent misoperation such as latch-up, connecting all VCC and VSS pins appropriately minimizes unwanted radiation, prevents misoperation of strobe signals due to increases in the ground level, and keeps the overall output current rating.

Also, take care to connect VCC and VSS to a low impedance current source.

Connection of a bypass capacitor (a ceramic capacitor of approximately 0.1  $\mu$ F connected close to the device) between VCC and VSS is recommended.

#### (5) Crystal oscillator circuit

Noise in the vicinity of the X0 and X1 pins can be a cause of device misoperation. Place X0, X1, the crystal oscillator (or ceramic oscillator), and the bypass capacitor to ground as close together as possible. Also, design the circuit board so that the wiring for the crystal oscillator circuit does not cross other wiring.

A printed circuit board design that surrounds the X0 and X1 pins with ground provides for stable operation and is strongly recommended.

#### (6) A/D converter power supply and the turn-on sequence for analog inputs

Do not apply current to the A/D converter power supply (AVCC, AVR+, AVR-) or analog inputs (AN0 to

#### 1.7 Device Operation

AN7) until the digital power supply (VCC) is turned on.

When turning the device off, turn off the digital power supply after cutting the A/D converter power supply and analog inputs.

When turning the power on or off, ensure that AVR+ does not exceed AVCC.

2.1 CPU

## Chapter 2: Hardware

## 2.1 CPU

#### 2.1.1 Memory Space

■ Outline of the CPU memory space

The program, data, and I/O managed by the F<sup>2</sup>MC-16L CPU are all located in the CPU's 16MB memory space. The CPU accesses each resource by setting the corresponding address on the 24-bit address bus (Figure 2.1.1).



Fig. 2.1.1 Example of the Relationship Between the F<sup>2</sup>MC-16L System and Memory Map

#### 2.1 CPU

■ Address generation modes

Address generation in the F<sup>2</sup>MC-16L can be broadly divided into two modes: linear addressing and bank addressing. In linear addressing, the instruction specifies the entire 24-bit address. In bank addressing, the upper 8 bits of the address are set in a bank register based on the application and the instruction specifies the lower 16 bits of the address.

Linear addressing can be further divided into two types. In one method, the operand specifies the 24-bit address directly. In the other method, the lower 24 bits of a 32-bit general-purpose register are used as the address. (Figure 2.1.2)

#### Example 1: Linear addressing with a 24-bit operand specified



Example 2: Linear addressing using 32-bit register indirect addressing

#### MOV A,@RL1+7



#### Fig. 2.1.2 Example of Linear Address Generation

■ Bank addressing modes

Bank addressing splits the 16MB address space into 256 banks of 64KB. The bank registers specify the bank address. Five types of bank register are provided. Table 2.1.1 lists the memory space accessed and the main use for each bank register.

| Bank Register Name        |         | Memory Space<br>Name  | Main Application                                                                                                              | Initial Value<br>After Reset |  |
|---------------------------|---------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|
| Program bank register     | (PCB)   | Program (PC) space    | Stores instruction code, vector tables, and immediate data                                                                    | FFн                          |  |
| Data bank register        | (DTB)   | Data (DT) space       | Stores readable and writable data.<br>Accesses control registers and data registers for internal<br>and external peripherals. | 00н                          |  |
| User stack bank register  | (USB)   |                       | Area used for stack access such as by PUSH and POP                                                                            | 00н                          |  |
| System stack bank registe | r (SSB) | Stack (SP) space      | instructions or register saving at interrupts.<br>SSB is used when S=1 in CCR.<br>USB is used when S=0 in CCR.                | 00н                          |  |
| Additional bank register  | (ADB)   | Additional (AD) space | Stores data such as data that is too large for the data (DT) space.                                                           | 00н                          |  |

 Table 2.1.1 Memory Space Accessed by Each Bank Register

After a reset, the DT, SP, and AD spaces are allocated to bank 00 (000000H to 00FFFFH) and the PC space is allocated to bank FF (FF0000H to FFFFFFH).

To improve instruction code efficiency, instructions have a default space for each addressing mode. Table 2.1.2 lists the defaults. Prefix codes can be prefixed to instructions to specify a space other than the default for the addressing mode used. The system accesses the space corresponding to the prefix code.

Table 2.1.2 Default Memory Spaces

| Default Space    | Addressing                                                  |  |
|------------------|-------------------------------------------------------------|--|
| Program space    | PC indirect, program access, branching                      |  |
| Data space       | @A, addr16, dir, Addressing using @RW0, @RW1, @RW4, or @RW5 |  |
| Stack space      | Addressing using PUSHW, POPW, @RW3, or @RW7                 |  |
| Additional space | Addressing using @RW2 or @RW6                               |  |

#### 2.1 CPU

Figure 2.1.3 shows an example of the division of memory space into banks and each bank register.





■ Memory space layout for multi-byte data

Figure 2.1.4 shows the data configuration of multi-byte data in memory. The lower 8 bits are placed at location n and subsequent bytes placed at locations n+1, n+2, n+3, etc.



#### Fig. 2.1.4 Example of Memory Layout for Multi-Byte Data

Memory is written to from the lowest address. Therefore, for 32-bit data, the lower 16 bits are transferred first, followed by the upper 16 bits.

If a reset signal is input immediately after writing the lower data bits, writing the upper data bits may not occur.

■ Accessing multi-byte data

All access occurs within a bank. Therefore, for instructions that access multi-byte data, the next address after location FFFFH is location 0000H in the same bank. Figure 2.1.5 shows an execution example for an instruction that accesses multi-byte data.



Fig. 2.1.5 Execution of MOVW A,080FFFFH

#### 2.1 CPU

#### 2.1.2 Registers

The F<sup>2</sup>MC-16L registers can be broadly divided into two categories: dedicated registers located in the CPU and general-purpose registers located in internal RAM. Dedicated registers exist as specific hardware in the CPU and their use is limited by the CPU architecture. In contrast, general-purpose registers are located in RAM in the CPU's address space. Like special registers, general-purpose registers can be accessed without specifying an address. However, general-purpose registers can also be used as specified by the user, in the same way as standard memory. Figure 2.1.6 shows the layout of the dedicated and general-purpose registers in the device.



Fig. 2.1.6 Special and General-Purpose Registers

Dedicated registers

Table 2.1.3 lists the eleven dedicated registers in the  $F^2MC-16L$ .

| Structure | Register Name                 | Function                                                                                                              |
|-----------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| AH AL     | Accumulator                   | $2 \times 16$ -bit registers used to save operation results and similar. Can be combined as a single 32-bit register. |
| USP       | User stack pointer            | 16-bit pointer that specifies the user stack area                                                                     |
| SSP       | System stack pointer          | 16-bit pointer that specifies the system stack area                                                                   |
| PS        | Processor status              | 16-bit register that indicates the system status                                                                      |
| PC        | Program counter               | 16-bit register that stores the address containing the program                                                        |
| DPR       | Direct page register          | 8-bit register that specifies the direct page                                                                         |
| PCB       | Program bank register         | 8-bit register that specifies the program space                                                                       |
| DTB       | Data bank register            | 8-bit register that specifies the data space                                                                          |
| USB       | User stack bank register      | 8-bit register that specifies the user stack space                                                                    |
| SSB       | System stack bank register    | 8-bit register that specifies the system stack space                                                                  |
| ADB       | Additional data bank register | 8-bit register that specifies the additional space                                                                    |

## Table 2.1.3 Dedicated Registers

■ Accumulator (A)

The accumulator consists of two 16-bit operation registers: AH and AL. The accumulator is used for temporary storage of operation results and data moves. AH and AL can be combined for 32-bit data processing. For 16-bit word processing or 8-bit byte processing, the AL register only is used. (See Figures 2.1.7 and 2.1.8.)

Operations can be performed on accumulator data and memory or register (Ri, RWi, or RLi) data. Like the  $F^2MC-8$ , when word-length or shorter data is transferred to the  $F^2MC-16$ 's AL register, the previous content of AL is automatically transferred to AH (the data retention function). The data keep function and AL-AH operations increase the processing efficiency of the device. (Figure 2.1.8)

<u>MOVL A,@RW1+6</u> (This instruction performs a long-word read from the location specified by adding an 8-bit offset value to RW1 and places the data in the accumulator.)



Fig. 2.1.7 32-Bit Data Move Example

<u>MOVW A,@RW1+6</u> (This instruction performs a single-word read from the location specified by adding an 8-bit offset value to RW1 and places the data in the accumulator.)



Fig. 2.1.8 AL-AH Move Example

When moving byte-length or shorter data to AL, the data placed in AL is sign extended or zero extended to a length of 16 bits. Data in AL can be treated as word-length or byte-length. When the CPU executes a byte-length arithmetic instruction on AL, the operation ignores the upper 8 bits of AL and sets the upper 8 bits of the result to zero. (See Figures 2.1.9 and 2.1.10.)

The accumulator is not initialized by a reset. The value of the accumulator after a reset is undefined.

MOV A,3000H (This instruction zero extends the data at location 3000H and places the result in AL.)



#### Fig. 2.1.9 Zero Extend Execution Example

MOVX A.3000H (This instruction sign extends the data at location 3000H and places the result in AL.)



#### Fig. 2.1.10 Sign Extend Execution Example

■ User stack pointer (USP) and system stack pointer (SSP)

The USP and SSP are 16-bit registers that specify the memory address for saving and restoring data at PUSH/POP instruction or subroutine execution. Stack instructions operate in the same way on both USP and SSP. The instructions use USP if the S flag in the processor status (PS) register is set to "0" and SSP if the S flag is set to "1" (see Figure 2.1.11).

The S flag is set to "1" when an interrupt is received. Therefore, when an interrupt occurs, the processor always saves registers to the memory specified by SSP. Normally, stack processing in interrupt routines uses SSP and stack processing other than in interrupt routines uses USP. If separate stack spaces are not necessary, use SSP only.

Always set an even numbered address to the stack pointer. Setting an odd numbered address splits word access in two and reduces efficiency.

SSB specifies the upper 8 bits of the stack address for SSP and USB specifies the upper 8 bits for USP. USP and SSP are not initialized by a reset. The values of USP and SSP after a reset are undefined.



Example 1: Executing PUSHW A when the S flag is "0".

Example 2: Executing PUSHW A when the S flag is "1".





■ Processor status (PS)

The processor status register consists of control bits that control the CPU operation and status bits that indicate the CPU status. Figure 2.1.12 shows the structure of PS. The upper byte contains the register bank pointer (RP), which indicates the top address of the register bank, and the interrupt level mask register (ILM). The lower byte contains the condition code register (CCR). The CCR consists of flags which are set to "0" or "1" by instruction execution results, interrupt generation, or other events.



#### Fig. 2.1.12 PS Structure

#### (1) Condition code register (CCR)

Figure 2.1.13 shows the structure of the condition code register.



#### Fig. 2.1.13 Condition Code Register Structure

| I: Interrupt enable flag | For all interrupts other than software interrupts, setting I to "1" enables the interrupts and setting I to "0" masks the interrupts. Cleared by a reset.                                         |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S: Stack flag            | Stack operations use USP if the S flag is set to "0" and SSP if the S flag is set to "1". Set by a reset or on receiving an interrupt.                                                            |
| T: Sticky bit flag       | Set to "1" if the data shifted out of carry during a logical or arithmetic right shift instruction contains one or more "1"s. Otherwise, set to "0". Also set to "0" if the shift amount is zero. |
| N: Negative flag         | Set if the MSB of an operation result is "1", cleared if the MSB is "0".                                                                                                                          |
| Z: Zero flag             | Set if an operation result is all "0"s, cleared otherwise.                                                                                                                                        |
| V: Overflow flag         | Set if an overflow occurs for a signed value as the result of the execution of<br>an operation. Cleared if no overflow occurs.                                                                    |
| C: Carry flag            | Set if a carry-up or carry-down occurs for the MSB as the result of the execution of an operation. Cleared if no carry occurs.                                                                    |

#### 2.1 CPU

#### (2) Register bank pointer (RP)

The RP register specifies the relationship between the  $F^2MC-16L$ 's general-purpose registers and the addresses in internal RAM where the registers are located. The top memory address of the register bank currently in use is specified by the conversion formula: [000180H + (RP)\*10H] (Figure 2.1.14). RP consists of 5 bits and can be set in the range 00H to 1FH. This allows register banks to be located in memory between 000180H and 00037FH. However, addresses in this range can only be used as general-purpose registers if the address is in internal RAM. RP is initialized to 00H by a reset.

RP can be set by an 8-bit immediate move instruction but only the lower 5 bits are used.



#### Fig. 2.1.14 Register Bank Pointer

#### (3) Interrupt Level Mask Register (ILM)

The ILM consists of 3 bits and specifies the interrupt mask level for the CPU. The CPU only receives interrupts with a higher priority level than the level specified in ILM. Zero is the highest interrupt level and seven is the lowest interrupt level (see Table 2.1.4). Therefore, to receive an interrupt, the level value of the interrupt request must be less than the value set in ILM. When an interrupt is received, the interrupt level value is set in ILM. This disables the subsequent reception of interrupts of the same or lower priority. ILM is initialized to all zeros by a reset. Instruction allows 8-bit immediate value transfer to ILM but only the upper 3 bits are actually used.

#### Fig. 2.1.15 Interrupt Level Register

|      | , , , , , , , , , , , , , , , , , , , |      |       | 5 ( )                     |  |
|------|---------------------------------------|------|-------|---------------------------|--|
| ILM2 | ILM1                                  | ILM0 | Level | Allowed Interrupt Levels  |  |
| 0    | 0                                     | 0    | 0     | All interrupts prohibited |  |
| 0    | 0                                     | 1    | 1     | 0 only                    |  |
| 0    | 1                                     | 0    | 2     | Level 1 or less           |  |
| 0    | 1                                     | 1    | 3     | Level 2 or less           |  |
| 1    | 0                                     | 0    | 4     | Level 3 or less           |  |
| 1    | 0                                     | 1    | 5     | Level 4 or less           |  |
| 1    | 1                                     | 0    | 6     | Level 5 or less           |  |
| 1    | 1                                     | 1    | 7     | Level 6 or less           |  |

Table 2.1.4 Priority Levels for the Interrupt Level Mask Register (ILM)

■ Program counter (PC)

The PC is a 16-bit counter. The PC specifies the lower 16 bits of the memory address of the instruction code to be executed by the CPU. PCB specifies the upper 8 bits of the address. Operations that update the content of the PC include conditional branch instructions, subroutine call instructions, interrupts, and resets.



Fig. 2.1.16 Program Counter

■ Direct page register (DPR) <Initial value: 01H>

As shown in Figure 2.1.17, the DPR specifies addr8 to addr15 of the operand for direct addressing instructions. DPR is an 8-bit register and is initialized to 01H by a reset. The DPR can be read from or written to by instructions.



#### Fig. 2.1.17 Physical Address Generation Using Direct Addressing

■ Program counter bank register (PCB) <Initial value: value from reset vector>

| Data bank register            | (DTB) | <initial 00h="" value:=""></initial> |
|-------------------------------|-------|--------------------------------------|
| User stack bank register      | (USB) | <initial 00h="" value:=""></initial> |
| System stack bank register    | (SSB) | <initial 00h="" value:=""></initial> |
| Additional data bank register | (ADB) | <initial 00h="" value:=""></initial> |

The bank registers specify the memory banks for the PC space, DT space, SP space (user), SP space (system), and AD space respectively. All bank registers consist of 8 bits. A reset initializes PCB to FFH and other bank registers to 00H. The bank registers other than PCB permit reading and writing. The PCB permits reading but not writing. The PCB is written to on execution of branch instructions (JMPP, CALLP, RETP, and RETI) that operate in the total (16MB) memory space, on execution of a software interrupt instruction, and when exceptions or hardware interrupts occur. See 2.1.1 "Memory Space" for details on the operation of each register.

#### 2.1 CPU

■ General-purpose registers

The general-purpose registers of the  $F^2MC-16L$  are located in RAM at 000180H to 00037FH in the memory map. The register bank pointer (RP) specifies the section of memory that is currently used as the register bank. Each bank contains the following three register types. The registers are not independent. Figure 2.1.18 shows the relationship between the registers.



#### Fig. 2.1.18 General-Purpose Registers

#### Register bank

The register bank consists of eight 16-bit registers: byte registers R0 to R7, word registers RW0 to RW7, and long word registers RL0 to RL3. The registers can be used as general-purpose registers in various operations and as pointers in various instructions. RL0 to RL3 can also be used as linear pointers to directly access the entire memory space. Table 2.1.5 lists the function of each register.

As for standard RAM, the register contents are not initialized by a reset and the registers maintain the values that they had prior to the reset. However, the register contents are indeterminate at power on.

| Table 2.1.5 | Register | Functions |
|-------------|----------|-----------|
|-------------|----------|-----------|

| R0 to R7   | Used as instruction operands.<br><b>Note:</b> R0 is also used as the barrel shift counter and normalize instruction counter. |  |
|------------|------------------------------------------------------------------------------------------------------------------------------|--|
| RW0 to RW7 | Used as pointers.<br>Used as instruction operands.<br><b>Note:</b> RW0 is also used as the string instruction counter.       |  |
| RL0 to RL3 | Used as long pointers.<br>Used as instruction operands.                                                                      |  |

#### 2.1.3 Prefix Codes

Placing a prefix code in front of an instruction modifies the operation of the instruction. Three types of prefix codes are available: bank select prefixes, common register bank prefixes, and flag change inhibit prefixes.

■ Bank select prefix

The memory space used for data access is determined by the addressing mode. Placing a bank select prefix in front of an instruction selects a specific memory space for data access by the instruction, irrespective of the addressing mode. Table 2.1.6 lists the memory space selected by each bank select prefix.

| Bank Select Prefix | Memory Space                                                                                                     |
|--------------------|------------------------------------------------------------------------------------------------------------------|
| PCB                | PC space                                                                                                         |
| DTB                | Data space                                                                                                       |
| ADB                | AD space                                                                                                         |
| SPB                | If the S flag in CCR is "0", selects the user stack space. If the S flag is "1", selects the system stack space. |

Table 2.1.6 Bank Select Prefix

However, note that the instructions listed in Table 2.1.7 ignore the bank select prefix. Also, for the instructions listed in Table 2.1.8, the effect of the bank select prefix is passed on to the next instruction.

| Instruction Type                   | Ins                                                                                                            | struction                                                                                             | Effect of the Bank Select Prefix                                                             |
|------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| String instructions                | MOVS<br>SCEQ<br>FILS                                                                                           | MOVSW<br>SCWEQ<br>FILSW                                                                               | Uses the bank register specified in the operand, whether or not a prefix is present.         |
| Stack manipulation<br>instructions | PUSHW                                                                                                          | POPW                                                                                                  | Uses USB (if the S flag = 0) or SSB (if the S flag = 1), whether or not a prefix is present. |
| I/O access<br>instructions         | MOV A,io<br>MOVW A,io<br>MOV io,A<br>MOV io,#imm8<br>MOVB A,io:bp<br>SETB io:bp<br>BBC io:bp,rel<br>WBTC io:bp | MOVX A,io<br>MOVW io,A<br>MOVW io,#imm16<br>MOVB io:bp,A<br>CLRB io:bp<br>BBS io:bp,rel<br>WBTS io:bp | Accesses the memory space 000000н to 0000FFн, whether or not a prefix is present.            |
| Interrupt return<br>instruction    | RETI                                                                                                           |                                                                                                       | Uses SSB, whether or not a prefix is present.                                                |

Table 2.1.7 Instructions that Ignore the Bank Select Prefix

Table 2.1.8 Instructions for Which the Effect of the Bank SelectPrefix is Passed on to the Next Instruction

| Instruction Type         | Instruction                |  |
|--------------------------|----------------------------|--|
| Flag modify instructions | AND CCR,#imm8 OR CCR,#imm8 |  |
| PS restore instruction   | POPW PS                    |  |
| ILM set instruction      | MOV ILM,#imm8              |  |

■ When multiple prefix codes are specified

When multiple conflicting prefix codes are specified, the final code specified is used.



## Fig. 2.1.19 Multiple Prefix Codes

Common register bank prefix (CMR)

To simplify data exchange between tasks, a predetermined common register bank is required that can be accessed by a comparatively simple procedure unaffected by the value of RP at the time. Placing CMR in front of an instruction that accesses a register bank changes the accessed register bank to the common bank located at 000180H to 00018FH (the bank selected when RP = 0), irrespective of the current value of RP. However, care is required with the instructions listed in Table 2.1.9.

| Table 2.1.9 | Instructions Requiring Care When Using the |
|-------------|--------------------------------------------|
|             | Common Register Bank Prefix                |

| Instruction Type            | Instruction                            | Explanation                                                    |
|-----------------------------|----------------------------------------|----------------------------------------------------------------|
| String instructions         | MOVS MOVSW<br>SCEQ SCWEQ<br>FILS FILSW | Do not use the CMR prefix with string instructions.            |
| Flag modify<br>instructions | AND CCR,#imm8 OR CCR,#imm8             | The effect of the prefix is passed on to the next instruction. |
| PS restore instruction      | POPW PS                                | The effect of the prefix is passed on to the next instruction. |
| ILM set instruction         | MOV ILM,#imm8                          | The effect of the prefix is passed on to the next instruction. |

■ Flag change inhibit prefix

Use the flag change inhibit prefix code (NCC) to inhibit unwanted changes to the flags. Placing NCC in front of an instruction prevents instruction execution from changing the flags. The prefix inhibits changes to the T, N, Z, V, and C flags.

However, care is required with the instructions listed in Table 2.1.10.

| Instruction Type                                              | Instructions                                     | Explanation                                                                                                                                       |
|---------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| String instructions                                           | MOVSMOVSWSCEQSCWEQFILSFILSW                      | Do not use the NCC prefix with string instructions.                                                                                               |
| Flag modify<br>instructions                                   | AND CCR,#imm8 OR CCR,#imm8                       | The instruction changes CCR as<br>usual, whether or not a prefix is<br>present. The effect of the prefix is<br>passed on to the next instruction. |
| PS restore<br>instruction                                     | POPW PS                                          | The instruction changes CCR as<br>usual, whether or not a prefix is<br>present^\The effect of the prefix is<br>passed on to the next instruction. |
| ILM set instruction                                           | MOV ILM,#imm8                                    | The effect of the prefix is passed on to the next instruction.                                                                                    |
| Interrupt<br>instructions<br>Interrupt return<br>instructions | INT #vct8 INT9<br>INT addr16 INTP addr24<br>RETI | The instruction changes CCR as usual, whether or not a prefix is present.                                                                         |
| Context switch instruction                                    | JCTX @A                                          | The instruction changes CCR as usual, whether or not a prefix is present.                                                                         |

Table 2.1.10 Instructions Requiring Care When Using the Flag Change Inhibit Prefix

### ■ Interrupt inhibiting instructions

Hardware interrupt requests are not detected and interrupt requests are ignored for the ten types of instruction listed in Table 2.1.11.

| MOV ILM,#imm8 | PCB | SPB |  |
|---------------|-----|-----|--|
| AND CCR,#imm8 | ADB | CMR |  |
| OR CCR,#imm8  | NCC |     |  |
| POPW PS       | DTB |     |  |

### Table 2.1.11 Hardware Interrupt Inhibiting Instructions

Therefore, if a valid hardware interrupt request occurs during execution of one of these instructions, interrupt processing does not start until after the execution of the next instruction of a type other than those listed above. Figure 2.1.20 shows an example.



## Fig. 2.1.20 Interrupt Inhibiting Instructions

Restrictions for interrupt inhibiting instructions and prefix instructions

If a prefix code is placed in front of an interrupt inhibiting instruction, the effect of the prefix code is passed on to the next instruction that is not an interrupt inhibiting instruction. Figure 2.1.21 shows an example.



## Fig. 2.1.21 Interrupt Inhibiting Instructions and Prefix Codes

## 2.1.4 Interrupts, Extended Intelligent I/O Service, and Exceptions

The  $F^2MC-16L$  has functions that halt the currently executing processing and pass control to another defined program when an event or similar occurs. The functions can be divided into the following four types.

| • Hardware interrupt                                    | Interrupt processing triggered by an event occurring in an internal resource circuit.     |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------|
| • Software interrupt                                    | Interrupt processing triggered by a software event instruction.                           |
| • Extended intelligent I/O service (EI <sup>2</sup> OS) | Data transfer processing triggered by an event occurring in an internal resource circuit. |
| • Exception                                             | Interrupt processing triggered by an exception.                                           |

■ Hardware interrupts

## (1) Outline

The hardware interrupt function temporarily interrupts the program currently executing in the CPU in response to an interrupt request signal from an internal resource circuit. Control is passed to a user-defined interrupt handling program.

To activate a hardware interrupt, the hardware compares the interrupt level of the interrupt request with the interrupt level mask register (ILM) in the PS register of the CPU and checks the value of the I flag in the PS register. The hardware interrupt activates if the conditions are valid. The CPU performs the following processing when a hardware interrupt occurs.

- The A, DPR, ADB, DTB, PCB, PC, and PS registers in the CPU are saved on the system stack.
- The current interrupt level is stored in ILM in the PS register.
- Execution branches to the corresponding interrupt vector.

## (2) Configuration

The mechanisms relating to hardware interrupts can be divided into the following three groups.

| • Internal resource circuits | Interrupt enable bit and interrupt request bit: Controls interrupt requests from internal resources.            |
|------------------------------|-----------------------------------------------------------------------------------------------------------------|
| • Interrupt controller       | ICR: Assigns interrupt levels and prioritizes simultaneous interrupts.                                          |
| • CPU                        | I, ILM: Compares the level of the interrupt request with the current level. Stores the interrupt enable status. |
|                              | Microcode: Executes the interrupt processing steps.                                                             |

Each mechanism is represented by the content of its respective registers: internal resource control registers for internal resource circuits, the ICR for the interrupt controller, and the CCR for the CPU. When using hardware interrupts, the program must first set values to these three register types. See "Interrupt Control Register (ICR)" in the "Extended Intelligent I/O Service" section for details on the ICR.

The interrupt vector table referenced during interrupt processing is located in the memory area FFFC00H to FFFFFFH. The area is shared with software interrupts. Table 2.1.12 lists the allocation of interrupt numbers and interrupt vectors.

| Software<br>Interrupt<br>Instruction | Vector<br>Address L | Vector<br>Address M | Vector<br>Address H | Mode<br>Register | Interrupt<br>Number | Hardware<br>Interrupt    |
|--------------------------------------|---------------------|---------------------|---------------------|------------------|---------------------|--------------------------|
| INT 0                                | FFFFFCH             | FFFFDH              | FFFFEH              | Unused           | #0                  | None                     |
|                                      |                     |                     |                     |                  |                     |                          |
| INT 7                                | FFFFE0H             | FFFFE1H             | FFFFE2H             | Unused           | #7                  | None                     |
| INT 8                                | FFFFDCH             | FFFFDDH             | FFFFDEH             | FFFFDF           | #8                  | (Reset<br>vector)        |
| INT 9                                | FFFFD8H             | FFFFD9H             | FFFFDAH             | Unused           | #9                  | None                     |
| INT 10                               | FFFFD4H             | FFFFD5H             | FFFFD6H             | Unused           | #10                 | <exception></exception>  |
| INT 11                               | FFFFD0H             | FFFFD1H             | FFFFD2H             | Unused           | #11                 | Hardware<br>interrupt #0 |
| INT 12                               | FFFFCCH             | FFFFCDH             | FFFFCEH             | Unused           | #12                 | Hardware<br>interrupt #1 |
| INT 13                               | FFFFC8H             | FFFFC9H             | FFFFCAH             | Unused           | #13                 | Hardware<br>interrupt #2 |
| INT 14                               | FFFFC4H             | FFFFC5H             | FFFFC6H             | Unused           | #14                 | Hardware<br>interrupt #3 |
|                                      |                     |                     |                     |                  |                     |                          |
| INT 254                              | FFFC04H             | FFFC05H             | FFFC06H             | Unused           | #254                | Free                     |
| INT 255                              | FFFC00H             | FFFC01H             | FFFC02H             | Unused           | #255                | <stack fault=""></stack> |

Table 2.1.12 Allocation of Interrupt Numbers and Interrupt Vectors

## (3) Operation

Internal resources with a hardware interrupt function have an "interrupt request flag" that indicates whether an interrupt request is present and an "interrupt enable flag" that selects whether or not the resource circuit can send interrupt requests to the CPU. The interrupt request flag is set by specific events in the internal resource circuit. If the interrupt enable flag is set to "enabled", the internal resource circuit passes the interrupt request to the interrupt controller.

The interrupt controller compares the interrupt level (IL) in the ICR for each simultaneously occurring interrupt request, selects the request with the highest level (the lowest IL value), and notifies the CPU. If more than one request occurs with the same level, the request with the lowest interrupt number has priority. See Section 2.2.3 "Interrupt Vector Allocation" for details on the relationship between each interrupt request and ICR.

The CPU compares the received interrupt level with ILM in the PS register. If the interrupt level (IL) is less than ILM and the I flag in the PS register is "1", the CPU activates the interrupt processing microcode after completing execution of the current instruction. The interrupt processing microcode first checks that the ISE bit in the interrupt controller's ICR register is set to "0" (indicating an interrupt), then activates the main body of interrupt processing.

After saving the A, DPR, ADB, DTB, PCB, PC, and PS registers (12 bytes) to the memory area specified by SSB and SSP, interrupt processing reads the 3-byte interrupt vector and loads the vector to PC and PCB, changes ILM in the PS register to the level of the received interrupt request, sets the S flag to "1", then executes branch processing.

As a result, the next executed instruction is the user-defined interrupt processing program.

Figure 2.1.22 shows the flow of processing from the generation of a hardware interrupt until the interrupt request is completed by the interrupt processing program. Figure 2.1.23 shows the operation flow for a hardware interrupt.





36

- (1) Interrupt source generated in the internal resource.
- (2) If interrupts are enabled in the internal resource by the interrupt enable bit, the interrupt request is passed from the resource to the interrupt controller.
- (3) The interrupt controller receives the interrupt request, evaluates the priorities of any simultaneous interrupt requests, then passes the interrupt level of the highest priority interrupt to the CPU.
- (4) The CPU compares the level of the interrupt request from the interrupt controller with ILM in the processor status register.
- (5) If the result of comparison is that the priority is higher than for the current interrupt processing level, the CPU then checks the I flag in the processor status register.
- (6) If checking the I flag in step 5 indicates that interrupts are enabled, the CPU waits until the current instruction completes executing, then sets the request level in ILM.
- (7) The CPU saves the registers, then passes control by branching to the interrupt processing routine.
- (8) The interrupt request completes when the user's interrupt processing routine software clears the interrupt source generated in step 1.



Fig. 2.1.23 Interrupt Operation Flow

## (4) Example procedure for using hardware interrupts



## Fig. 2.1.24 Example Procedure for Using Hardware Interrupts

- (1) Set the system stack area.
- (2) Initialize the internal resource that can generate interrupt requests.
- (3) Set ICR in the interrupt controller.
- (4) Set the internal resource to the operating state and set the interrupt enable bit to "enabled".
- (5) Set the ILM and I flag in the CPU to enable the reception of interrupts.
- (6) Generation of an interrupt in the internal resource triggers a hardware interrupt request.
- (7) The interrupt processing hardware saves the registers and branches to the interrupt processing program.
- (8) The interrupt processing program performs the necessary processing for the internal resource that generated the interrupt.
- (9) Release the interrupt request from the internal resource circuit.
- (10) Execute the interrupt return instruction and return to the previous program.

## (5) Hardware interrupt requests during a write to an internal resource area

Hardware interrupt requests cannot be received during a write to an internal resource area. This is to prevent misoperation of CPU interrupt processing due to an interrupt request occurring during an update of the interrupt control register in an internal resource. The internal resource area refers to the area allocated for the control and data registers of internal resources (not the I/O addressing area between 000000H and 0000FFH).



## Fig. 2.1.25 Hardware Interrupt Request During a Write to an Internal Resource Area

#### (6) Interrupt inhibiting instructions

Some  $F^2MC-16L$  instructions do not detect hardware interrupt requests. These are called interrupt inhibiting instructions. See Table 2.1.11 for details.

#### (7) Multiple interrupts

The  $F^2MC-16L$  CPU supports multiple interrupts. If, during the processing of an interrupt, a second interrupt with a higher priority level occurs, control passes to the second interrupt on completion of the currently executing instruction. Control returns to the original interrupt processing when the higher priority interrupt completes.

If an interrupt of the same or lower priority occurs during interrupt processing, the new interrupt request is held until the current interrupt completes processing (unless the ILM or I flag has been modified by an instruction).

The extended intelligent I/O service does not support overlapping operation. Any interrupt or extended intelligent I/O service request that occurs during processing of the extended intelligent I/O service is held.

#### (8) Saved registers

Figure 2.1.26 shows the order in which registers are saved on the stack.



Fig. 2.1.26 Registers Saved on the Stack

## (9) Cautions

For some internal resources, reading the control or data registers clears any interrupt request. Clearing an interrupt source by performing a read after generation of an interrupt request but before control has passed to the interrupt processing hardware causes misoperation.

Therefore, when using internal resources for which interrupt requests are cleared by register read operations, do not perform register read operations when interrupts are generated.

■ Software interrupts

## (1) Overview

The software interrupt function transfers control from the program currently executing in the CPU to a user-defined interrupt processing program on execution of a special instruction. Software interrupts are always activated by the execution of the software interrupt instruction. The CPU performs the following processing when a software interrupt occurs.

- The A, DPR, ADB, DTB, PCB, PC, and PS registers in the CPU are saved on the system stack.
- The I flag in the PS register is set to "0" to inhibit hardware interrupts.
- Execution branches to the corresponding interrupt vector.

Interrupt requests initiated by the software interrupt instruction (INT) do not have an interrupt request flag or interrupt enable flag. Executing the INT instruction always generates an interrupt request. The INT instruction does not have interrupt levels. Accordingly, the INT instruction does not modify ILM. Instead the instruction sets the I flag to "0" to hold any subsequent interrupt requests.

## (2) Configuration

All software interrupt mechanisms are located in the CPU. The software interrupt instruction must be executed to use a software interrupt.

As shown in Table 2.1.12, software and hardware interrupt vectors share the same area. For example, interrupt request number INT 11 is used by both hardware interrupt #0 and software interrupt INT #11. Therefore, hardware interrupt #0 and INT #11 call the same interrupt processing routine.

### (3) Operation

On executing the software interrupt instruction, the CPU activates the software interrupt processing microcode. After saving the A, DPR, ADB, DTB, PCB, PC, and PS registers (12 bytes) to the memory area specified by SSB and SSP, the software interrupt processing microcode reads the 3-byte interrupt vector and loads the vector to PC and PCB, sets the I flag to "0" and the S flag to "1", then executes branch processing. As a result, the next executed instruction is the user-defined interrupt processing program.

Figure 2.1.27 shows the flow of processing from the generation of a software interrupt until the interrupt request is completed by the interrupt processing program.



## Fig. 2.1.27 Steps from Generation to Release of a Software Interrupt

- (1) A software interrupt instruction is executed.0
- (2) The microcode for the software interrupt instruction saves the dedicated registers.
- (3) Interrupt processing completes on execution of the RETI instruction in the user interrupt processing routine.

### (4) Cautions

When the program bank register (PCB) is FFH, the vector area for the CALLV instruction overlaps the table for the INT #vct8 instruction. Take note of the address overlap of the CALLV and INT #vct8 instructions when developing software.

Extended intelligent I/O service (EI<sup>2</sup>OS)

The EI<sup>2</sup>OS function automatically transfers data between I/O and memory. The function provides DMAstyle I/O data handling and replaces I/O data handling by interrupt processing programs. The function has the following advantages over interrupt processing.

- No data transfer program is required. This reduces total program size.
- Data transfer does not use internal registers. This increases transfer speed because register saving is not required.
- The I/O can stop data transfer as required. This eliminates unnecessary data transfer.
- Incrementing or no-change of the buffer address can be selected.
- Incrementing or no-change of the I/O register address can be selected.

On completion, EI<sup>2</sup>OS sets the completion conditions then automatically branches to an interrupt processing routine. This allows the user to determine the completion conditions.

To implement EI<sup>2</sup>OS, hardware is distributed between two locations. The blocks have the following registers and descriptors.

Interrupt control register
 Located in the interrupt controller. Specifies the ISD address.
 Extended intelligent I/O service descriptor (ISD)
 Located in RAM. Holds the transfer mode, I/O address, transfer count, and buffer address.

Figure 2.1.28 shows an overview of the extended intelligent I/O service.



## Fig. 2.1.28 Overview of the Extended Intelligent I/O Service

**Note:** The area that can be specified by IOA is 000000H to 00FFFFH. The area that can be specified by BAP is 000000H to FFFFFFH. The maximum transfer count that can be specified by DCT is 65536.

■ Interrupt control registers (ICR00 to 15)

The interrupt control registers are located in the interrupt controller and are provided for each I/O that has an interrupt function. See 2.2.3 "Interrupt Vector Allocation" for details on interrupts and ICRs. The registers perform the following three functions.

- Sets the interrupt level for the corresponding internal resource.
- Selects whether the corresponding internal resource uses a standard interrupt or the extended intelligent I/O service.
- Selects the extended intelligent I/O service channel.

Do not access these registers using read-modify-write instructions as this can cause misoperation.

Figure 2.1.29 shows the bit structure of the interrupt control registers.



Note: ICS3 to 0 are only meaningful when El<sup>2</sup>OS is active. Set ISE to "1" when using El<sup>2</sup>OS and set ISE to "0" when not using El<sup>2</sup>OS. Any values can be set to ICS3 to 0 if El<sup>2</sup>OS is not used.

## Fig. 2.1.29 Interrupt Control Registers (ICR)

[Bits 2 to 0] IL0, IL1, IL2: Interrupt level setting bits

The interrupt level setting bits specify the interrupt level of the corresponding internal resource. The bits are readable and writable. The bits are initialized to level 7 (no interrupt) by a reset. Table 2.1.13 lists the relationship between the interrupt level setting bits and each interrupt level.

| IL2 | IL1 | IL0 | Level                       |  |  |  |
|-----|-----|-----|-----------------------------|--|--|--|
| 0   | 0   | 0   | 0 (Highest interrupt level) |  |  |  |
| 0   | 0   | 1   | 1                           |  |  |  |
| 0   | 1   | 0   | 2                           |  |  |  |
| 0   | 1   | 1   | 3                           |  |  |  |
| 1   | 0   | 0   | 4                           |  |  |  |
| 1   | 0   | 1   | 5 🕴                         |  |  |  |
| 1   | 1   | 0   | 6 (Lowest interrupt level)  |  |  |  |
| 1   | 1   | 1   | 7 (No interrupt)            |  |  |  |

| Table 2.1.13         Correspondence         Between         Interrupt         Level |  |
|-------------------------------------------------------------------------------------|--|
| Setting Bits and Interrupt Levels                                                   |  |

[Bit 3] ISE: Extended intelligent I/O service enable bit

The EI<sup>2</sup>OS enable bit. The processor activates EI<sup>2</sup>OS if ISE is "1" when an interrupt occurs. If the ISE bit is "0", the processor activates the interrupt sequence. The bit is readable and writable. The ISE bit changes to "0" when EI<sup>2</sup>OS completes (count completion or completion by the internal resource). If the internal resource does not have an EI<sup>2</sup>OS function, set the ISE bit to "0" by software.

The ISE bit is initialized to "0" by a reset.

[Bits 7 to 4] ICS3 to 0: Extended intelligent I/O service channel select bits

The EI<sup>2</sup>OS channel select bits specify the EI<sup>2</sup>OS channel. The bits are write-only. The value set in ICS determines the address of the extended intelligent I/O service descriptor (ISD). ICS is initialized to "0000" by a reset.

Table 2.1.14 lists the correspondence between ICS, the channel number, and the descriptor address.

| ICS3 | ICS2 | ICS1 | ICS0 | Channel | Descriptor Address |
|------|------|------|------|---------|--------------------|
| 0    | 0    | 0    | 0    | 0       | 000100н            |
| 0    | 0    | 0    | 1    | 1       | 000108н            |
| 0    | 0    | 1    | 0    | 2       | 000110н            |
| 0    | 0    | 1    | 1    | 3       | 000118н            |
| 0    | 1    | 0    | 0    | 4       | 000120н            |
| 0    | 1    | 0    | 1    | 5       | 000128н            |
| 0    | 1    | 1    | 0    | 6       | 000130н            |
| 0    | 1    | 1    | 1    | 7       | 000138н            |
| 1    | 0    | 0    | 0    | 8       | 000140н            |
| 1    | 0    | 0    | 1    | 9       | 000148н            |
| 1    | 0    | 1    | 0    | 10      | 000150н            |
| 1    | 0    | 1    | 1    | 11      | 000158н            |
| 1    | 1    | 0    | 0    | 12      | 000160н            |
| 1    | 1    | 0    | 1    | 13      | 000168н            |
| 1    | 1    | 1    | 0    | 14      | 000170н            |
| 1    | 1    | 1    | 1    | 15      | 000178н            |

 Table 2.1.14 Correspondence Between ICS, Channel Number, and Descriptor Address

[Bits 5, 4] S1, S0: Extended intelligent I/O service status

The extended intelligent I/O service status bits can be referenced to determine the operation status and completion status of EI<sup>2</sup>OS. The bits are read-only. The bits are initialized to "00" by a reset.

Table 2.1.15 lists the relationship between the S bits and EI<sup>2</sup>OS status.

| S1 | S0 | El <sup>2</sup> OS Status                     |
|----|----|-----------------------------------------------|
| 0  | 0  | EI2OS active or inactive                      |
| 0  | 1  | Stopped due to count completion               |
| 1  | 0  | Reserved                                      |
| 1  | 1  | Stopped by request from the internal resource |

Table 2.1.15 S Bits and El<sup>2</sup>OS Status

□ Extended intelligent I/O service descriptor (ISD)

The extended intelligent I/O service descriptors are located in internal RAM between 000100H to 00017FH. ISD consist of the following items.

- Various control data for data transfer
- Status data
- Buffer address pointer

Figure 2.1.30 shows the structure of the extended intelligent I/O service descriptor.

|                                        | Data counter (upper 8 bits)            | (DCTH) | Н |
|----------------------------------------|----------------------------------------|--------|---|
|                                        | Data counter (lower 8 bits)            | (DCTL) | Î |
|                                        | 3I/O address pointer (upper 8 bits)    | (IOAH) |   |
|                                        | I/O address pointer (lower 8 bits)     | (IOAL) |   |
|                                        | El <sup>2</sup> OS status              | (ISCS) |   |
|                                        | Buffer address pointer (upper 8 bits)  | (BAPH) |   |
|                                        | Buffer address pointer (middle 8 bits) | (BAPM) |   |
| 000100H + 8 × ICS<br>ISD top address → | Buffer address pointer (lower 8 bits)  | (BAPL) | L |
|                                        |                                        |        |   |

Fig. 2.1.30 Structure of the Extended Intelligent I/O Service Descriptor

O Data counter (DCT)

A 16-bit register used as a counter for the number of data transferred. The counter is decremented by one before each data transfer. EI<sup>2</sup>OS completes when this counter reaches zero. Figure 2.1.31 shows the structure of the data counter.



## Fig. 2.1.31 Data Counter Structure

O I/O register address pointer (IOA)

A 16-bit register that indicates the lower 16 bits (A15 to A0) of the address of the I/O register for data transfer to or from the buffer. The upper address (A23 to A16) is all zeros. This allows I/O to be specified anywhere between locations 000000H and 00FFFFH. Figure 2.1.32 shows the structure of IOA.



## Fig. 2.1.32 Structure of the I/O Register Address Pointer

O EI<sup>2</sup>OS status register (ISCS)

An 8-bit register that specifies whether the buffer address pointer and I/O register address pointer are updated or fixed, the transfer data length (byte or word), and the transfer direction. Figure 2.1.33 shows the structure of ISCS.



## Fig. 2.1.33 ISCS Structure

The meaning of each bit is as follows.

[Bit 4] IF: Specifies whether the I/O register address pointer is updated or fixed.

0:Update the I/O register address pointer after data transfer. 1:Do not update the I/O register address pointer after data transfer. **Note :**Only incrementing is available.

[Bit 3] BW: Specifies the data transfer length

0:Byte 1:Word

[Bit 2] BF: Specifies whether the buffer address pointer is updated or fixed.

0:Update the buffer address pointer after data transfer.
1:Do not update the buffer address pointer after data transfer.
Note:Updating changes only the lower 16 bits of the buffer address pointer. Only incrementing is available.

[Bit 1] DIR: Specifies the data transfer direction.

0:I/O address pointer  $\rightarrow$  Buffer address pointer 1:Buffer address pointer  $\rightarrow$  I/O address pointer

[Bit 0] SE: Controls completion of the extended intelligent I/O service by request from the internal resource.

0:Do not terminate on request from the internal resource.

1 :Terminate on request from the internal resource.

□ Buffer address pointer (BAP)

A 24-bit register that stores the address to use for the next EI<sup>2</sup>OS transfer. As a separate BAP is provided for each EI<sup>2</sup>OS channel, each EI<sup>2</sup>OS channel can perform data transfer to any location in the 16MB memory space. If updating is specified by the BF bit in ISCS, the lower 16 bits only of BAP are updated and BAPH does not change.

Figure 2.1.34 shows the structure of BAP.



## Fig. 2.1.34 Structure of the Buffer Address Pointer

Figure 2.1.35 shows the operation flow of EI<sup>2</sup>OS. Figure 2.1.36 shows the procedure for using EI<sup>2</sup>OS.



Fig. 2.1.35 El<sup>2</sup>OS Operation Flow



Fig. 2.1.36 Procedure for Using El<sup>2</sup>OS

#### Exception processing

The F<sup>2</sup>MC-16L generates exceptions in the following cases and performs exception processing.

#### (1) Execution of an undefined instruction

In principle, exception processing is the same as interrupt processing. When an exception is detected at an instruction boundary, control passes from standard processing to exception processing. In general, as exception processing occurs as a result of an unexpected operation, it is recommended that exception processing only be used for purposes such as debugging or to activate emergency recovery software.

Generation of an exception by execution of an undefined instruction

The F<sup>2</sup>MC-16L treats all codes not defined in the instruction map as undefined instructions. Executing an undefined instruction triggers the same processing as executing the software interrupt instruction "INT 10". That is, AL, AH, DPR, DTB, ADB, PCB, PC, and PS are saved on the system stack, the I flag is set to "0" and the S flag to "1", and execution branches to the program specified by the vector for interrupt 10. The value of PC saved on the stack contains the address of the undefined instruction. For instruction codes of 2 bytes or more, the PC value on the stack contains the address of the code that was recognized as undefined. Therefore, although returning by the RETI instruction is possible, this is meaningless as it only triggers another exception.

## 2.1.5 Standby Control Register Access

The device is set to the low power modes (stop mode or sleep mode) by writing to the low power mode control register. In this case, use one of the instructions listed in Table 2.1.16. Correct operation cannot be guaranteed if you change to a low power mode using an instruction other than the instructions listed in Table 2.1.16. However, any instruction can be used on the low power mode control register when controlling functions other than changing to a low power mode.

Always write to an even-numbered address when performing a word-length write to the low power mode control register. Changing to a low power mode by writing to an odd-numbered address may cause misoperation.

| MOV io,#imm8      | MOV dir,#imm8   | MOV eam,#imm8   | MOV eam,Ri   |
|-------------------|-----------------|-----------------|--------------|
| MOV io,A          | MOV dir,A       | MOV addr16,A    | MOV eam,A    |
| MOV @RLi+disp8,A  | MOVP addr24,A   |                 |              |
| MOVW io,#imm16    | MOVW dir,#imm16 | MOVW eam,#imm16 | MOVW eam,RWi |
| MOVW io,A         | MOVW dir,A      | MOVW addr16,A   | MOVW eam,A   |
| MOVW @RLi+disp8,A | MOVPW addr24,A  |                 |              |
| SETB io:bp        | SETB dir:bp     | SETB addr16:bp  |              |

## Table 2.1.16 Instructions to Use When Changing to a Low Power Mode

# 2.2 Map

This section describes the allocation of memory space, I/O space, and interrupt numbers in the MB90610A.

# 2.2.1 Memory Space for Each Mode

Figure 2.2.1 shows the MB90610A memory space. Only external ROM/external bus mode is available.



### Fig. 2.2.1 Memory Space Allocation for Each MB90610A Mode

**Note:** When output of the upper address (A23 to A16) is disabled, the MB90610A series can only access a maximum of 64KB.

## 2.2 Map

# 2.2.2 I/O Map

The following shows the MB90610A I/O map.

| Address               | Register                                     | Abbreviation | Access | Resource<br>Name | Initial Value |
|-----------------------|----------------------------------------------|--------------|--------|------------------|---------------|
| 00000н                | Free                                         |              | Note 3 |                  |               |
| 000001н               | Port 1 data register                         | PDR1         | R/W*   | Port 1 Note 8    | XXXXXXXX      |
| 000002н               | Port 2 data register                         | PDR2         | R/W*   | Port 2 Note 7    | XXXXXXXX      |
| 00003н                | Port 3 data register                         | PDR3         | R/W*   | Port 3 Note 7    | XXXXXXXX      |
| 000004н               | Port 4 data register                         | PDR4         | R/W    | Port 4           | XXXXXXXX      |
| 000005н               | Port 5 data register                         | PDR5         | R/W    | Port 5           | XXXXXX        |
| 00006н                | Port 6 data register                         | PDR6         | R/W    | Port 6           | 11111111      |
| 000007н               | Port 7 data register                         | PDR7         | R/W    | Port 7           | -XXXXXXX      |
| 00008н                | Port 8 data register                         | PDR8         | R/W    | Port 8           | -XXXXXXX      |
| 00009н                | Port 9 data register                         | PDR9         | R/W    | Port 9           | XXXXXX        |
| 00000Ан               | Port A data register                         | PDRA         | R/W    | Port A           | XXXXXXX-      |
| 00000Bн to<br>000010н | Free                                         |              | Note 3 |                  |               |
| 000011н               | Port 1 direction register                    | DDR1         | R/W*   | Port 1 Note 8    | 00000000      |
| 000012н               | Port 2 direction register                    | DDR2         | R/W*   | Port 2 Note 7    | 00000000      |
| 000013н               | Port 3 direction register                    | DDR3         | R/W*   | Port 3 Note 7    | 00000000      |
| 000014н               | Port 4 direction register                    | DDR4         | R/W    | Port 4           | 00000000      |
| 000015н               | Port 5 direction register                    | DDR5         | R/W    | Port 5           | 000000        |
| 000016н               | Analog input enable register                 | ADER         | R/W    | Port 6           | 11111111      |
| 000017н               | Port 7 direction register                    | DDR7         | R/W    | Port 7           | -0000000      |
| 000018н               | Port 8 direction register                    | DDR8         | R/W    | Port 8           | -0000000      |
| 000019н               | Port 9 direction register                    | DDR9         | R/W    | Port 9           | 000000        |
| 00001Ан               | Port A direction register                    | DDRA         | R/W    | Port A           | 000000-       |
| 00001Bн to<br>00001Fн | Free                                         |              | Note 3 |                  |               |
| 000020н               | Mode register 0                              | SMR0         | R/W!   |                  | 00000000      |
| 000021н               | Control register 0                           | SCR0         | R/W!   |                  | 00000100      |
| 000022н               | Input data register 0/Output data register 0 | SIDR0/SODR0  | R/W    | UART0 (SCI)      | xxxxxxx       |
| 000023н               | Status register 0                            | SSR0         | R/W!   |                  | 00001-00      |
| 000024н               | Mode register 1                              | SMR1         | R/W!   |                  | 00000000      |
| 000025н               | Control register 1                           | SCR1         | R/W!   |                  | 00000100      |
| 000026н               | Input data register 1/Output data register 1 | SIDR1/SODR1  | R/W    | UART1 (SCI)      | xxxxxxx       |
| 000027н               | Status register 1                            | SSR1         | R/W!   | 7                | 00001-00      |

# Table 2.2.2 MB90610A I/O Map (1)

| Address               | Register                                             | Abbreviation | Access      | Resource<br>Name | Initial Value |
|-----------------------|------------------------------------------------------|--------------|-------------|------------------|---------------|
| 000028н               | Interrupt/DTP enable register                        | ENIR         | R/W         |                  | 00000000      |
| 000029н               | Interrupt/DTP source register                        | EIRR         | R/W         | DTP/External     | 00000000      |
| 00002Ан               | Interrupt lovel actting register                     |              | R/W         | interrupt        | 00000000      |
| 00002Вн               | <ul> <li>Interrupt level setting register</li> </ul> | ELVR         | R/VV        |                  | 00000000      |
| 00002Сн               | AD control status register                           | ADCS         | R/W!        |                  | 00000000      |
| 00002Dн               |                                                      | ADCS         | R/VV!       | A/D converter    | 00000000      |
| 00002Ен               | AD data register ADCR R/W! Note 4                    |              |             | XXXXXXXX         |               |
| 00002Fн               | AD data register                                     | ADOK         | N/W! NOLE 4 |                  | 000000XX      |
| 000030н               | PPG0 operation mode control register                 | PPGC0        | R/W         | PPG0             | 000000-1      |
| 000031н               | PPG1 operation mode control register                 | PPGC1        | R/W         | PPG1             | 000000-1      |
| 000032н to<br>000033н | Free                                                 |              | Note 3      |                  |               |
| 000034н               | DDC0 relead register                                 | PRL0         | R/W         | PPG0             | XXXXXXXX      |
| 000035н               | <ul> <li>PPG0 reload register</li> </ul>             | PRLU         | R/VV        | PPG0             | XXXXXXXX      |
| 000036н               | DBC1 relead register                                 | PRL1         | R/W         | PPG1             | XXXXXXXX      |
| 000037н               | <ul> <li>PPG1 reload register</li> </ul>             | PRLI         | R/VV        | PPGI             | XXXXXXXX      |
| 000038н               | Control status register                              | TMCSR0       | R/W!        |                  | 00000000      |
| 000039н               | <ul> <li>Control status register</li> </ul>          | TNCSRU       | R/VV!       | 16-bit reload    | 0000          |
| 00003Ан               | 16-bit timer register/16-bit reload                  | TMR0/TMRLR0  | R/W         | timer 0          | XXXXXXXX      |
| 00003Вн               | register                                             |              | 10/00       |                  | XXXXXXX       |
| 00003Сн               | <ul> <li>Control status register</li> </ul>          | TMCSR1       | R/W!        |                  | 00000000      |
| 00003Dн               | Control status register                              | IMCORT       | 10/00:      | 16-bit reload    | 0000          |
| 00003Ен               | 16-bit timer register/16-bit reload                  | TMR1/TMRLR1  | R/W         | timer 1          | XXXXXXXX      |
| 00003Fн               | register                                             |              | 10,00       |                  | XXXXXXXX      |
| 000040н to<br>000043н | Free                                                 |              | Note 3      |                  |               |
| 000044н               | Mode register 2                                      | SMR2         | R/W!        |                  | 00000000      |
| 000045н               | Control register 2                                   | SCR2         | R/W!        |                  | 00000100      |
| 000046н               | Input data register 2/Output data register 2         | SIDR2/SODR2  | R/W         | UART2 (SCI)      | xxxxxxx       |
| 000047н               | Status register 2                                    | SSR2         | R/W!        |                  | 00001-00      |
| 000048н               | CS control register 0                                | CSCR0        | R/W         |                  | 0000          |
| 000049н               | CS control register 1                                | CSCR1        | R/W         |                  | 0000          |
| 00004Ан               | CS control register 2                                | CSCR2        | R/W         |                  | 0000          |
| 00004Вн               | CS control register 3                                | CSCR3        | R/W         | Chip select      | 0000          |
| 00004Сн               | CS control register 4                                | CSCR4        | R/W         | function         | 0000          |
| 00004Dн               | CS control register 5                                | CSCR5        | R/W         |                  | 0000          |
| 00004Ен               | CS control register 6                                | CSCR6        | R/W         |                  | 0000          |
| 00004Fн               | CS control register 7                                | CSCR7        | R/W         |                  | 0000          |

Table 2.2.2 MB90610A I/O Map (3)

| Address               | Register                                                  | Abbreviation | Access | Resource<br>Name                           | Initial Value |
|-----------------------|-----------------------------------------------------------|--------------|--------|--------------------------------------------|---------------|
| 000050н               | Free                                                      |              | Note 3 |                                            |               |
| 000051н               | UART0 (SCI) machine clock<br>divide-by-n control register | CDCR0        | w      | UART0 (SCI)                                | 1111          |
| 000052н               | Free                                                      |              | Note 3 |                                            |               |
| 000053н               | UART1 (SCI) machine clock<br>divide-by-n control register | CDCR1        | w      | UART1 (SCI)                                | 1111          |
| 000054н               | Free                                                      |              | Note 3 |                                            |               |
| 000055н               | UART2 (SCI) machine clock<br>divide-by-n control register | CDCR2        | w      | UART2 (SCI)                                | 1111          |
| 000056н to<br>00008Fн | Free                                                      |              | Note 3 |                                            |               |
| 000090н to<br>00009Ен | Reserved system area                                      |              | Note 1 |                                            |               |
| 00009Fн               | Delay interrupt generate/<br>release register             | DIRR         | R/W    | Delay<br>interrupt<br>generation<br>module | 0             |
| 0000А0н               | Low power mode control register                           | LPMCR        | R/W!   | Low power consumption                      | 00011000      |
| 0000А1н               | Clock selection register                                  | CKSCR        | R/W!   | Low power consumption                      | 11111100      |
| 0000А2н to<br>0000А4н | Free                                                      |              | Note 3 |                                            |               |
| 0000А5н               | Auto-ready function selection register                    | ARSR         | w      | External pins                              | 001100        |
| 0000А6н               | External address output control register                  | HACR         | w      | External pins                              | 00000000      |
| 0000А7н               | Bus control signal selection register                     | ECSR         | w      | External pins                              | -00*0000      |
| 0000А8н               | Watchdog timer control register                           | WDTC         | R/W!   | Watchdog<br>timer                          | XXXXX111      |
| 0000А9н               | Timebase timer control register                           | твтс         | R/W!   | Timebase<br>timer                          | 100100        |
| 0000ААн to<br>0000АFн | Free                                                      |              | Note 3 |                                            |               |

| Address               | Register                      | Abbreviation | Access | Resource<br>Name | Initial Value |
|-----------------------|-------------------------------|--------------|--------|------------------|---------------|
| 0000В0н               | Interrupt control register 00 | ICR00        | R/W!   |                  | 00000111      |
| 0000B1н               | Interrupt control register 01 | ICR01        | R/W!   | -                | 00000111      |
| 0000В2н               | Interrupt control register 02 | ICR02        | R/W!   |                  | 00000111      |
| 0000В3н               | Interrupt control register 03 | ICR03        | R/W!   |                  | 00000111      |
| 0000В4н               | Interrupt control register 04 | ICR04        | R/W!   |                  | 00000111      |
| 0000В5н               | Interrupt control register 05 | ICR05        | R/W!   |                  | 00000111      |
| 0000В6н               | Interrupt control register 06 | ICR06        | R/W!   |                  | 00000111      |
| 0000 <b>B7</b> н      | Interrupt control register 07 | ICR07        | R/W!   |                  | 00000111      |
| 0000В8н               | Interrupt control register 08 | ICR08        | R/W!   | Interrupt        | 00000111      |
| 0000В9н               | Interrupt control register 09 | ICR09        | R/W!   | controller       | 00000111      |
| 0000ВАн               | Interrupt control register 10 | ICR10        | R/W!   |                  | 00000111      |
| 0000ВВн               | Interrupt control register 11 | ICR11        | R/W!   |                  | 00000111      |
| 0000ВСн               | Interrupt control register 12 | ICR12        | R/W!   |                  | 00000111      |
| 0000BDн               | Interrupt control register 13 | ICR13        | R/W!   |                  | 00000111      |
| 0000ВЕн               | Interrupt control register 14 | ICR14        | R/W!   | -                | 00000111      |
| 0000BFн               | Interrupt control register 15 | ICR15        | R/W!   |                  | 00000111      |
| 0000C0н to<br>0000FFн | External area Note 2          |              |        |                  |               |

## Table 2.2.2 MB90610A I/O Map (4)

Note 1: Access prohibited.

- **Note 2:** This is the only external access area in the area below address 0000FFH. Access this address as an external I/O area.
- **Note 3:** Areas marked as "free" in the I/O map are reserved areas. These areas are accessed by internal access. No access signals are output on the external bus.
- **Note 4:** Only bit 15 can be written. The other bits are written to by the test function. Reading bits 10 to15 returns zeros.
- **Note 5:** The R/W! symbol in the access column indicates that some bits are read-only or write-only. See the resource's register list for details.
- **Note 6:** Using a read-modify-write instruction (such as the bit set instruction) to access one of the registers indicated by R/W!, R/W\*, or W in the access column sets the specified bit to the desired value. However, this can cause misoperation if the other register bits include write-only bits. Therefore, do not use read-modify-write instructions to access these registers.
- **Note 7:** This register is only available when the address/data bus is in multiplex mode. Access to the register is prohibited in non-multiplex mode.
- **Note 8:** This register is only available when the external data bus is in 8-bit mode. Access to the register is prohibited in 16-bit mode.

Initial values

- 0: The initial value for this bit is zero.
- 1: The initial value for this bit is one.
- \*: The initial value for this bit is one or zero. (Determined by the level of the MD0 to 2 pins.)
- X: The initial value for this bit is indeterminate.
- -: This bit is not used. The initial value is indeterminate.
- **Note:** The initial values listed for write-only bits are the initial values set by a reset. They are not the values returned by a read.

Also, LPMCR, CKSCR, and WDTC are sometimes initialized and sometimes not initialized, depending on the reset type. The listed initial values are for when these registers are initialized.

#### 2.2 Map

# 2.2.3 Interrupt Vector Allocation

The following shows the interrupt vector allocation in the MB90610A.

| Interrupt                         | l <sup>2</sup> OS<br>Support |     | Interrup | t vector | Interrupt Control<br>Register |         |  |
|-----------------------------------|------------------------------|-----|----------|----------|-------------------------------|---------|--|
|                                   | Support                      | Nu  | mber     | Address  | ICR                           | Address |  |
| Reset                             | ×                            | #08 | 08н      | FFFFDCH  | -                             | -       |  |
| INT 9 instruction                 | ×                            | #09 | 09н      | FFFFD8H  | -                             | -       |  |
| Exception                         | ×                            | #10 | 0Ан      | FFFFD4H  | -                             | -       |  |
| External interrupt #0             | 0                            | #11 | 0Вн      | FFFFD0H  | ICR00                         | 0000В0н |  |
| External interrupt #1             | 0                            | #13 | 0DH      | FFFFC8H  | ICR01                         | 0000В1н |  |
| External interrupt #2             | 0                            | #15 | 0FH      | FFFFC0H  | ICR02                         | 0000В2н |  |
| External interrupt #3             | 0                            | #17 | 11н      | FFFFB8H  | ICR03                         | 0000В3н |  |
| External interrupt #4             | 0                            | #19 | 13H      | FFFFB0H  | ICR04                         | 0000В4н |  |
| External interrupt #5             | 0                            | #21 | 15H      | FFFFA8H  | ICR05                         | 0000В5н |  |
| External interrupt #6             | 0                            | #23 | 17H      | FFFFA0H  | ICR06                         | 0000000 |  |
| UART0 transmit complete           | 0                            | #24 | 18H      | FFFF9CH  | ICRUD                         | 0000В6н |  |
| External interrupt #7             | 0                            | #25 | 19н      | FFFF98H  |                               | 0000070 |  |
| UART1 transmit complete           | 0                            | #26 | 1Ан      | FFFF94H  | ICR07                         | 0000В7н |  |
| PPG #0                            | ×                            | #27 | 1Вн      | FFFF90H  | ICR08                         | 0000000 |  |
| PPG #1                            | ×                            | #28 | 1Сн      | FFFF8CH  | ICRUO                         | 0000В8н |  |
| 16-bit reload timer #0            | 0                            | #29 | 1DH      | FFFF88H  | ICR09                         |         |  |
| 16-bit reload timer #1            | 0                            | #30 | 1Ен      | FFFF84H  | ICRU9                         | 0000В9н |  |
| A/DC measurement complete         | 0                            | #31 | 1FH      | FFFF80H  | ICR10                         | 0000ВАн |  |
| UART2 transmit complete           | 0                            | #33 | 21н      | FFFF78H  | ICR11                         |         |  |
| Timebase timer interval interrupt | ×                            | #34 | 22н      | FFFF74H  | ICRII                         | 0000ВВн |  |
| UART2 receive complete            | 0                            | #35 | 23н      | FFFF70H  | ICR12                         | 0000BCH |  |
| UART1 receive complete            | 0                            | #37 | 25н      | FFFF68H  | ICR13                         | 0000BDH |  |
| UART0 receive complete            | 0                            | #39 | 27н      | FFFF60H  | ICR14                         | 0000ВЕн |  |
| Delay interrupt generation module | ×                            | #42 | 2Ан      | FFFF54H  | ICR15                         | 0000BFH |  |

Table 2.2.3 MB90610A Interrupt Vector Allocation

Note: O indicates I<sup>2</sup>OS support (no stop request), <sup>●</sup> indicates I<sup>2</sup>OS support (with stop request), and × indicates no I<sup>2</sup>OS support. Do not set I<sup>2</sup>OS activation in ICRXX for resources that do not support I<sup>2</sup>OS.

# 2.2.4 Clock Supply Map



Fig. 2.2.2 Clock Supply Map

## 2.3 Parallel Ports

The MB90610A has 58 I/O pins, 18 output pins, and 8 open drain output pins.

Ports 1 to 5 and ports 7 to A are I/O ports. The ports are inputs when the corresponding direction register bit is "0" and outputs when the corresponding bit is "1".

Port 1 is only available when the external data bus is in 8-bit mode. Access is prohibited in 16-bit mode. Ports 2 and 3 are only available when the address/data bus is in multiplex mode. Access is prohibited in non-multiplex mode.

Port 6 is an open drain port. Port 6 can only be used as a port when the analog input enable register is "0".

## 2.3.1 Registers





```
Note: No register bits are provided for bits 6 and 7 of port 5.
No register bit is provided for bit 7 of port 7.
No register bit is provided for bit 7 of port 8.
No register bits are provided for bits 6 and 7 of port 9.
No register bit is provided for bit 0 of port A.
```



#### 2.3 Parallel Ports

Note: No register bits are provided for bits 6 and 7 of port 5. No register bit is provided for bit 7 of port 7. No register bit is provided for bit 7 of port 8. No register bits are provided for bits 6 and 7 of port 9. No register bit is provided for bit 0 of port A. Port 6 does not have a DDR.

| Analog input enable register    | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 🗇 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| ADER 000016H                    | ADE7         | ADE6         | PADE5        | ADE4         | ADE3         | ADE2         | ADE1         | ADE0         | ADER      |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(1) |           |

## 2.3.2 Block Diagram

## ■ I/O ports



## Fig. 2.3.1 I/O Port Block Diagram

■ Open drain port (Also used as analog inputs)



Fig. 2.3.2 Open Drain Port Block Diagram

## 2.3.3 Register Details

#### (1) PDR1, 2, 3, 4, 5, 7, 8, 9, A (Port data registers)

Register layout



Note: No register bits are provided for bits 6 and 7 of port 5. No register bit is provided for bit 7 of port 7. No register bit is provided for bit 7 of port 8. No register bits are provided for bits 6 and 7 of port 9. No register bit is provided for bit 0 of port A.

Port 1 is only available when the external data bus is in 8-bit mode. Access is prohibited in 16-bit mode.

Ports 2 and 3 are only available in multiplex mode. Access is prohibited in non-multiplex mode.

Register contents

When the pins on ports other than port 6 are not set as output pins for their respective peripherals, each pin can be individually specified as either an input or an output by setting the direction register. When specified as inputs, reading the data register reads the levels applied to the pins. When specified as outputs, reading the data register reads the data register latch value. The same applies when reading as part of a read-modify-write.

When used as control outputs, reading the data register reads the control output value, irrespective of the direction register value.

#### 2.3 Parallel Ports

- **Note:** Accessing these registers using a read-modify-write instruction (bit setting and similar instructions) sets the specified bit to the desired value. However, if the other register bits include bits set as inputs, the output register values for these bits are overwritten with the current input values at the pins. Therefore, when switching a pin from input to output, write the desired value to the PDR before setting the bit as an output in the DDR.
- Note: Reading and writing to I/O ports differs from reading and writing to memory as follows.
  - ▷ Input mode

Reading: The read value is the level at the corresponding pin.Writing: The write data is stored in the output latch. The data is not output to the pin.

- Output mode
   Reading: The read value is the value stored in the PDR.
   Writing: The write data is stored in the output latch and output to the pin.
- Note: Note that the R/W operation for port 6 differs from other ports.

Port 6 (P67 to P60) is a general-purpose I/O port with open drain outputs. The port shares pins with the analog inputs. Always set the corresponding ADER bit to "0" when using as a general-purpose port. When using port 6 as an input port, set the output data register value to "1" to turn off the open drain output transistor and provide a pull-up resistor to the external pin. Use one of the following two operations for reading, depending on the instruction used.

- Reading using a read-modify-write type instruction Reads the contents of the output data register. Bits not specified by the instruction do not change, even if the pin is forcibly driven to "0" from outside the device.
- Reading using other instructions Reads the pin level.

When used as an output port, writing the desired value to the corresponding output data register changes the pin value.

Reading always returns "0" for pins for which the corresponding bit in the analog input enable register is set to "1".

## (2) DDR1, 2, 3, 4, 5, 7, 8, 9, A (Port direction registers)

#### Register layout

| Port direct | tion registers                               |              |              |              |              |              |                 |              |              |                            |           |
|-------------|----------------------------------------------|--------------|--------------|--------------|--------------|--------------|-----------------|--------------|--------------|----------------------------|-----------|
| Address:    | DDR1 000011H<br>DDR3 000013H                 | 1            | 5 1          | 4 1          | 3 1          | 2 1          | 11 1            | -            | 9            | ° ⇔                        | Bit No.   |
|             | DDR5 000015H<br>DDR7 000017H<br>DDR9 000019H | DDx7         | DDx6         | DDx5         | DDx4         | DDx3         | DDx2            | DDx1         | DDx0         | ŧ <u>́</u> ́́́́́́́́́·́···· | - DDRx    |
|             | Read/write ⇔                                 | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0)    | (R/W)<br>(0) | (R/W)<br>(0) | ∔╧╸╸╸                      |           |
| Port dire   | ection registers                             | (0)          | 7            | 6            | 5            | 4            | 3               | 2            | 1            | 0                          | ⇔ Bit No. |
| Address:    | DDR2 000012H<br>DDR4 000014H                 | · · · ·      | <u> </u>     |              | 1            | <u> </u>     | 1               | 1            |              |                            |           |
|             | DDR8 000018H<br>DDRA 00001AH                 | DD           | 0x7 DD       | x6 DD        | 0x5 DD       | 0x4 DE       | Dx3 DD          | Dx2 DD       | Dx1 DE       | Dx0                        | DDRx      |
|             | Read/write ⇔<br>Initial value ⇔              | (R/<br>(0    | ,            | / ( ·        | / / ·        | / ( ·        | W) (R/<br>D) (0 | , ( )        | / / ·        | /W)<br>D)                  |           |

Note: No register bits are provided for bits 6 and 7 of port 5.
No register bit is provided for bit 7 of port 7.
No register bit is provided for bit 7 of port 8.
No register bit is provided for bit 0 of port A.
No register bits are provided for bits 6 and 7 of port 9.
Port 6 does not have a DDR.

Port 1 is only available when the external data bus is in 8-bit mode. Access is prohibited in 16-bit mode.

Ports 2 and 3 are only available in multiplex mode. Access is prohibited in non-multiplex mode.

#### ■ Register contents

When pins are used as ports, the register bits control the corresponding pins as follows.

- 0: Input mode
- 1: Output mode

Bits are set to "0" by a reset.

### (3) ADER (Analog input enable register)

| Analog input enable register    | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 🗢 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| ADER 000016H                    | ADE7         | ADE6         | PADE5        | ADE4         | ADE3         | ADE2         | ADE1         | ADE0         | ADER      |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(1) |           |

■ Register contents

Controls each pin of port 6 as follows.

0: Port input mode

1: Analog input mode

Bits are set to "1" by a reset.

**Note:** Inputting an intermediate level signal in port input mode causes a leak current to flow. Therefore, set to analog input mode when applying an analog input.

## 2.3.4 Port Pin Allocation

Ports 1, 4, and 5 on the MB90610A series share pins with the external bus. The bus mode and register settings select the pin functions. Table 2.3.1 lists the port pin allocation for each mode.

|                                                           |                    |               |              | Fur           | nction          |                                |               |                 |  |  |  |
|-----------------------------------------------------------|--------------------|---------------|--------------|---------------|-----------------|--------------------------------|---------------|-----------------|--|--|--|
|                                                           |                    | Non-Mult      | iplex mode   |               |                 | Multiplex mode                 |               |                 |  |  |  |
| Pin                                                       |                    | External Ad   | dress Contro | bl            |                 | External Ad                    | dress Contro  | ol              |  |  |  |
| r                                                         | Enable             | (Address)     | Disab        | le (Port)     | Enable          | Enable (Address) Disable (Port |               |                 |  |  |  |
|                                                           | External Bus Width |               | External     | Bus Width     | Externa         | I Bus Width                    | Externa       | l Bus Width     |  |  |  |
|                                                           | 8-bit              | 16-bit        | 8-bit        | 16-bit        | 8-bit           | 16-bit                         | 8-bit         | 16-bit          |  |  |  |
| D07 to D00/<br>AD07 to AD00                               | D07 to D00         |               |              |               | AD07 to A       | D00                            |               |                 |  |  |  |
| P17 to P10/D15<br>to D08/AD15 to<br>AD08PortD15 to<br>D08 | Port               | D15 to<br>D08 | Port         | D15 to<br>D08 | A15 to<br>A08   | AD15 to<br>AD08                | A15 to<br>A08 | AD15 to<br>AD08 |  |  |  |
| P27 to P20/A07<br>to A00                                  | A07 to A00         |               | A07 to A00   |               | - Port          |                                |               |                 |  |  |  |
| P37 to P30/A15<br>to A08                                  | A15 to A08         |               | A15 to A08   | 3             |                 |                                |               |                 |  |  |  |
| P47 to P40/A23<br>to A16                                  | A23 to A16         |               | Port         |               | A23 to A16 Port |                                |               |                 |  |  |  |
| ALE                                                       | ALE                |               |              |               | ALE             |                                |               |                 |  |  |  |
| RDX                                                       | RDX                |               |              |               | RDX             |                                |               |                 |  |  |  |
| P55/WRLX                                                  | WRLX               |               |              |               | WRLX            |                                |               |                 |  |  |  |
| P54/WRHX                                                  | Port               | WRHX          | Port         | WRHX          | Port            | WRHX                           | Port          | WRHX            |  |  |  |
| P53/HRQ                                                   | HRQ                |               |              |               | HRQ             |                                |               |                 |  |  |  |
| P52/HAKX                                                  | HAKX               |               |              |               | НАКХ            |                                |               |                 |  |  |  |
| P51/RDY                                                   | RDY                |               |              |               | RDY             |                                |               |                 |  |  |  |
| P50/CLK                                                   | CLK                |               |              |               | CLK             |                                |               |                 |  |  |  |

 Table 2.3.1
 Port Pin Allocation for Each Mode

**Note:** The upper address, WRLX, WRHX, HAKX, HRQ, RDY, and CLK can be set for use as ports by function selection.

# 2.4 UART 0/1/2 (SCI)

UART 0, 1, and 2 are serial I/O ports that can be used for CLK asynchronous (start-stop synchronization) or CLK synchronous (I/O expansion serial) data transfer. The ports have the following features.

- Full duplex, double buffered
- Supports CLK asynchronous (start-stop synchronization) and CLK synchronous (I/O expansion serial) data transfer
- Multiprocessor mode
- Internal dedicated baud rate generator

CLK asynchronous: 62500/31250/19230/9615/4808/2404/1202 bps CLK synchronous: 2M/1M/500K/250K bps

- Supports flexible baud rate setting using an external clock
- Error detect function (parity, framing, and overrun)
- NRZ type transfer signal
- Intelligent I/O service support

# 2.4.1 Registers

| Serial mode register                                   | 7 6 5 4 3 2 1 0 ⇔ Bit No.                                                                                                                                             |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address: ch0 000020н *<br>ch1 000024н<br>ch2 000044н - | MD1 MD0 CS2 CS1 CS0 - SCKE SOE SMR                                                                                                                                    |
| Read/write ⇔<br>Initial value ⇔                        | (R/W) (R/W) (W) (W) (-) (R/W) (R/W)<br>(0) (0) (0) (0) (0) (-) (0) (0)                                                                                                |
| Serial control register                                | 15 14 13 12 11 10 9 8 🗢 Bit No.                                                                                                                                       |
| Address: ch0 000021н<br>ch1 000025н<br>ch2 000045н     | PEN P SBL CL A/D REC RXE TXE SCR                                                                                                                                      |
| Read/write ⇔<br>Initial value ⇔                        | (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W)<br>(0) (0) (0) (0) (0) (0) (0) (0)                                                                                          |
| Input data register/<br>Output data register           | 7 6 5 4 3 2 1 0 ⇔ Bit No.                                                                                                                                             |
| Address: ch0 000022н сh1 000026н ch2 000046н .         | D7         D6         D5         D4         D3         D2         D1         D0         SIDR (read) SODR (write)                                                      |
| Read/write ⇔<br>Initial value ⇔                        | (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W)<br>(X) (X) (X) (X) (X) (X) (X) (X)                                                                                          |
| Serial status register                                 | 15 14 13 12 11 10 9 8 🖙 Bit No.                                                                                                                                       |
| Address: ch0 000023н<br>ch1 000027н<br>ch2 000047н     | PE ORE FRE RDRF TDRE - RIE TIE SSR                                                                                                                                    |
| Read/write ⇔<br>Initial value ⇔                        | (R)         (R)         (R)         (R)         (-)         (R/W)         (R/W)           (0)         (0)         (0)         (1)         (-)         (0)         (0) |
| Machine clock divide-by-r<br>control register          |                                                                                                                                                                       |
| Address: ch0 000051н<br>ch1 000053н<br>ch2 000055н     | DIV3 DIV2 DIV1 DIV0 - CDCR                                                                                                                                            |
| Read/write ⇔<br>Initial value ⇒                        | (-) (-) (-) (-) (W) (W) (W) (W)<br>(-) (-) (-) (-) (1) (1) (1) (1)                                                                                                    |

## 2.4.2 Block Diagram



Fig. 2.4.1 Overall Block Diagram

## 2.4.3 Register Details

## (1) SMR (Serial mode register)

| Serial m | ode register                              |              | 7            | 6          | 5          | 4          | 3  | 3          | 2           | 1            | 0        | 🗇 Bit No. |
|----------|-------------------------------------------|--------------|--------------|------------|------------|------------|----|------------|-------------|--------------|----------|-----------|
| Address: | сh0 000020н<br>ch1 000024н<br>ch2 000044н | MD1          | MD0          | CS2        | CS1        | CS         | 30 | -          | SCK         | E SC         |          | SMR       |
|          | Read/write ⇔<br>Initial value ⇔           | (R/W)<br>(0) | (R/W)<br>(0) | (W)<br>(0) | (W)<br>(0) | (V)<br>(0) | '  | (-)<br>(-) | (R/V<br>(0) | V) (R/<br>(C | W)<br>)) |           |

- **Note 1:** SMR specifies the operation mode of the UART. Set the operation mode while operation is halted. Do not write to this register during UART operation.
- Note 2: Do not use read-modify-write instructions to access the register as this can cause misoperation.

[Bits 7, 6] MD1, MD0 (MoDe select): Tese bits select the UART operation mode.

| Mode | MD1 | MD0 | Operation Mode                                                    |
|------|-----|-----|-------------------------------------------------------------------|
| 0    | 0   | 0   | CLK asynchronous (start-stop synchronization) Normal mode         |
| 1    | 0   | 1   | CLK asynchronous (start-stop synchronization) Multiprocessor mode |
| 2    | 1   | 0   | CLK synchronous mode                                              |
| -    | 1   | 1   | Prohibited setting                                                |

Table 2.4.1 Operation Mode Selection

**Note:** The CLK asynchronous mode, mode 1 (multiprocessor), is used when a number of slave CPUs are connected to a single host CPU. As the UART resource cannot determine the data format of the received data, "master" multiprocessor mode only is supported.

Also, as the parity check function cannot be used, set the PEN bit of the SCR register to "0".

[Bits 5, 4, 3] CS2, CS1, CS0 (Clock Select):

Selects the baud rate clock source. When the dedicated baud rate generator is selected, this also selects the baud rate.

| CS2 to CS0   | Clock Input                   |  |  |  |  |
|--------------|-------------------------------|--|--|--|--|
| 000в to 100в | Dedicated baud rate generator |  |  |  |  |
| 101в         | Reserved                      |  |  |  |  |
| 110в         | Internal timer                |  |  |  |  |
| 111в         | External clock                |  |  |  |  |

Table 2.4.2 Clock Input Selection

**Note:** The MB90610A series has two 16-bit timers. Selecting the internal timer selects timer 0. CS2, CS1, and CS0 are write-only. Reading always returns "1".

[Bit 2] Free:

Accessing this bit is prohibited.

[Bit 1] SCKE (SCLK enable):

Specifies whether to use the SCK0 pin as the clock input pin or clock output pin for CLK synchronous mode (mode 2).

Set to zero in CLK asynchronous mode or external clock mode.

- 0: Operate as the clock input pin.
- 1: Operate as the clock output pin.

Note: When using this pin as the clock input pin, external clock source operation must be selected.

[Bit 0] SOE (Serial output enable):

The external pin (SOT) can also be used as a general-purpose I/O port. This bit specifies whether to use the pin as the serial output pin or I/O port pin.

0: Operate as a general-purpose I/O port pin.

1: Operate as a serial data output pin (SOT).

## (2) SCR (Serial control register)



SCR controls the transmission protocol for serial communications.

[Bit 15] PEN (Parity Enable):

Specifies whether to add a parity bit in serial data I/O.

- 0: Do not use parity.
- 1: Use parity.
- Note: Parity can only be used in the normal mode (mode 0) of CLK asynchronous (start-stop synchronization) data transfer. Parity cannot be used in multiprocessor mode (mode 1) and CLK synchronous data transfer mode (mode 2).

[Bit 14] P (Parity):

Specifies even or odd parity when parity is selected for data transfer.

- 0: Even parity
- 1: Odd parity

[Bit 13] SBL (Stop Bit Length):

Specifies the number of stop bits. The stop bits are the frame end mark for CLK asynchronous (start-stop synchronization) data transfer.

- 0: 1 stop bit
- 1: 2 stop bits

Chapter 2: Hardware

[Bit 12] CL (Character Length):

Specifies the number of data bits in a transmit or receive frame.

- 0: 7-bit data
- 1: 8-bit data
- Note: Using 7 data bits is only available in the normal mode (mode 0) of CLK asynchronous (start-stop synchronization) data transfer. Use 8 data bits for multiprocessor mode (mode 1) and CLK synchronous data transfer mode (mode 2).
- [Bit 11] A/D (Address/Data):

Specifies the data format for transmit and receive frames in multiprocessor mode (mode 1) of CLK asynchronous (start-stop synchronization) data transfer.

- 0: Data frame
- 1: Address frame

[Bit 10] REC (Receiver Error Clear):

Writing "0" clears the SSR register error flags (PE, ORE, and FRE).

Writing "1" has no effect. Reading always returns '1".

- **Note:** When the UART is operating and receive interrupts enabled, only write "0" to REC when one of PE, ORE, or FRE is "1".
- [Bit 9] RXE (Receiver Enable):

Controls the UART receive operation.

- 0: Disable receive operation.
- 1: Enable receive operation.
- **Note:** If reception is disabled during a receive (when data is being input to the receive shift register), the receive operation halts after reception of the frame has completed and the data is stored in the receive data buffer register (SIDR).
- [Bit 8] TXE (Transmitter Enable):

Controls the UART transmit operation.

- 0: Disable transmit operation.
- 1: Enable transmit operation.
- **Note:** If transmission is disabled during a transmit (when data is being output from the transmit register), the transmit operation halts after the transmit data buffer register (SODR) becomes empty.

#### 2.4 UART 0/1/2 (SCI)

#### (3) SIDR (Input data register) and SODR (Output data register)

| Input data register/Ou | utput data register                       |              | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0 | 🖙 Bit No.                   |
|------------------------|-------------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|---|-----------------------------|
| Address:               | ch0 000022н • •                           |              |              |              |              |              |              |              |              |   |                             |
| Address:               | сh0 000022н<br>ch1 000026н<br>ch2 000046н | D7           | D6           | D5           | D4           | D3           | D2           | D1           | D0           |   | SIDR (read)<br>SODR (write) |
|                        | Read/write ⇔<br>Initial value ⇒           | (R/W)<br>(X) | - |                             |

These registers are the receive and transmit data buffers.

The most significant bit (D7) is ignored if the data length is 7 bits. Only write to the SODR register when TDRE in the SSR register is "1". Only read the SIDR register when RDRF in the SSR register is "1".

Note1: Writing to this address writes to the SODR register. Reading reads from the SIDR register.

Note 2: Do not use read-modify-write instructions to access the register as this can cause misoperation.

### (4) SSR (Serial status register)

| Serial sta                                         | atus register                   |            | 15         | 14       | 1  | 3          | 12       | 1        | 1          | 10        |   | 9           | 8  | 🗢 Bi    | t No. |
|----------------------------------------------------|---------------------------------|------------|------------|----------|----|------------|----------|----------|------------|-----------|---|-------------|----|---------|-------|
| Addrooo                                            | ch0 000023н                     | <u> </u>   |            |          |    |            |          |          |            |           |   |             |    | <u></u> |       |
| Address: ch0 000023н<br>ch1 000027н<br>ch2 000047н |                                 | PE         | ORE        | E FF     | RE | RDRF       | TDF      | RE       | -          | R         | Е | TIE         |    |         | SSR   |
|                                                    | Read/write ⇔<br>Initial value ⇔ | (R)<br>(0) | (R)<br>(0) | (F<br>(C | /  | (R)<br>(0) | (R<br>(1 | <i>'</i> | (-)<br>(-) | (R/<br>(0 |   | (R/V<br>(0) | /) |         |       |

SSR contains the flags that indicate the operation status of the UART.

[Bit 15] PE (Parity Error):

The flag is an interrupt request flag and is set when a receive parity error occurs.

Once set, writing "0" to the REC bit (bit 10) in the SCR register clears the flag.

When this flag is set, the data in SIDR is invalid.

- 0: No parity error
- 1: Parity error

[Bit 14] ORE (Over Run Error):

The flag is an interrupt request flag and is set when a receive overrun error occurs. Once set, writing "0" to the REC bit (bit 10) in the SCR register clears the flag.

When this flag is set, the data in SIDR is invalid.

- 0: No overrun error
- 1: Overrun error

74 Chapter 2: Hardware [Bit 13] FRE (Framing Error):

The flag is an interrupt request flag and is set when a receive framing error occurs.

Once set, writing "0" to the REC bit (bit 10) in the SCR register clears the flag.

When this flag is set, the data in SIDR is invalid.

- 0: No framing error
- 1: Framing error

[Bit 12] RDRF (Receiver Data Register Full):

The flag is an interrupt request flag and indicates that receive data is present in the SIDR register.

The bit is set when the receive data is loaded into the SIDR register and automatically cleared by reading the SIDR register.

- 0: No receive data
- 1: Receive data present

[Bit 11] TDRE (Transmitter Data Register Empty):

The flag is an interrupt request flag and indicates that transmit data can be written to the SODR register.

Writing data to SODR clears the flag. The flag is set again when the data is loaded to the transmit shifter and transmission starts. This indicates that the next transmit data can be written.

- 0: Writing transmit data is disabled.
- 1: Writing transmit data is enabled.

[Bit 9] RIE (Receiver Interrupt Enable):

Controls receive interrupts.

- 0: Disable interrupts.
- 1: Enable interrupts.
- **Note:** Receive interrupt sources are generated by an error due to PE, ORE, or FRE as well as by RDRF (normal receive).

[Bit 8] TIE (Transmitter Interrupt Enable):

Controls transmit interrupts.

- 0: Disable interrupts.
- 1: Enable interrupts.

Note: Transmit interrupts are generated when a TDRE transmit request is present.

## (5) CDCR (Machine clock divide-by-n control register)



Note 1: Do not use read-modify-write instructions to access the register as this can cause misoperation.

The operating clock for the UART is obtained by dividing the machine clock. The divider is designed to obtain specific baud rates for a range of machine clocks. The CDCR register controls the machine clock divider.

[Bit 11, 10, 9, 8] DIV3 to 0 (DIVide 3 to 0)

Sets the machine clock divide ratio.

| DIV3 to DIV0 | Divide Ratio |
|--------------|--------------|
| 1110в        | Divide by 2  |
| 1101в        | Divide by 3  |
| 1100в        | Divide by 4  |
| 1011в        | Divide by 5  |
| 1010в        | Divide by 6  |
| 1001в        | Divide by 7  |
| 1000в        | Divide by 8  |
|              |              |

## Table 2.5.3 Machine Clock Divide Ratio

Set the CDCR register bits as follows for the different machine clocks  $\phi$ . These settings obtain the baud rates listed in Table 2.4.4.

| Machine<br>Clock∳ | div | DIV3 | DIV2 | DIV1 | DIV0 | φ÷div |
|-------------------|-----|------|------|------|------|-------|
| 6 MHz             | 3   | 1    | 1    | 0    | 1    |       |
| 8 MHz             | 4   | 1    | 1    | 0    | 0    |       |
| 10 MHz            | 5   | 1    | 0    | 1    | 1    | 2 MHz |
| 12 MHz            | 6   | 1    | 0    | 1    | 0    |       |
| 14 MHz            | 7   | 1    | 0    | 0    | 1    |       |
| 16 MHz            | 8   | 1    | 0    | 0    | 0    |       |
| 8 MHz             | 2   | 1    | 1    | 1    | 0    |       |
| 12 MHz            | 3   | 1    | 1    | 0    | 1    | 4 MHz |
| 16 MHz            | 4   | 1    | 1    | 0    | 0    |       |

When using different machine clock or div settings to those listed above, ensure that the product of  $\phi \div \text{div}$  does not exceed 4 MHz.

## 2.4.4 Operation

## (1) Operating modes

Table 2.4.3 lists the UART operating modes. Set the SMR and SCR registers to switch between modes.

| Mode | Parity   | Data Length | Operating Mode                                                        | Number of<br>Stop Bits |  |
|------|----------|-------------|-----------------------------------------------------------------------|------------------------|--|
| 0    | On/Off   | 7           | CLK asynchronous (start-stop                                          |                        |  |
| 0    | On/Off 8 |             | synchronization) Normal mode                                          | 1 bit or 2 bits        |  |
| 1    | Off      | 8+1         | CLK asynchronous (start-stop<br>synchronization) Multi-processor mode |                        |  |
| 2    | Off      | 8           | CLK synchronous mode                                                  | None                   |  |

Table 2.4.3 UART Operating Modes

However, for CLK asynchronous (start-stop synchronization) mode, the number of stop bits can only be set for transmission. The number of receive stop bits is always one. Do not set modes other than those listed above. The UART does not operate if an invalid mode is set.

**Note:** UART CLK synchronous mode uses clock control (I/O expansion serial). No start or stop bit is added to the data in clock synchronous mode.

## 2.4 UART 0/1/2 (SCI)

## (2) UART clock selection

### a) Dedicated baud rate generator

The baud rate when the dedicated baud rate generator is selected is as follows.

| (i) <b>\$</b> ÷di | (i) $\phi \div div = 2 \text{ MHz}$ |     |                                               |                    |  |  |  |  |  |  |  |  |
|-------------------|-------------------------------------|-----|-----------------------------------------------|--------------------|--|--|--|--|--|--|--|--|
| CS2               | CS1                                 | CS0 | Asynchronous (start-<br>stop synchronization) | CLK Synchronous    |  |  |  |  |  |  |  |  |
| 0                 | 0                                   | 0   | 9615 (1)                                      | Prohibited setting |  |  |  |  |  |  |  |  |
| 0                 | 0                                   | 1   | 31250 (2)                                     |                    |  |  |  |  |  |  |  |  |
| 0                 | 1                                   | 0   | 4808 (3)                                      | 1 M                |  |  |  |  |  |  |  |  |
| 0                 | 1                                   | 1   | 2404                                          | 500 k              |  |  |  |  |  |  |  |  |
| 1                 | 0                                   | 0   | 1202                                          | 250 k              |  |  |  |  |  |  |  |  |

## Table 2.4.4 Baud Rate

(ii)  $\phi \div div = 4 \text{ MHz}$ 

| CS2 | CS1 | CS0 | Asynchronous (start-<br>stop synchronization) | CLK Synchronous    |  |  |
|-----|-----|-----|-----------------------------------------------|--------------------|--|--|
| 0   | 0   | 0   | 19230 (1)                                     | Prohibited setting |  |  |
| 0   | 0   | 1   | Prohibited setting                            | Fromblied Setting  |  |  |
| 0   | 1   | 0   | 9615 (3)                                      | 2 M                |  |  |
| 0   | 1   | 1   | 4808                                          | 1 M                |  |  |
| 1   | 0   | 0   | 2404                                          | 500 k              |  |  |

For these cases, the baud rate is calculated as follows.

| (1) | (\$ +div)/(16 × 13)                       |
|-----|-------------------------------------------|
| (2) | (φ ÷div)/2 <sup>6</sup>                   |
| (3) | $(\phi \div div)/(16 \times 13 \times 2)$ |

(Where,  $\phi$  is the machine cycle.)

### b) Internal timer

Selecting the internal timer by setting "110" to CS2 to 0 sets the 16-bit timer (timer 4) to operate in reload mode. The baud rate is calculated as follows.

CLK asynchronous (start-stop synchronization) CLK synchronous  $(\phi \div N) / (16 \times 2 \times (n+1))$  $(\phi \div N) / (2 \times (n+1))$ 

- N: Count clock source for timer
- n: Timer reload value

Table 2.4.5 lists the relationship between baud rate and reload value (hexadecimal) for a machine cycle of 7.3728 MHz.

| Reload Value | N = 2 <sup>1</sup><br>(Machine cycle divided by 2) | N = 2 <sup>3</sup><br>(Machine cycle divided by 8) |
|--------------|----------------------------------------------------|----------------------------------------------------|
| Baud Rate    |                                                    |                                                    |
| 38400        | 2                                                  | -                                                  |
| 19200        | 5                                                  | -                                                  |
| 9600         | 11                                                 | 2                                                  |
| 4800         | 23                                                 | 5                                                  |
| 2400         | 47                                                 | 11                                                 |
| 1200         | 95                                                 | 23                                                 |
| 600          | 191                                                | 47                                                 |
| 300          | 383                                                | 95                                                 |

Table 2.4.5 Baud Rate and Reload Value

When the internal timer (16-bit timer 0) is selected as the baud rate clock source, the TOT0 output of 16-bit timer 0 is connected inside the controller. Therefore, the TOT0 output of 16-bit timer 0 does not have to be connected externally to the UART external clock input pin (SCK). Also, if the output pin of timer 0 is not used elsewhere, the pin can be used as an I/O port pin.

#### c) External clock

The baud rate is calculated as follows when the external clock is selected by setting "111" to CS2 to 0. Here, f is the frequency.

| CLK asynchronous (start-stop synchronization) | f/16 |
|-----------------------------------------------|------|
| CLK synchronous                               | f    |

The maximum external clock frequency (f) is 1 MHz.

## (3) CLK asynchronous (start-stop synchronization) mode

## a) Transfer data format

The UARTs only handle Non-Return-to-Zero (NRZ) type data. Figure 2.4.3 shows the data format.



## Fig. 2.4.3 Transfer Data Format (Mode 0 and 1)

As shown in Figure 2.4.3, the transfer data always starts from the start bit (L level data), the specified number of data bits are transmitted LSB-first, then transmission ends with the stop bit (H level data). Input a continuous clock signal if external clock operation is selected.

The number of data bits can be set to 7 or 8 bits in normal mode (mode 0). In multiprocessor mode (mode 1), the number of data bits must be 8. Also parity cannot be used in multiprocessor mode. Instead, the A/D bit is always added.

### b) Receive operation

Reception operates continuously when the RXE bit (bit 9) of the SCR register is "1".

After a start bit is received on the receive line, one frame of data is received in the data format specified by the SCR register. After reception of the frame is complete, an error flag is set if any error occurred, then the RDRF flag (bit 12 of the SSR register) is set. At this time, a receive interrupt is sent to the CPU if the RIE bit (bit 9) of the SSR register is set to "1". Check the flags in the SSR register, then read the SIDR register if reception was normal or perform any required processing if an error occurred.

Reading the SIDR register clears the RDRF flag.

#### c) Transmit operation

Write the transmit data to the SODR register when the TDRE flag (bit 11) in the SSR register is "1". The UART transmits the data if the TXE bit (bit 8) of the SCR register is "1".

The TDRE flag is set again when the data set in the SODR register is loaded to the transmit shift register to start transmission. The next transmit data can now be set. If the TIE bit (bit 8) of the SSR register is set to "1", a transmit interrupt is sent to the CPU requesting input of the next transmit data to SODR.

Setting data to the SODR register clears the TDRE flag.

80

### (4) CLK synchronous mode

#### a) Transfer data format

The UARTs only handle Non Return to Zero (NRZ) type data. Figure 2.4.4 shows the relationship between the transmit/receive clock and the data.



## Fig. 2.4.4 Transfer Data Format (Mode 2)

When an internal clock is selected (dedicated baud rate generator or internal timer), the synchronizing clock for data reception is automatically generated when transmitting data.

When an external clock is selected, exactly one byte of clock signal must be supplied after checking that data is present in the transmit data buffer (SODR register) of the transmitter UART (the TDRE flag is "0"). Note that SCLK must be at the mark level before starting transmission and after transmission is complete.

Only 8-bit data can be used and parity is not available. As no start or stop bits are used, the only error that can be detected is an overrun error.

#### b) Initialization

The following lists the settings for each control register when using CLK synchronous mode.

| (1) | SMR register   |                                                                     |     |
|-----|----------------|---------------------------------------------------------------------|-----|
|     | MD1, MD0:      | "10"                                                                |     |
|     | CS2, CS1, CS0: | Specify the clock input.                                            |     |
|     | SCKE:          | When the dedicated baud rate generator or internal timer is used: ' | '1' |
|     |                | When an external clock is used: "0"                                 |     |
|     | SOE:           | When transmitting: "1"                                              |     |
|     |                | When receiving only: "0"                                            |     |
| (2) | SCR register   |                                                                     |     |
|     | PEN:           | "0"                                                                 |     |
|     | P, SBL, A/D:   | These bits have no meaning.                                         |     |
|     | CL:            | "1"                                                                 |     |
|     | REC:           | "0" (for initialization)                                            |     |
|     | RXE, TXE:      | Set at least one of these to "1".                                   |     |
| (3) | SSR register   |                                                                     |     |
|     | RIE:           | Set "1" to use interrupts. Set "0" for no interrupts.               |     |
|     | TIE:           | "0"                                                                 |     |
|     |                |                                                                     |     |

## c) Starting communications

Writing to the SODR register starts communications. Note that temporary data must be written to the SODR register, even if not performing transmission.

### d) Ending communications

The RDRF flag in the SSR register changes to "1" to confirm the end of communications. Check the ORE bit in the SSR register to determine whether communication was performed correctly.

## (5) Interrupt generation and flag set timings

The UARTs have five flags and two interrupts sources.

The five flags are PE, ORE, FRE, RDRF, and TDRE. PE indicates a parity error, ORE an overrun error, and FRE a framing error. These flags are set if a receive error occurs and are cleared by writing "0" to RED in the SCR register. RDRF is set when receive data is loaded into the SIDR register. Reading SIDR clears RDRF. Note that the parity detect function is not available in mode 1 and the parity and framing error detect functions are not available in mode 2. TDRE is set when the SODR register becomes empty and available for writing. Writing to the SODR register clears TDRE.

The two interrupts are the receive and transmit interrupts. For reception, the PE, ORE, FRE, and RDRF flags request an interrupt. For transmission, the TDRE flag requests an interrupt. The following describes the interrupt flag set timings for each operating mode.

## a) Receive operation in mode 0

The PE, ORE, FRE, and RDRF flags are set and an interrupt request to the CPU generated when the final stop bit is detected indicating the end of reception. The data in SIDR is invalid when either the PE, ORE, or FRE bit is active.



## Fig. 2.4.5 ORE, FRE, and RDRF Set Timing (Mode 0)

## b) Receive operation in mode 1

The ORE, FRE, and RDRF flags are set and an interrupt request to the CPU generated when the final stop bit is detected indicating the end of reception. As only 8 data bits can be received, the final ninth bit containing the address/data indicator is not valid. The data in SIDR is invalid when either the ORE or FRE bit is active.



## Fig. 2.4.6 ORE, FRE, and RDRF Set Timing (Mode 1)

### c) Receive operation in mode 2

The ORE and RDRF flags are set and an interrupt request to the CPU generated when the final data bit (D7) is detected indicating the end of reception. The data in SIDR is invalid when the ORE bit is active.





### d) Transmit operation in mode 0 and mode 1

Writing data to the SODR register clears TDRE. TDRE is set and an interrupt request to the CPU generated when the data written in the SODR register is transferred to the internal shift register and the next data is able to be written to SODR. Writing "0" to TXE (also to RXE in mode 2) in the SCR register during transmission disables transmission operation after TDRE in the SSR register goes to "1" and the transmit shifter stops. If "0" is written to TXE (also to RXE in mode 2) in the SCR register while transmission is in progress, the data written to the SODR register before transmission was halted is transmitted.







## Fig. 2.4.9 TDRE Set Timing (Mode 2)

## (6) EI<sup>2</sup>OS (Extended intelligent I/O service)

See Section 3.3.2 "EI<sup>2</sup>OS" for details on EI<sup>2</sup>OS.

## 2.4.5 Cautions

Set the communication mode when operation is halted. Data transmitted or received during mode setting cannot be guaranteed.

## 2.4.6 Application Example

Mode 1 is used when a number of slave CPUs are connected to a host CPU (see Figure 2.4.10). This resource only supports the host-side communication interface.



## Fig. 2.4.10 Example System Configuration Using Mode 1

Communication starts with the host CPU transmitting address data. Address data is data transmitted with the A/D bit in the SCR register set to "1". The address selects the slave CPU with which to communicate and enables communication with the host CPU. Normal data is data transmitted with the A/D bit in the SCR register is set to "0". Figure 2.4.11 shows a flow chart of operation in this mode.

As the parity check function is not available in this mode, set the PEN bit in the SCR register to "0".



Fig. 2.4.11 Communication Flowchart for Mode 1 Operation

# 2.5 10-Bit 8-Input A/D Converter (With 8-Bit Resolution Mode)

The 10-bit 8-input A/D converter converts analog input voltages to digital values. The A/D converter has the following features.

| • Conversion time:      | Minimum of $6.13 \mu s$ per channel (98 machine cycles for a 16 MHz machine clock - including sample and hold time) |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|
| • Sample and hold time: | Minimum of $3.75 \mu s$ per channel (60 machine cycles for a 16 MHz machine clock)                                  |

- Uses RC-type successive approximation conversion with a sample-and-hold circuit.
- 10-bit or 8-bit resolution
- Eight program-selectable analog input channels

| Single conversion mode:<br>Scan conversion mode: | Selectively convert a single channel.<br>Continuously convert multiple channels. Maximum of 8 program-<br>selectable channels. |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Continuous conversion mode:                      | Repeatedly convert specified channels.                                                                                         |
| Stop conversion mode:                            | Convert one channel then halt until the next activation. (Enables synchronization of the conversion start timing.)             |

- An A/D conversion completion interrupt request to the CPU can be generated on the completion of A/D conversion. This interrupt can activate I<sup>2</sup>OS to transfer the result of A/D conversion to memory and is suitable for continuous processing.
- Activation by software, external trigger (falling edge), or timer (rising edge) can be selected.

## 2.5.1 Registers

| Control status register (upper) | 15           | 14            | 13             | 12           | 11           | 10             | 9             | 8              | ¢  | Bit No.   |
|---------------------------------|--------------|---------------|----------------|--------------|--------------|----------------|---------------|----------------|----|-----------|
| Address: 00002DH                | BUSY         | INT           | INTE           | PAUS         | STS1         | STS0           | STRT          | Reserved       |    | ADCS1     |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) | (R/W)<br>(0)  | (R/W)<br>(0)   | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0)   | (W)<br>(0     | (-)<br>(0)     |    |           |
| Control status register (lower) | 7            | 6             | 5              | 4            | 3            | 2              | 1             | 0              |    | ⇔ Bit No. |
| Address: 00002CH                | MD1          | MDO           | ANS            | 2 ANS        | 1 ANS        | 0 ANE          | 2 ANE         | 1 ANE          | 0  | ADCS0     |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) | ) (R/W<br>(0) | /) (R/W<br>(0) | (R/W<br>(0)  | (R/W<br>(0)  | /) (R/W<br>(0) | ) (R/W<br>(0) | /) (R/W<br>(0) | /) |           |
| Data register (upper)           | 15           | 14            | 13             | 12           | 11           | 10             | 9             | 8              | ¢  | Bit No.   |
| Address: 00002FH                | S10          | -             | -              | -            | -            | -              | D9            | D8             |    | ADCR1     |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) | (R)<br>(0)    | (R)<br>(0)     | (R)<br>(0)   | (R)<br>(0)   | (R)<br>(0)     | (R)<br>(X)    | (R)<br>(X)     |    |           |
| Data register (lower)           | 7            | 6             | 5              | 4            | 3            | 2              | 1             | 0              |    | 🗇 Bit No. |
| Address: 00002EH                | D7           | D6            | D5             | D4           | D3           | D2             | D1            | D0             |    | ADCR0     |
| Read/write ⇔<br>Initial value ⇔ | (R)<br>(X)   | (R)<br>(X)    | (R)<br>(X)     | (R)<br>(X)   | (R)<br>(X)   | (R)<br>(X)     | (R)<br>(X)    | (R)<br>(X)     |    |           |

# 2.5.2 Block Diagram



Fig. 2.5.1 Block Diagram

## 2.5.3 Register Details

### (1) ADCS1, 0 (Control status register)

Register layout

| Control status register (upper) | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 🗇 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| Address: 00002DH                | BUSY         | INT          | INTE         | PAUS         | STS1         | STS0         | STRT         | Reserved     | ADCS1     |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (W)<br>(0    | (-)<br>(0)   |           |
| Control status register (lower) | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            | 🗇 Bit No. |
| Address: 00002CH                | MD1          | MD0          | ANS2         | ANS1         | ANS0         | ANE2         | ANE1         | ANE0         | ADCS0     |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) | -         |

Register contents

This register is used for control and status indication for the A/D converter. Do not modify Note 1: ADCS0 during A/D conversion.

Do not access this register using read-modify-write instructions as this can cause misoperation. Note 2:

#### Bit meanings

[Bit 15] BUSY (Busy flag and stop)

- On reading: A/D converter operation indication bit. Set on activation of A/D conversion and cleared on completion.
- Writing "0" to this bit during A/D conversion forcibly terminates conversion. Use to On writing: forcibly terminate in continuous and stop modes.

Writing "1" to this bit has no effect. RMW instructions read a value of "1". Cleared on the completion of A/D conversion in single conversion mode. In continuous and stop mode, the flag is not cleared until conversion is terminated by writing "0". Initialized to "0" by a reset.

Note: Do not specify forcible termination and software activation (BUSY="0" and STRT="1") at the same time.

[Bit 14] INT (Interrupt)

Data indication bit. This bit is set when conversion data is stored in ADCR. When INTE (bit 13) is "1", an interrupt request is generated when this bit is set. When I<sup>2</sup>OS activation is enabled, I<sup>2</sup>OS is activated. Writing "1" has no meaning. The bit is cleared by I<sup>2</sup>OS data transfer or by writing "0" to the bit from the CPU. The bit is initialized to "0" by a reset.

**Note:** Only clear this bit (by writing "0" from the CPU) while conversion is halted.

[Bit 13] INTE (Interrupt enable)

This bit enables or disables the conversion completion interrupt.

- 0: Disable interrupt
- 1: Enable interrupt

Always set this bit when using I<sup>2</sup>OS. Generation of an interrupt request activates I<sup>2</sup>OS. Initialized to "0" by a reset.

[Bit 12] PAUS (A/D converter pause)

This bit is set when A/D conversion temporarily halts.

The A/D converter has only one register to store the conversion result. Therefore, in continuous conversion mode, the previous conversion result is lost when the next conversion result is stored in the register if the previous data has not been read by the CPU. To avoid this problem when using continuous conversion mode, use I<sup>2</sup>OS to transfer the conversion result to memory automatically after each conversion is complete. However, there may be cases when transfer of the conversion data does not occur before completion of the next conversion (for example, if multiple interrupts occur). This bit is provided to deal with such cases. The bit is set from the time conversion completes until the content of the data register is transferred by I<sup>2</sup>OS. This halts A/D conversion during this period and prevents the next conversion data from being stored in the register. The A/D converter then automatically restarts after completion of data transfer by I<sup>2</sup>OS. This bit is only meaningful when I<sup>2</sup>OS is used. The bit is initialized to "0" by a reset.

[bits 11, 10] STS1, STS0 (Start source select)

These bits select the A/D activation source. Initialized to "00" by a reset.

| STS1 | STS0 | Function                                                                   |  |  |  |  |
|------|------|----------------------------------------------------------------------------|--|--|--|--|
| 0    | 0    | Software activation                                                        |  |  |  |  |
| 0    | 1    | Software activation and external trigger pin activation                    |  |  |  |  |
| 1    | 0    | Software activation and timer activation                                   |  |  |  |  |
| 1    | 1    | Software activation, external trigger pin activation, and timer activation |  |  |  |  |

Table 2.5.1 STS Bit Settings

In multiple-activation modes, the first activation to occur starts A/D conversion. The activation source changes immediately on writing to the register. Therefore, when switching activation modes during A/D operation, switch the mode while the new activation source is not active.

Setting the external trigger pin as an activation source when the external trigger input level is "L" may start A/D conversion.

[Bit 9] STRT (Start)

Writing "1" to this bit starts A/D operation. Write "1" again to restart conversion. Restarting does not function in stop mode. Initialized to "0" by a reset.

**Note:** Do not specify forcible termination and software activation (BUSY="0" and STRT="1") at the same time.

### [Bit 8] Test bit

Test bit. Always write "0" to this bit.

[Bits 7, 6] MD1, MD0 (A/D converter MoDe set)

These bits set the operation mode. Table 2.5.2 lists the available modes.

| MD1                                                                          | MD0 | Operation Mode                                                                              |
|------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------|
| 0                                                                            | 0   | Single conversion mode. Re-activation during operation is always available. (Initial value) |
| 0                                                                            | 1   | Single conversion mode. Re-activation during operation is not available.                    |
| 1 0 Continuous conversion mode. Re-activation during operation is available. |     |                                                                                             |
| 1                                                                            | 1   | Stop mode. Re-activation during operation is not available.                                 |

Table 2.5.2 MD Bit Settings

- Single conversion mode:Performs one A/D conversion for each channel from the start to the end<br/>channel, then halts. ANS2 to ANS0 specifies the start channel and ANE2<br/>TO ANE0 specifies the end channel.Continuous conversion mode:Repeatedly performs A/D conversion for the start to end channels. ANS2<br/>to ANS0 specifies the start channel and ANE2 to ANE0 specifies the end<br/>channel.Stop mode:Performs one A/D conversion each time for the start to end channels.<br/>Halts temporarily after each conversion and re-activates when a trigger<br/>occurs. ANS2 to ANS0 specifies the start channel and ANE2 to ANE0<br/>specifies the end channel.
  - When A/D conversion is activated in continuous mode or stop mode, conversion operates continuously until stopped by the BUSY bit.
  - •
  - Write "0" to the BUSY bit to stop conversion.
  - When re-activation is not available in single, continuous, or stop mode, this applies to activation by timer, external trigger, and software.

[Bits 5, 4, 3] ANS2, ANS1, ANS0 (ANalog Start channel set)

These bits set the start channel for A/D conversion. Activating the A/D converter starts A/D conversion from the channel specified by these bits.

| ANS2 | ANS1 | ANS0 | Start Channel |
|------|------|------|---------------|
| 0    | 0    | 0    | AN0           |
| 0    | 0    | 1    | AN1           |
| 0    | 1    | 0    | AN2           |
| 0    | 1    | 1    | AN3           |
| 1    | 0    | 0    | AN4           |
| 1    | 0    | 1    | AN5           |
| 1    | 1    | 0    | AN6           |
| 1    | 1    | 1    | AN7           |

 Table 2.5.3 Conversion Start Channel Setting by the ANS Bits

Reading these bits during A/D conversion reads the channel number currently being converted. Reading these bits while A/D conversion is halted in stop mode reads the most recently converted channel. Initialized to "000" by a reset.

[Bits 2, 1, 0] ANE2, ANE1, ANE0 (ANalog End channel set)

These bits set the end channel for A/D conversion. Activating the A/D converter performs A/D conversion up to the channel specified by these bits.

| ANE2 | ANE1 | ANE0 | End Channel |
|------|------|------|-------------|
| 0    | 0    | 0    | AN0         |
| 0    | 0    | 1    | AN1         |
| 0    | 1    | 0    | AN2         |
| 0    | 1    | 1    | AN3         |
| 1    | 0    | 0    | AN4         |
| 1    | 0    | 1    | AN5         |
| 1    | 1    | 0    | AN6         |
| 1    | 1    | 1    | AN7         |

 Table 2.5.4 Conversion End Channel Setting by the ANE Bits

Setting the same channel as ANS2 to ANS0 specifies conversion for that channel only. In continuous or stop mode, conversion is performed up to the channel specified by these bits. Conversion then starts again from the start channel specified by ANS2 to ANS0. If ANS > ANE, conversion starts with the channel specified by ANS, continues up to AN7, starts again from AN0, and ends with the channel specified by ANE. The following shows an example.

Example: Channel setting ANS = 6ch, ANE = 3ch, single conversion mode Operation Conversion channel  $6ch \rightarrow 7ch \rightarrow 0ch \rightarrow 1ch \rightarrow 2ch \rightarrow 3ch$ 

Initialized to "000" by a reset.

#### 2.5 10-Bit 8-Input A/D Converter (With 8-Bit Resolution Mode)

## (2) ADCR1, ADCR0 (Data registers)

#### Register layout

| Data register (upper)<br>(For 10-bit mode) | 15           | 14         | 13         | 12         | 11         | 10         | 9          | 8          | ⇔ Bit No. |
|--------------------------------------------|--------------|------------|------------|------------|------------|------------|------------|------------|-----------|
| Address:00002FH                            | S10          | -          | -          | -          | -          | -          | D9         | D8         | ADCR1     |
| Read/write ⇔<br>Initial value ⇔            | (R/W)<br>(0) | (R)<br>(0) | (R)<br>(0) | (R)<br>(0) | (R)<br>(0) | (R)<br>(0) | (R)<br>(X) | (R)<br>(X) |           |
| Data register (upper)<br>(For 8-bit mode)  | 15           | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 🗢 Bit No. |
| Address:00002FH                            | S10          | -          | -          | -          | -          | -          | -          | -          | ADCR1     |
| Read/write ⇔<br>Initial value ⇔            | (R/W)<br>(0) | (-)<br>(-) |           |
|                                            |              |            |            |            |            |            |            |            |           |
| Data register (lower)                      | 7            | 6          | 5          | 4          | 3          | 2          | 1          | 0          | 🗇 Bit No. |
| Address:00002EH                            | D7           | D6         | D5         | D4         | D3         | D2         | D1         | D0         | ADCR0     |
| Read/write ⇔<br>Initial value ⇔            | (R)<br>(X)   | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) |           |

#### Register contents

These registers store the digital result of A/D conversion. The resolution of the conversion result is 10 bits when bit S10 is "0" and 8 bits when bit S10 is "1". ADCR1 stores the upper 2 bits of the conversion result and ADCR0 stores the lower 8 bits. The D9 to D0 value is updated at the completion of every conversion. The registers normally hold the previous conversion value. Other than S10, the register values after a reset are indeterminate. S10 is initialized to "0" by a reset.

Reading bits 15 to 10 of ADCR1 always returns "0" in 10-bit mode. In 8-bit mode, all contents of ADCR1 are undefined and the result is stored in ADCR0.

Only write to S10 before conversion, when A/D operation is halted. Writing to S10 after conversion causes the contents of ADCR to become indeterminate.

## 2.5.4 Operation

The A/D converter operates using the successive approximation method with 10 or 8-bit resolution. As only one 16-bit register is provided to store conversion results, the previous conversion data is lost each time conversion completes. Therefore,  $I^2OS$  must be used to successively transfer conversion data to memory when using continuous conversion mode.

The following describes the operating modes.

■ Single conversion mode

In this mode, the A/D converter converts each analog input channel from the start channel specified by ANS to the end channel specified by ANE. Conversion completes on reaching the end channel and A/D operation halts. When the start and end channels are the same (ANS = ANE), conversion is only performed for the channel specified in ANS.

Example 1: ANS = "000", ANE = "011"  $\Rightarrow$  Start  $\rightarrow$  AN0  $\rightarrow$  AN1  $\rightarrow$  AN2  $\rightarrow$  AN3  $\rightarrow$  End

Example 2: ANS = "010", ANE = "010"  $\Rightarrow$  Start  $\rightarrow$  AN2  $\rightarrow$  End

- I<sup>2</sup>OS activation example in single conversion mode
  - Convert analog inputs AN1 to AN3, then end.
  - Sequentially transfer the conversion data to locations 200H to 205H.
  - Activate by software.
  - Maximum interrupt priority level

#### □ Setting I<sup>2</sup>OS

| Set ICR in the interrupt controller.                   |
|--------------------------------------------------------|
| MOV ICR10, #08H①                                       |
| $\triangleright$ Set the I <sup>2</sup> OS descriptor. |
| MOV BAPL, #00H ②                                       |
| MOV BAPM, #02H3                                        |
| MOV BAPH, #00H                                         |
| MOV ISCS, #18H                                         |
| MOV IOAL, #2EH6                                        |
| MOV IOAH, #00H                                         |
| MOV DCTL, #03H⑦                                        |
| MOV DCTH, #00H⑦                                        |
| $\Box$ Set the A/D converter.                          |
| MOV ADCS0, #0BH                                        |
| MOV ADCS1, #A2H                                        |
| □ Other processing                                     |

#### •

### □ I<sup>2</sup>OS completion interrupt sequence

| MOV ADCS1,#80H |    |
|----------------|----|
| RETI           | 10 |

- (1) Set maximum interrupt priority, specify I<sup>2</sup>OS activation by the interrupt, and set the descriptor address.
- (2)(3)(4) Set the destination address for the conversion data.
- (5) Set word data transfer, increment the destination address after each transfer, and transfer from I/O to memory.
- (6) Set the A/D converter result register.
- (7) Perform  $I^2OS$  data transfer three times (same as the number of conversions).
- (8) Set single conversion mode, start channel AN1, and end channel AN3.

- (9) Specify software activation. Start A/D conversion.
- (10) Return from interrupt.

| ICR10: | Interrupt control register        |
|--------|-----------------------------------|
| BAPL:  | Buffer address pointer (lower)    |
| BAPM:  | Buffer address pointer (middle)   |
| BAPH:  | Buffer address pointer (upper)    |
| ISCS:  | I <sup>2</sup> OS status register |
| I/OAL: | I/O address register (lower)      |
| I/OAH: | I/O address register (upper)      |
| DCTL:  | Data counter (lower)              |
| DCTL:  | Data counter (lower)              |
| DCTH:  | Data counter (upper)              |
| 20111  | z ana counter (apper)             |

•

## Activation start

| Interrupt $\rightarrow$ I <sup>2</sup> OS data transfer |
|---------------------------------------------------------|
|                                                         |
|                                                         |
|                                                         |
| Interrupt $\rightarrow$ I <sup>2</sup> OS data transfer |
| -                                                       |
| Interrupt sequence                                      |
| lel processing                                          |
|                                                         |

#### ■ Continuous conversion mode

In this mode, the A/D converter converts each analog input channel from the start channel specified by ANS to the end channel specified by ANE. On reaching the end channel, A/D conversion operation returns to the ANS analog input and the cycle starts again. When the start and end channels are the same (ANS = ANE), conversion is performed continuously for the channel specified in ANS.

Example 1: ANS = "000", ANE = "011"  $\Rightarrow$  Start  $\rightarrow AN0 \rightarrow AN1 \rightarrow AN2 \rightarrow AN3 \rightarrow AN0 \rightarrow PRepeat$ Example 2: ANS = "010", ANE = "010" $\Rightarrow$  Start  $\rightarrow AN2 \rightarrow AN2 \rightarrow AN2 \rightarrow PRepeat$ 

In continuous mode, conversion repeats continuously until "0" is written to the BUSY bit. Writing "0" to the BUSY bit forcibly terminates operation.

Forcibly terminating operation halts the A/D converter mid-conversion and the value being converted at the time cannot be obtained. The result in ADCR is the most recent conversion value prior to halting.

- I<sup>2</sup>OS activation example in continuous conversion mode
- Convert analog inputs AN3 to AN5 and collect two conversion data for each channel.
- Sequentially transfer the conversion data to locations 600H to 60BH.
- Activate by an external edge input.
- Maximum interrupt priority level

□ Setting I<sup>2</sup>OS Set ICR in the interrupt controller. MOV ICR10,#08H .....(1) Set the I<sup>2</sup>OS descriptor. MOV BAPL,#00H.....(2) MOV BAPM,#06H.....(3) MOV BAPH.#00H .....(4) MOV ISCS,#18H .....(5) MOV IOAL,#2EH.....(6) MOV IOAH,#00H.....(6) MOV DCTL,#06H .....(7) MOV DCTH,#00H.....(7)  $\Box$  Set the A/D converter. MOV ADCS0,#9DH .....(8) MOV ADCS1,#A4H .....(9) □ Other processing □ I<sup>2</sup>OS completion interrupt sequence MOV ADCS1,#80H .....(10) RETI

(1) Set maximum interrupt priority, specify I<sup>2</sup>OS activation by the interrupt, and set the descriptor address.

(2)(3)(4)Set the destination address for the conversion data.

- (5) Set word data transfer, increment the destination address after each transfer, and transfer from I/O to memory.
- (6) Set the source address for data transfer.
- (7) Perform I<sup>2</sup>OS data transfer six times ( $3ch \times 2$  data transfers).
- (8) Set continuous conversion mode, start channel AN3, and end channel AN5.
- (9) Specify external edge activation. Start A/D conversion.
- (10) Return from interrupt.



#### ■ Stop mode

In this mode, the A/D converter converts each analog input channel from the start channel specified by ANS to the end channel specified by ANE. However, conversion operation temporarily halts after each conversion. The next trigger received releases the temporary halt. On reaching the end channel specified by ANE, operation returns to the ANS analog input and the cycle starts again.

When the start and end channels are the same (ANS = ANE), conversion is only performed for the channel specified in ANS.

- Example 1: ANS = "000", ANE = "011" $\Rightarrow$  Start  $\rightarrow AN0 \rightarrow halt \rightarrow activate \rightarrow AN1 \rightarrow halt \rightarrow activate \rightarrow AN2 \rightarrow halt \rightarrow activate \rightarrow AN3 \rightarrow halt \rightarrow activate \rightarrow AN0 - Repeat$
- Example 2: ANS = "010", ANE = "010"

 $\Rightarrow \text{Start} \rightarrow \text{AN2} \rightarrow \text{halt} \rightarrow \text{activate} \rightarrow \text{AN2} \rightarrow \text{halt} \rightarrow \text{activate} \rightarrow \text{AN2} \quad \cdot \bullet \text{Repeat}$ 

The available activation sources are the sources set in STS1, 0. This mode can be used to synchronize the conversion start timing.

- I<sup>2</sup>OS activation example in stop mode
- Convert analog input AN3 twelve times at fixed intervals.
- Sequentially transfer the conversion data to locations 600H to 617H.
- Activate by an external edge input.
- Maximum interrupt priority level

| □ Setting I <sup>2</sup> OS                       |     |  |  |  |  |
|---------------------------------------------------|-----|--|--|--|--|
| Set ICR in the interrupt controller.              |     |  |  |  |  |
| MOV ICR10,#08H                                    | 1   |  |  |  |  |
| Set the I <sup>2</sup> OS descriptor.             |     |  |  |  |  |
| MOV BAPL,#00H                                     | 2   |  |  |  |  |
| MOV BAPM,#06H                                     | 3   |  |  |  |  |
| MOV BAPH,#00H                                     | 4   |  |  |  |  |
| MOV ISCS,#18H                                     | (5) |  |  |  |  |
| MOV IOAL,#2EH                                     | 6   |  |  |  |  |
| MOV IOAH,#00H                                     | 6   |  |  |  |  |
| MOV DCTL,#0CH                                     | 0   |  |  |  |  |
| MOV DCTH,#00H                                     | 7   |  |  |  |  |
| $\Box$ Set the A/D converter.                     |     |  |  |  |  |
| MOV ADCS0,#DBH                                    | 8   |  |  |  |  |
| MOV ADCS1,#A4H                                    | 9   |  |  |  |  |
| □ Other processing                                |     |  |  |  |  |
| :                                                 |     |  |  |  |  |
| :                                                 |     |  |  |  |  |
| :                                                 |     |  |  |  |  |
| □ I <sup>2</sup> OS completion interrupt sequence |     |  |  |  |  |
| MOV ADCS1,#80H                                    | 10  |  |  |  |  |
| RETI                                              |     |  |  |  |  |
|                                                   |     |  |  |  |  |

- (1) Set maximum interrupt priority, specify I<sup>2</sup>OS activation by the interrupt, and set the descriptor address.
- (2)(3)(4) Set the destination address for the conversion data.
- (5) Set word data transfer, increment the destination address after each transfer, transfer from I/O to memory, and termination on a request from the resource.
- (6) Set the source address for data transfer.
- (7) Perform I<sup>2</sup>OS data transfer twelve time.
- (8) Set stop mode, start channel AN3, and end channel AN3 (single-channel conversion).
- (9) Specify external edge activation. Start A/D conversion.
- (10) Return from interrupt.



#### 2.5 10-Bit 8-Input A/D Converter (With 8-Bit Resolution Mode)

■ Conversion operation using I<sup>2</sup>OS

The following shows an example using continuous mode. The example shows the steps from A/D conversion activation to conversion data transfer.



☆ Depends on the I<sup>2</sup>OS setting.



Conversion data protection function

A feature of the A/D converter is the conversion data protection function which uses I<sup>2</sup>OS to perform continuous conversion and save multiple data.

The A/D converter has only one conversion data register. Therefore, when continuous A/D conversion saves the new conversion data at conversion completion, this overwrites the previous conversion data. To protect the previous data, the A/D converter has a function to temporarily halt the A/D converter and prevent conversion data being written to the register (even if conversion has already completed) until the previous data has been transferred to memory by I<sup>2</sup>OS.

The temporary halt releases after I<sup>2</sup>OS transfers the data to memory.

If the previous data has already been transferred, the A/D converter continues without a temporary halt.

**Note:** This function depends on the INT and INTE bits in ADCS1.

The data protect function only operates when interrupts are enabled (INTE = "1").

The function does not operate when interrupts are disabled (INTE = "0"). In this case, performing continuous A/D conversion continuously overwrites the register data with new conversion results. Note that the INT bit is not cleared when interrupts are enabled (INTE = "1") but I<sup>2</sup>OS is not used. As a result, the data protection function causes the A/D converter to temporarily halt. In this case, use the interrupt sequence to clear the INT bit and release the halt.

The A/D converter re-starts if interrupts are disabled during  $I^2OS$  operation when the A/D converter is temporarily halted. This may result in the conversion data register contents changing before data transfer occurs.

Also, the data waiting to be written to the register is lost if an activation is received while the A/D converter is temporarily halted.



## Fig. 2.5.3 Data Protection Function Flowchart Using I<sup>2</sup>OS

**Note:** When setting the A/D converter to be activated by an external trigger or internal timer, set the external trigger or internal timer input value to inactive when setting the start source select bits (STS1, 0) in the ADCS1 register. If the input is active, the A/D converter may start to operate.

Set ADTRG = "1" to the input state and internal timer (16-bit reload timer 1) = "0" to the output state when setting STS1, 0.

## 2.5.5 Other Points to Note

Always set the corresponding ADER bit to "1" for each analog input pin used.

| Analog input enable register    | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 🗢 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| ADER 000016 н                   | ADE7         | ADE6         | ADE5         | ADE4         | ADE3         | ADE2         | ADE1         | ADE0         | ADER      |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(1) |           |

Controls each pin of port 6 as follows.

- 0: Port input mode
- 1: Analog input mode

Initialized to "1" by a reset.

- **Note:** Set to analog input mode when inputting an analog signal. Inputting an intermediate level signal to a pin set as an input port causes a leak current to flow.
- **Note:** The ATGX pin is shared with other functions. Unless done intentionally, halt input (INT7) to the pin from other functions.

#### 2.6 PPG

# 2.6 PPG

This block contains the 8-bit reload timer module. The block performs PPG output in which the pulse output is controlled by the operation of the timer.

The hardware consists of two 8-bit down-counters, four 8-bit reload registers, one 16-bit control register, two external pulse output pins, and two interrupt outputs. The unit has the following functions.

- 8-bit PPG output in 2-channel independent operation mode: Two independent PPG output channels are available.
- 16-bit PPG output operation mode: One 16-bit PPG output channel is available.
- 8+8-bit PPG output operation mode: Variable-period 8-bit PPG output operation is available by using the output of ch0 as the clock input to ch1.
- PPG output operation: Outputs pulse waveforms with variable period and duty ratio.

Can be used as a D/A converter in conjunction with an external circuit.

# 2.6.1 Registers



# 2.6.2 Block Diagram



Fig. 2.6.1 Block Diagram of 8-Bit PPG ch0

# 2.6.2 Block Diagram



Fig. 2.6.2 Block Diagram of 8-Bit PPG ch1

# 2.6.3 Register Details

### (1) PPGC0 (PPG0 operation mode control register)

| PPG0 operation mode control register |              | 6          | 5            | 4            | 3            | 2            | 1            | 0          | 🗇 Bit No. |
|--------------------------------------|--------------|------------|--------------|--------------|--------------|--------------|--------------|------------|-----------|
| Address: ch0 000030H                 | PEN0         | -          | POE0         | PIE0         | PUF0         | PCM1         | PCM0         | Reserved   | PPGC0     |
| Read/write ⇔<br>Initial value ⇔      | (R/W)<br>(0) | (-)<br>(-) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0) | (-)<br>(1) |           |

A 6-bit control register that selects the operation mode of the block, controls pin output, selects the count clock, and controls the trigger.

[Bit 7] PEN0 (Ppg ENable): Operation enable bit Starts PPG operation or selects the operation mode as follows.

| PEN0 | Operation State                              |  |  |  |
|------|----------------------------------------------|--|--|--|
| 0    | Operation stopped (output held at "L" level) |  |  |  |
| 1    | PPG operation enabled                        |  |  |  |

Writing "1" to this bit starts the PPG counting. Initialized to "0" by a reset. Readable and writable.

[Bit 5] POE0 (Ppg Output Enable): PPG pin output enable bit Controls the external pulse output pin (PPG0) as follows.

| 0 | General-purpose port pin (pulse output disabled) |
|---|--------------------------------------------------|
| 1 | PPG0 = pulse output pin (pulse output enabled)   |

Initialized to "0" by a reset. Readable and writable.

[Bit 4] PIE0 (Ppg Interrupt Enable): PPG interrupt enable bit Controls PPG interrupt enable as follows.

| 0 | Interrupts disabled |
|---|---------------------|
| 1 | Interrupts enabled  |

When this bit is "1", an interrupt request is generated when PUF0 becomes "1". No interrupt request is generated if this bit is "0".

Initialized to "0" by a reset. Readable and writable.

[Bit 3] PUF0 (Ppg Underflow Flag): PPG counter underflow bit The meaning of the PPG counter underflow bit is as follows.

| 0 | No PPG counter underflow detected. |
|---|------------------------------------|
| 1 | PPG counter underflow detected.    |

In 2-channel 8-bit PPG mode or 8-bit prescaler + 8-bit PPG mode, this bit is set to "1" when an underflow occurs in ch0 (when the counter value changes from 00H to FFH). In single channel 16-bit PPG mode, this bit is set to "1" when an underflow occurs in ch1/ch0 (when the counter value changes from 0000H to FFFFH). Writing "0" to this bit changes the bit to "0". Writing "1" has no meaning. Reading returns "1" in read-modify-write instructions.

Initialized to "0" by a reset. Readable and writable.

[Bits 2, 1] PCM1/0 (Ppg Count Mode): Count clock selection bits Selects the operating clock for the down-counter as follows.

| PCM1 | PCM0 | Operation Mode                                                                    |
|------|------|-----------------------------------------------------------------------------------|
| 0    | 0    | Peripheral clock (62.5ns for a 16 MHz machine clock)                              |
| 0    | 1    | Peripheral clock/4 (250ns for a 16 MHz machine clock)                             |
| 1    | 0    | Peripheral clock/16 (1 µs for a 16 MHz machine clock)                             |
| 1    | 1    | Input clock from the timebase counter (128 $\mu s$ for a 4 MHz source oscillator) |

Initialized to "00" by a reset. Readable and writable.

[Bit 0] Reserved bit. Always set to "1" when setting PPGC0.

### (2) PPGC1 (PPG1 operation mode control register)

| PPG1 operation mode control register | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8          | ⇔ Bit No. |
|--------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|------------|-----------|
| Address: ch1 000031H                 | PEN1         | PCS1         | POE1         | PIE1         | PUF1         | MD1          | MD0          | Reserved   | PPGC1     |
| Read/write ⇔<br>Initial value ⇔      | (R/W)<br>(0) | (-)<br>(1) |           |

A 7-bit control register that selects the operation mode of the block, controls pin output, selects the count clock, and controls the trigger.

[Bit 15] PEN1 (Ppg ENable): Operation enable bit

Starts PPG operation or selects the operation mode as follows.

| PEN1 | Operation State                              |
|------|----------------------------------------------|
| 0    | Operation stopped (output held at "L" level) |
| 1    | PPG operation enabled                        |

Writing "1" to this bit starts PPG counting.

Initialized to "0" by a reset. Readable and writable.

[Bit 14] PCS1 (Ppg Count Select): Count clock selection bit Selects the operating clock for the down-counter as follows.

| 0 | Peripheral clock (62.5ns for a 16 MHz machine clock)                              |
|---|-----------------------------------------------------------------------------------|
| 1 | Input clock from the timebase counter (128 $\mu s$ for a 4 MHz source oscillator) |

Initialized to "0" by a reset. Readable and writable.

**Note:** The PCS1 bit setting is ignored in 8-bit prescaler + 8-bit PPG mode and 16-bit PPG mode. In these modes, the count clock for ch1 of the PPG is received from ch0.

[Bit 13] POE1 (Ppg Output Enable): PPG pin output enable bit Controls the external pulse output pin (PPG1) as follows.

| 0 | General-purpose port pin (pulse output disabled) |
|---|--------------------------------------------------|
| 1 | PPG1 = pulse output pin (pulse output enabled)   |

Initialized to "0" by a reset. Readable and writable.

[Bit 12] PIE1 (Ppg Interrupt Enable): PPG interrupt enable bit Controls PPG interrupt enable as follows.

| 0 | Interrupts disabled |
|---|---------------------|
| 1 | Interrupts enabled  |

When this bit is "1", an interrupt request is generated when PUF1 becomes "1". No interrupt request is generated if this bit is "0".

Initialized to "0" by a reset. Readable and writable.

[Bit 11] PUF1 (Ppg Underflow Flag): PPG counter underflow bit The meaning of the PPG counter underflow bit is as follows.

| 0 | No PPG counter underflow detected. |
|---|------------------------------------|
| 1 | PPG counter underflow detected.    |

In 2-channel 8-bit PPG mode or 8-bit prescaler + 8-bit PPG mode, this bit is set to "1" when an underflow occurs in ch1 (when the counter value changes from 00H to FFH). In single channel 16-bit PPG mode, this bit is set to "1" when an underflow occurs in ch1/ch0 (when the counter value changes from 0000H to FFFH). Writing "0" to this bit changes the bit to "0". Writing "1" has no meaning. Reading returns "1" in read-modify-write instructions.

Initialized to "0" by a reset. Readable and writable.

[Bits 10, 9] MD1, 0 (PPG count MoDe): Operation mode selection bits Selects the operating mode of the PPG timer as follows.

| MD1 | MD0 | Operation Mode                                  |
|-----|-----|-------------------------------------------------|
| 0   | 0   | 2-channel independent 8-bit PPG mode            |
| 0   | 1   | Single channel 8-bit prescaler + 8-bit PPG mode |
| 1   | 0   | Reserved (prohibited setting)                   |
| 1   | 1   | Single channel 16-bit PPG mode                  |

Initialized to "00" by a reset. Readable and writable.

**Note:** Do not set these bits to "10".

- **Note:** Do not set the PEN0 bit of PPGC0 and the PEN1 bit of PPGC1 to "01" when the MD bits are set to "01". Setting the PEN0 and PEN1 bits to "11" or "00" is recommended.
- **Note:** When setting the MD bits to "11", write to PPGC0 and PPGC1 using a word write and set the PEN0 and PEN1 bits to "11" or "00" at the same time.

[Bit 8] Reserved bit. Always set to "1" when setting PPGC1.

# (3) PRLL/PRLH (Reload registers)



Two 8-bit registers that store the reload values loaded to the down-counter PCNT. The registers are used as follows.

| Register | Function                       |
|----------|--------------------------------|
| PRLL     | Stores the L-side reload value |
| PRLH     | Stores the H-side reload value |

Both registers are readable and writable.

**Note:** The ch1 PPG waveform may be different for each cycle if different values are set in PRLL and PRLH for ch0 when using 8-bit prescaler + 8-bit PPG mode. Therefore, setting the same value in both ch0 registers (PRLL and PRLH) is recommended.

# 2.6.4 Operation

The block consists of two 8-bit PPG units. The two channels can be used independently (2-channel independent mode) or linked for 8-bit prescaler + 8-bit PPG mode or single-channel 16-bit PPG mode. This gives a total of three different operation modes.

Both 8-bit PPG units have L-side and H-side 8-bit reload registers (PRLL and PRLH). The values written to these registers are used alternately to reload the 8-bit down-counter (PCNT) for the L-side and H-side counts respectively. The PCNT value is down-counted with each count clock until a borrow triggers a reload and inverts the output pin (PPG) level. As a result of this operation, the output pin (PPG) outputs pulses with an H-width and L-width determined by the reload register values.

Operation is started or re-started by writing to a register bit.

The following table shows the relationship between the reload operation and pulse output.

| Reload Operation | Output Change at Pin   |
|------------------|------------------------|
| PRLH ⇔ PCNT      | PPG0/1 [0 ⇔ 1] _F Rise |
| PRLL ⇔ PCNT      | PPG0/1 [1 ⇔ 0] ⊐_ Fall |

 Table 1 Relationship Between Reload Operation and Pulse Output

Also, when bit 4 (PIE0) of PPGC0 or bit 12 (PIE1) of PPGC1 is "1", an interrupt request is output when the corresponding borrow occurs as the counter value changes from 00H to FFH. (For 16-bit PPG mode, the borrow occurs as the counter value changes from 0000H to FFFFH.)

### (1) Operation modes

The block has a total of three different operation modes: 2-channel independent mode, 8-bit prescaler + 8-bit PPG mode, and single-channel 16-bit PPG mode.

In 2-channel independent mode, the two channels operate as independent 8-bit PPGs. The PPG output of ch0 is connected to the PPG0 pin and the PPG output of ch1 is connected to the PPG1 pin.

In 8-bit prescaler + 8-bit PPG mode, ch0 operates as an 8-bit prescaler and ch1 counts on each ch0 borrow. This operation mode produces a variable-period 8-bit PPG waveform output. The prescaler output of ch0 is connected to the PPG0 pin and the PPG output of ch1 is connected to the PPG1 pin.

In single-channel 16-bit PPG mode, the upper and lower registers of ch0 and ch1 are linked to operate as a single 16-bit PPG. (That is, the PRLL0 and PRLL1 registers and the PRLH0 and PRLH1 registers are linked.) The 16-bit PPG output is connected to both the PPG0 and PPG1 pins.

### (2) PPG output operation

Set "1" to bit 7 (PEN0) of the PPGC0 (PPG operation mode control) register or bit 15 (PEN1) of the PPGC1 register to activate PPG0 or PPG1 respectively and start counting. After starting operation, writing "0" to bit 7 (PEN0) of the PPGC0 register or bit 15 (PEN1) of the PPGC1 register stops count operation and holds the pulse output at the "L" level.

In 8-bit prescaler + 8-bit PPG mode, do not start ch1 operation when ch0 is stopped.

In single-channel 16-bit PPG mode, always start or stop operation by bit 7 (PEN0) of the PPGC0 register and bit 15 (PEN1) of the PPGC1 register together.

The following describes PPG output operation.

Variable frequency and duty ratio pulse waveforms are output continuously during PPG operation. (The duty ratio is the ratio of the H-level and L-level durations in the pulse waveform.) Once started, PPG pulse waveform output does not stop until operation stop is specified.



### Fig. 1.0.3 Figure 2.6.3 PPG Output Operation and Output Waveforms

#### (3) Relationship between the reload values and pulse width

The output pulse width is the product of the value written in the reload register + 1 and the count clock period. Note that a reload register value of 00H for 8-bit PPG operation or 0000H for 16-bit PPG operation generates a pulse width of one count clock cycle. Also, a reload register value of FFH in 8-bit PPG operation generates a pulse width of 256 count clock cycles and a reload register value of FFFFH in 16-bit PPG operation generates a pulse width of 65536 count clock cycles. The pulse width is calculated as follows.

| $\mathbf{DI} = \mathbf{T}_{\mathbf{Y}}(\mathbf{I} + 1)$ | $\int$ L: PRLL value                                                              |
|---------------------------------------------------------|-----------------------------------------------------------------------------------|
| $\mathbf{PI} = \mathbf{T} \times (\mathbf{L} + 1)$      | H: PRLH value                                                                     |
| $Ph = T \times (H+1)$                                   | T: Input clock period                                                             |
|                                                         | L: PRLL value<br>H: PRLH value<br>T: Input clock period<br>Ph: H-side pulse width |
|                                                         | PI: L-side pulse width                                                            |

#### (4) Count clock selection

This block can select from four count clock inputs, using either the peripheral clock or timebase counter input. (ch1 of the PPG can only select from two count clocks.)

When bits 2 and 1 (PCM1, 0) of the PPGC0 register are "00", the count clock counts once for each peripheral clock count.

When bits 2 and 1 (PCM1, 0) of the PPGC0 register are "01", the count clock counts once for each four peripheral clock counts.

When bits 2 and 1 (PCM1, 0) of the PPGC0 register are "10", the count clock counts once for each 16 peripheral clock counts.

When bits 2 and 1 (PCM1, 0) of the PPGC0 register are "11", the count clock counts once for each timebase counter input.

When bit 14 (PCS1) of the PPGC1 register is "0", the count clock counts once for each peripheral clock count.

When bit 14 (PCS1) of the PPGC1 register is "1", the count clock counts once for each timebase counter input.

However, bit 14 (PCS1) of the PPGC1 register has no meaning in 8-bit prescaler + 8-bit PPG mode and 16-bit PPG mode. In these modes, ch1 of the PPG receives its count clock from ch0.

When using the timebase counter input, note that the count period may vary for the first count after activation by the trigger or the first count after a stop. The period may also vary if the timebase counter is cleared during operation of this module.

Also, when using 8-bit prescaler + 8-bit PPG mode, note that the period of the first count may vary if ch0 is already operating when ch1 is changed from stopped to activated.

#### (5) Controlling pulse output from the pin

The pulse outputs generated by this module can be output from external pins PPG0 and PPG1.

Bit 5 (POE0) of PPGC0 enables external output from pin PPG0 and bit 13 (POE1) of PPGC1 enables external output from pin PPG1. When these bits are set to "0" (initial value), pulse output from the external pin is disabled and the pin functions as a general-purpose port. Setting the bits to "1" enables pulse output from the external pin.

As PPG0 and PPG1 output the same waveforms in 16-bit PPG mode, enabling either of these external output pins produces the same output.

In 8-bit prescaler + 8-bit PPG mode, PPG0 outputs the toggle waveforms from the 8-bit prescaler and PPG1 outputs the 8-bit PPG waveforms. The following shows an example of the output waveforms in this mode.



Note: Setting the same value to PRLL and PRLH for ch0 is recommended.

# Fig. 1.0.4 8+8 PPG Output Operation and Output Waveforms

#### (6) Interrupts

The interrupts for this module become active when the reload value counts-out and a borrow occurs.

In 2-channel 8-bit PPG mode and 8-bit prescaler + 8-bit PPG mode, interrupt requests are generated for each counter borrow. In 16-bit PPG mode, PUF0 and PUF1 are set simultaneously by the 16-bit counter borrow. Therefore, enabling only one of PIE0 and PIE1 is recommended so as to produce only one source of interrupt. Clearing the sources of interrupt in both PUF0 and PUF1 is also recommended.

### (7) Initial values for each hardware element

The hardware elements in this block are initialized by a reset as follows. <Registers>

• PPGC0 ⇒ 0Х00001в

• PPGC1 ⇒ 0000001B

<Pulse output>

 $\begin{array}{c} PPG0 \Leftrightarrow "L"\\ PPG1 \Leftrightarrow "L"\\ POE0 \Leftrightarrow PPG0 \text{ output inhibit}\\ POE1 \Leftrightarrow PPG1 \text{ output inhibit}\\ < Interrupt request>\\ IRQ0 \Leftrightarrow "L"\\ IRO1 \Leftrightarrow "L"\\ \end{array}$ 

Hardware elements other than those listed above are not initialized.

Note: Write timings to the reload register

Writing to the reload registers (PRLL and PRLH) using word move instructions is recommended in modes other than 16-bit PPG mode. Writing using two byte transfer instructions may result in output of an unexpected pulse width, depending on the timing.



Fig. 1.0.5 Write Timing Timechart

If the value of PRLL is changed from A to C before timing (1) on the timechart and the value of PRLH is changed from B to D after timing (1), the value of PRL at timing 1 is PRLL=C and PRLH=B. This results in the output of one pulse cycle with an L pulse width of C counts and an H pulse width of B counts.

Similarly, in 16-bit PPG mode, write to the PRL registers for ch0 and ch1 using a long word move instruction, or write to ch0 first and ch1 second using word move instructions. In this mode, writing to the ch0 PRL register only performs a temporary write. The actual write to the ch0 PRL register is performed at the same timing as the write to the ch1 PRL register.

In modes other than 16-bit PPG mode, the PRL registers for ch0 and ch1 can be written to independently.



# Fig. 1.0.6 Block Diagram of the Steps for Writing to PRL

**Note:** The PPG0 and PPG1 pins are shared with other functions. Unless done intentionally, halt input (INT5 and INT6) to the pins from other functions.

#### 2.7 16-Bit Reload Timer (With Event Count Function)

# 2.7 16-Bit Reload Timer (With Event Count Function)

The 16-bit reload timers consists of a 16-bit down-counter, a 16-bit reload register, one input (TIN) and one output (TOT) pin, and a control register. The input clock can be selected from one external clock and three types of internal clock. The output pin (TOT) outputs a toggle waveform in reload mode and a rectangular waveform during counting in one-shot mode. The input pin (TIN) functions as the event input in event count mode and as the trigger input or gate input in internal clock mode.

This product has two internal 16-bit reload timer channels.

# 2.7.1 Registers



# 2.7.2 Block Diagram



Fig. 2.7.1 Block Diagram

# 2.7.3 Register Details

### (1) TMCSR (Timer control status register)

■ Register layout



Register contents

Controls the operation mode and interrupts for the 16-bit timer. Only modify bits other than UF, CNTE, and TRG when CNTE = "0".

#### ■ Bit meanings

[Bits 11, 10] CSL1, CSL0 (Clock SeLect 1, 0) The count clock select bits. Table 2.7.1 lists the clock source selections.

| CSL1 | CSL0 | Clock Source (Machine cycle $\phi$ = 16 MHz) |
|------|------|----------------------------------------------|
| 0    | 0    | φ/2¹ (0.125 μs)                              |
| 0    | 1    | φ/2³ (0.5 μs)                                |
| 1    | 0    | φ/2 <sup>5</sup> (2.0 μs)                    |
| 1    | 1    | External event count mode                    |

Table 2.7.1 CSL Bit Clock Source Settings

[Bits 9, 8, 7] MOD2, MOD1, MOD0

These bits set the operation mode and I/O pin functions.

Internal clock mode (CSL0, 1 = "00", "01", or "10")

The MOD2 bit selects the I/O functions. When MOD2 = "0", the input pin functions as a retrigger input. In this case, the reload register is loaded to the counter when an active edge is input to the input pin and count operation proceeds. When MOD2 = "1", the timer operates in gate counter mode and the input pin functions as a gate input. In this mode, the counter only counts while an active level is input to the input pin.

The MOD1, 0 bits set the pin functions for each mode. Tables 2.7.2 and 2.7.3 list the MOD2, 1, 0 bit settings.

| MOD2 | MOD1 | MOD0 | Input Pin Function | Active Edge or Level |
|------|------|------|--------------------|----------------------|
| 0    | 0    | 0    | Trigger disabled   | -                    |
| 0    | 0    | 1    | Trigger input      | Rising edge          |
| 0    | 1    | 0    | Ŷ                  | Falling edge         |
| 0    | 1    | 1    | 仓                  | Both edges           |
| 1    | ×    | 0    | Gate input         | "L" level            |
| 1    | ×    | 1    | Ŷ                  | "H" level            |

### Table 2.7.2 MOD2, 1, 0 Bit Settings (1)

Table 2.7.3 MOD2, 1, 0 Bit Settings (2)

Event counter mode (CSL0, 1 = "11")

| MOD2 | MOD1             | MOD0 | Input Pin Function | Active Edge or Level |
|------|------------------|------|--------------------|----------------------|
|      | 0                | 0    | -                  | -                    |
| ×    | 0 1 Trigger inpu |      | Trigger input      | Rising edge          |
| ^    | 1                | 0    | Ŷ                  | Falling edge         |
|      | 1                | 1    | Ŷ                  | Both edges           |

**Note:** Bits marked as  $\times$  in the table can be set to any value.

#### [Bit 6] OUTE

Output enable bit. The TOT pin functions as a general-purpose port when this bit is "0" and as the timer output pin when this bit is "1". In reload mode, the output waveform toggles. In one-shot mode, TOT outputs a rectangular waveform that indicates when counting is in progress.

#### 2.7 16-Bit Reload Timer (With Event Count Function)

#### [Bit 5] OUTL

This bit sets the output level for the TOT pin. When OUTL is "0" or "1", the output pin level is opposite.

| OUTE | RELD | OUTL | Output Waveform                                     |
|------|------|------|-----------------------------------------------------|
| 0    | х    | х    | General-purpose port                                |
| 1    | 0    | 0    | Output an "H" rectangular waveform during counting. |
| 1    | 0    | 1    | Output an "L" rectangular waveform during counting. |
| 1    | 1    | 0    | Toggle output. "L" level at count start.            |
| 1    | 1    | 1    | Toggle output. "H" level at count start.            |

Table 2.7.4 OUTE, RELD, and OUTL Settings

#### [Bit 4] RELD (RELoaD)

This bit enables reload operations. When RELD = "1", the timer operates in reload mode. In this mode, the timer loads the reload register contents into the counter and continues counting whenever an underflow occurs (when the counter value changes from 0000H to FFFFH). When RELD = "0", the timer operates in one-shot mode. In this mode, the count operation stops when an underflow occurs due to the counter value changing from 0000H to FFFFH.

#### [Bit 3] INTE (INTerrupt Enable)

Timer interrupt request enable bit. When INTE is "1", an interrupt request is generated when the UF bit changes to "1". When INTE is "0", no interrupt request is generated when the UF bit changes to "1".

#### [Bit 2] UF (UnderFlow)

Timer interrupt request flag. UF is set to "1" when an underflow occurs (when the counter value changes from 0000H to FFFFH). Cleared by writing "0" or by the intelligent I/O service. Writing "1" to this bit has no meaning. Read as "1" by read-modify-write instructions.

#### [Bit 1] CNTE (CouNT Enable)

Timer count enable bit. Writing "1" to CNTE sets the timer to wait for a trigger. Writing "0" stops count operation.

#### [Bit 0] TRG (TRiGger)

Software trigger bit. Writing "1" to TRG applies a software trigger, causing the timer to load the reload register contents to the counter and start counting. Writing "0" has no meaning. Reading always returns "0". Applying a trigger using this register is only valid when CNTE = "1". Writing "1" has no effect if CNTE = "0".

#### (2) TMR (16-bit timer register)/TMRLR (16-bit reload register)

### Register layout



#### ■ TMR contents

Reading this register reads the count value of the 16-bit timer. The initial value is undefined. Always read this register using word move instructions.

#### ■ TMRLR contents

The 16-bit reload register holds the initial count value. The initial value is indeterminate. Always write to this register using word move instructions.

#### 2.7 16-Bit Reload Timer (With Event Count Function)

# 2.7.4 Operation

### (1) Internal clock operation

The machine clock divided by  $2^1$ ,  $2^3$ , or  $2^5$  can be selected as the clock source when operating the timer from an internal clock. The external input pin can be selected as either a trigger input or gate input by a register setting.

Writing "1" to both the CNTE and TRG bits in the control register enables and starts counting simultaneously. Using the TRG bit as a trigger input is always available when the timer is enabled (CNTE = "1"), regardless of the operation mode.

Figure 2.7.2 shows counter activation and counter operation. A time period T (T: machine cycle) is required from the counter start trigger being input until the reload register data is loaded into counter.



Fig. 2.7.2 Counter Activation and Operation

### (2) Underflow operation

An underflow is defined for this timer as the time when the counter value changes from 0000H to FFFFH. Therefore, an underflow occurs after (reload register setting + 1) counts.

If the RELD bit in the control register is "1" when the underflow occurs, the contents of the reload register is loaded into the counter and counting continues. When RELD is "0", counting stops with the counter at FFFFH.

The UF bit in the control register is set when the underflow occurs. If the INTE bit is "1" at this time, an interrupt request is generated.

Figure 2.7.3 shows the operation when an underflow occurs.



Fig. 2.7.3 Underflow Operation

### (3) Input pin functions (for internal clock mode)

The TIN pin can be used as either a trigger input or a gate input when an internal clock is selected as the clock source. When used as a trigger input, input of an active edge causes the timer to load the contents of the reload register into the counter, clear the internal prescaler, and start counting. Input a pulse width of at least  $2 \times T$  (T is the machine cycle) to TIN. Figure 2.7.4 shows the operation of trigger input.



# Fig. 2.7.4 Trigger Input Operation

When used as a gate input, the counter only counts while the active level specified by the MOD0 bit of the control register is input to the TIN pin. The count clock operates continuously during this time. The software trigger can be used in gate mode, regardless of the gate level. Input a pulse width of at least  $2 \times T$  (T is the machine cycle) to the TIN pin. Figure 2.7.5 shows the operation of gate input.



# Fig. 2.7.5 Gate Input Operation

### (4) External event counter

The TIN pin functions as an external event input pin when an external clock is selected. The counter counts on the active edge specified in the register. Input a pulse width of at least  $4 \times T$  (T is the machine cycle) to the TIN pin.

#### (5) Output pin functions

In reload mode, the TOT pin performs toggle output (inverts at each underflow). In one-shot mode, the TOT pin functions as a pulse output that outputs a particular level while the count is in progress. The OUTL bit of the control register sets the output polarity. When OUTL = "0", the initial value for toggle output is "0" and the one-shot pulse output is "1" while the count is in progress. The opposite levels are output when OUTL = "1".



[RELD=1, OUTL=0]





[RELD=0, OUTL=0]

Fig. 2.7.7 Output Pin Functions (2)

### (6) Intelligent I/O service (I<sup>2</sup>OS) function and interrupts

The timer includes a circuit that supports I<sup>2</sup>OS. The timer can activate I<sup>2</sup>OS when an underflow occurs. I<sup>2</sup>OS can be used with both timers on this product. However, as both timers (ch0 and ch1) are connected to the same interrupt control register (ICRx) in the interrupt controller, ch0 and ch1 cannot be assigned to different I<sup>2</sup>OS services. Also, as the two timers have different interrupt vectors, they can be assigned to different interrupt services. However, as ch0 and ch1 share an interrupt control register as described above, the same interrupt level applies to both channels.

### (7) Counter operation state

The counter state is determined by the CNTE bit in the control register and the internal WAIT signal. Available states are: CNTE = "0" and WAIT = "1" (STOP state), CNTE = "1" and WAIT = "1" (WAIT state), and CNTE = "1" and WAIT = "0" (RUN state). Figure 2.7.8 shows the transitions between each state.



Fig. 2.7.8 Counter State Transitions

# 2.8 Chip Select Function

### 2.8.1 Outline

This module generates chip select signals to simplify connection of memory or I/O devices. The module has 8 chip select output pins. The hardware outputs the chip select signals from the pins when it detects access of an address in the areas specified in the pin registers.

# 2.8.2 Block Diagram



Fig. 2.8.1 Block Diagram of Chip Select

# 2.8.3 Registers



# 2.8.4 Register Details

O Chip select control registers (CSCR0 to 7)

| 15/07 | 14/06 | 13/05 | 12/04 | 11/03 | 10/02 | 09/01 | 08/00 | 🗇 Bit No.     |
|-------|-------|-------|-------|-------|-------|-------|-------|---------------|
| -     | -     | -     | -     | ACTL  | OPEL  | CSA1  | CSA0  | CSCR0 to 7    |
| -     | -     | -     | -     | 0     | 0     | 0     | 0     | Initial value |
| -     | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | Read/write    |

[Bits 15/07 to 12/04]: Unused bits Unused bits. The read value is undefined.

[Bit 11/03]: ACTL

These bits set the active level for pins CS0 to 7. Set as follows.

"0": Output "L" from the CS0 to 7 pin when an address is decoded.

"1": Output "H" from the CS0 to 7 pin when an address is decoded.

[Bit 10/02]: OPEL (Pin output is always enabled for CS0.)

These bits enable or disable external output for pins CS1 to 7. The settings are as follows. Note that CS0 is always enabled and so setting is not necessary.

"0": Disable decoding output from the CS1 to 7 pin.

"1": Enable decoding output from the CS1 to 7 pin.

[Bits 09/01 to 08/00]: CSA1, CSA0

These bits select the address decode range (ROM, RAM, or external circuit) for each chip select pin. See Table 2.8.1 for details of the ranges and sizes.

### 2.8.5 Operation

O When the CPU accesses program or data, the chip select module decodes the highest and lowest order bytes of the address and activates the chip select signals based on the output setting registers.



- O This module's chip select function sets the CS0 to 7 pin signals to active when the CPU accesses an area specified by the CSA1 and CSA0 bits in the output setting register. The table below lists the bit settings.O Output can be masked by setting the OPEL bit in the output setting register.
- O The active level of the CS0 to 7 pins can be changed using the ACTL bit in the output setting register.

| Pin  | CS | SA | Decode Area        | Area Size                                                                                                         | Remarks                                                  |  |  |  |
|------|----|----|--------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--|--|--|
|      | 1  | 0  | Decode Area        | (Bytes)                                                                                                           | Rellidiks                                                |  |  |  |
|      | 0  | 0  | F00000н to FFFFFFн | 1 Mbyte                                                                                                           |                                                          |  |  |  |
| CS0  | 0  | 1  | F80000н to FFFFFFн | Goes active when a program<br>ROM area or program vector                                                          |                                                          |  |  |  |
|      | 1  | 0  | FE0000н to FFFFFFн | 128 Kbyte                                                                                                         | fetch occurs.                                            |  |  |  |
|      | 1  | 1  | -                  | NoveROM are<br>fetch oci128 Kbytefetch oci1 MbyteUse for<br>areas, o<br>circuits.128 KbyteUse for<br>areas, o<br> |                                                          |  |  |  |
|      | 0  | 0  | E00000н to EFFFFFн | 1 Mbyte                                                                                                           |                                                          |  |  |  |
| CS1  | 0  | 1  | F00000н to F7FFFFн | 512 Kbyte                                                                                                         | Use for data ROM or RAM<br>areas, or for external        |  |  |  |
| 0.51 | 1  | 0  | FC0000H to FDFFFFH | 128 Kbyte                                                                                                         |                                                          |  |  |  |
|      | 1  | 1  | 68FF80н to 68FFFFн | 128 byte                                                                                                          |                                                          |  |  |  |
|      | 0  | 0  | -                  | For future use                                                                                                    |                                                          |  |  |  |
| 662  | 0  | 1  | FA0000H to FBFFFFH | 128 Kbye                                                                                                          | Use for data ROM or RAM                                  |  |  |  |
| CS2  | 1  | 0  | 68FF80н to 68FFFFн | 128 byte                                                                                                          | <ul> <li>areas, or for external<br/>circuits.</li> </ul> |  |  |  |
|      | 1  | 1  | 68FF00н to 68FF7Fн | 128 byte                                                                                                          |                                                          |  |  |  |
| CS3  | 0  | 0  | F80000н to F9FFFFн | 128 Kbyte                                                                                                         |                                                          |  |  |  |
|      | 0  | 1  | 68FF00н to 68FF7Fн | 128 byte                                                                                                          | Use for I/O or RAM areas, or                             |  |  |  |
|      | 1  | 0  | 68FE80н to 68FEFFн | 128 byte                                                                                                          | for external circuits.                                   |  |  |  |
|      | 1  | 1  | 0000C0н to 0000FFн | 64 byte                                                                                                           |                                                          |  |  |  |
|      | 0  | 0  | -                  | For future use                                                                                                    |                                                          |  |  |  |
| CS4  | 0  | 1  | 68FE80н to 68FEFFн | 128 byte                                                                                                          | Use for I/O or RAM areas, or                             |  |  |  |
| 0.04 | 1  | 0  | 0000C0н to 0000FFн | 64 byte                                                                                                           | for external circuits.                                   |  |  |  |
|      | 1  | 1  | 0000E0н to 0000FFн | 32 byte                                                                                                           |                                                          |  |  |  |
|      | 0  | 0  | 68FF80н to 68FFFFн | 128 byte                                                                                                          |                                                          |  |  |  |
| CS5  | 0  | 1  | 0000C0н to 0000FFн | 64 byte                                                                                                           | Use for I/O or RAM areas, or                             |  |  |  |
| 035  | 1  | 0  | 0000E0н to 0000FFн | 32 byte                                                                                                           | for external circuits.                                   |  |  |  |
|      | 1  | 1  | 0000D8н to 0000DFн | 8 byte                                                                                                            |                                                          |  |  |  |
|      | 0  | 0  | 68FF00н to 68FF7Fн | 128 byte                                                                                                          |                                                          |  |  |  |
| CS6  | 0  | 1  | 0000C0н to 0000FFн | 64 byte                                                                                                           | Use for I/O or RAM areas, or                             |  |  |  |
| 030  | 1  | 0  | 0000E0н to 0000FFн | 32 byte                                                                                                           | for external circuits.                                   |  |  |  |
|      | 1  | 1  | 0000D0н to 0000D7н | 8 byte                                                                                                            |                                                          |  |  |  |
|      | 0  | 0  | 0000C0] to 0000FFн | 64 byte                                                                                                           |                                                          |  |  |  |
| CS7  | 0  | 1  | 0000E0н to 0000FFн | 32 byte                                                                                                           | Use for I/O or RAM areas, or                             |  |  |  |
| 03/  | 1  | 0  | 0000C8н to 0000CFн | 8 byte                                                                                                            | for external circuits.                                   |  |  |  |
|      | 1  | 1  | - For future use   |                                                                                                                   |                                                          |  |  |  |

Table 2.8.1 Address Decoding Areas

### \_\_\_ < NOTE > \_\_

- As the CS0 pin outputs the decode signal for the program vector fetch after a reset (initial state) (from the 128Kbyte program ROM region between FE0000H and FFFFFFH), always use this pin for program ROM. The active output level for this pin is "L".
- As the chip select decode signal pins are initialized as port inputs, you must set each setting register explicitly. (Except for the CS0 pin which is a dedicated pin and does not need to be set.)

|              | Pin                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CS0  | CS1  | CS2  | CS3  | CS4  | CS5  | CS6  | CS7  |
|--------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------|
|              | CSA                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 001- | 0011 | -011 | 0011 | -011 | 0011 | 0011 | 011- |
|              | UUA                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 010- | 0101 | -101 | 0101 | -101 | 0101 | 0101 | 010- |
| Address Area | 68FF8<br>68FF0<br>68FE8<br>00010<br>0000E<br>0000E<br>0000D | 0H -<br>0H |      |      |      |      |      |      |      |      |

Fig. 2.8.2 Address Decoding Map (See Table 2.8.1 for the details of the decoding areas)



Fig. 2.8.3 CS0 Output after Release of a Reset

#### 2.9 DTP/External Interrupts

# 2.9 DTP/External Interrupts

The DTP (Data Transfer Peripheral) is a peripheral block that interfaces external peripherals to the F<sup>2</sup>MC-16L CPU. The DTP receives DMA and interrupt processing requests from external peripherals and passes the requests to the F<sup>2</sup>MC-16L CPU to activate the extended intelligent I/O service or interrupt processing. Two request levels ("H" and "L") are provided for extended intelligent I/O. For external interrupt requests, generation of interrupts on a rising or falling edge as well as on "H" and "L" levels can be selected, giving a total of four types.

# 2.9.1 Registers

| Interrupt/DTP enable register          | 7            | 6            | 5              | 4            | 3              | 2              | 1            | 0              | 🗇 Bit No. |
|----------------------------------------|--------------|--------------|----------------|--------------|----------------|----------------|--------------|----------------|-----------|
| Address: 000028н                       | EN7          | EN6          | EN5            | EN4          | EN3            | EN2            | EN1          | EN0            | ENIR      |
| Read/write ⇔<br>Initial value ⇔        | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0)   | (R/W)<br>(0) | ) (R/W<br>(0)  | ) (R/W)<br>(0) | (R/W<br>(0)  | ) (R/W)<br>(0) |           |
| Interrupt/DTP register                 | 15 1         | 4            | 13             | 12           | 11             | 10             | 9            | 8 🖨            | Bit No.   |
| Address: 000029H                       | ER7 E        | R6 E         | ER5            | ER4          | ER3            | ER2            | ER1          | ER0            | EIRR      |
| Read/write ⇔<br>Initial value ⇔        |              |              | R/W) (I<br>(0) | R/W)<br>(0)  | (R/W)<br>(0)   | (R/W)<br>(0)   | (R/W)<br>(0) | (R/W)<br>(0)   |           |
| Request level setting register (upper) | 15           | 14           | 13             | 12           | 11             | 10             | 9            | 8              | ⇔ Bit No. |
| Address: 00002BH                       | LB7          | LA7          | LB6            | LA6          | LB5            | LA5            | LB4          | LA4            |           |
| Read/write ⇔<br>Initial value ⇔        | (R/W)<br>(0) | (R/W)<br>(0) | (R/W)<br>(0)   | (R/W)<br>(0) | ) (R/W)<br>(0) | ) (R/W)<br>(0) | (R/W<br>(0)  | ) (R/W)<br>(0) |           |
| Request level setting register (lower) | 7            | 6            | 5              | 4            | 3              | 2              | 1            | 0 🛱            | Bit No.   |
| Address: 00002AH                       | LB3 L        | .A3 I        | LB2            | LA2          | LB1            | LA1            | LB0          | LA0            | ELVR      |
| Read/write ⇔<br>Initial value ⇔        | . , .        | , ,          | R/W) (I<br>(0) | R/W)<br>(0)  | (R/W)<br>(0)   | (R/W)<br>(0)   | (R/W)<br>(0) | (R/W)<br>(0)   |           |

# 2.9.2 Block Diagram



Fig. 2.9.1 Block Diagram

# 2.9.3 Register Details

### (1) ENIR (Interrupt/DTP enable register)

■ Register layout

| Interrupt/DTP enable register   | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            | 🗇 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| Address: 000028H                | EN7          | EN6          | EN5          | EN4          | EN3          | EN2          | EN1          | EN0          | ENIR      |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) |           |

#### ■ Register contents

The ENIR register enables or disables the function that generates interrupt requests to the interrupt controller using device pins as external interrupt or DTP request inputs. Writing "1" to a register bit sets the corresponding pin as an external interrupt or DTP request input and enables the generation of interrupt requests to the interrupt controller. Pins corresponding to bits set to "0" hold external interrupt or DTP request inputs but do not pass the request to the interrupt controller.

### (2) EIRR (Interrupt/DTP register)

Register layout

| Interrupt/DTP register          | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 🗇 Bit No. |
|---------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| Address: 000029H                | ER7          | ER6          | ER5          | ER4          | ER3          | ER2          | ER1          | ER0          | EIRR      |
| Read/write ⇔<br>Initial value ⇔ | (R/W)<br>(0) |           |

#### Register contents

Reading EIRR indicates whether any external interrupt or DTP requests are present. Writing to EIRR clears the value of the flip-flop that indicates the request. Bits that have the value "1" on reading the register indicate that an external interrupt or DTP request for the corresponding pin is present. Writing "0" to bits in this register clears the request flip-flop for the corresponding bit. Writing "1" has no effect. Always read as "1" by read-modify-write type instructions.

**Note:** When interrupts are enabled, only write "0" to the bit that is set to "1". Avoid unconditionally clearing other flag bits when clearing the interrupt flag bit for a received interrupt.

#### 2.9 DTP/External Interrupts

### (3) ELVR (Request level setting register)

#### Register layout



#### Register contents

The ELVR register selects how to detect requests. The selection for each pin is set using two bits as shown below. If level-detection is selected for a pin, clearing the request when the active level is input causes the request to be set again.

Table 2.9.1 ELVR Settings

| LBx | LAx | Operation                                      |
|-----|-----|------------------------------------------------|
| 0   | 0   | Generate a request when an input is "L" level. |
| 0   | 1   | Generate a request when an input is "H" level. |
| 1   | 0   | ↑Generate a request at a rising edge.          |
| 1   | 1   | ightarrowGenerate a request at a falling edge. |

### 2.9.4 Operation

### (1) External interrupt operation

If the request specified in the ELVR register is input to a pin after the pin has been set for external interrupts, the resource generates an interrupt request signal to the interrupt controller. The interrupt controller prioritizes any simultaneously occurring interrupts. When the interrupt request from this resource has the highest priority, the interrupt controller passes the request to the  $F^2MC-16L$  CPU. The  $F^2MC-16L$  CPU compares the interrupt request with the ILM bits of the CCR register in the CPU. If the priority of the request is higher than the priority set in the ILM bits, the hardware interrupt processing microprogram is activated after completion of the currently executing instruction.



Fig. 2.9.2 External Interrupt Operation

Under control of the hardware interrupt processing microprogram, the CPU reads the ISE bit from the interrupt controller to identify that the current request is for interrupt processing, then branches to the interrupt processing microprogram. The interrupt processing microprogram reads the interrupt vector area, sends an interrupt acknowledge to the interrupt controller, and loads the macro instruction branch destination address created from the vector into the program counter to execute the user interrupt processing program.

### (2) DTP operation

Set the I/O address pointer and buffer address pointer in the extended intelligent I/O service descriptor as part of user program initialization for activating the extended intelligent I/O service. Set the address of a register between 000000H and 00FFFFH as the I/O address pointer and set the top address of the memory buffer as the buffer address pointer.

The operation sequence for DTP is exactly the same as for an external interrupt up to the point where the CPU activates the hardware interrupt processing microprogram. For DTP, the ISE bit read by the CPU in the hardware interrupt processing microprogram specifies DTP operation. This causes control to pass to the microprogram for the extended intelligent I/O service. On activation, the extended intelligent I/O service sends read or write signals to the external peripheral address and performs data transfer with this chip. The external peripheral must remove the interrupt request for the chip within 3 machine cycles of performing data transfer. Descriptor updating and similar operations are performed at the completion of data transfer, then the interrupt controller generates the signal to clear the sources of transfer. On receiving the transfer source clear signal, the DTP/external interrupt resource clears the flip-flop holding the sources and waits for the next request from the pin. See "3.3.3 Extended Intelligent I/O Service" for details on extended intelligent I/O Service.



# Fig. 2.9.3 External Interrupt Remove Timing at the Completion of DTP Operation



# Fig. 2.9.4 Example Interface Circuit with External Peripheral

### (3) Switching between external interrupt requests and DTP requests

Switching between external interrupt requests and DTP requests is performed by setting the ISE bit in the ICR register for the DTP/external interrupt resource. The ICR registers are located in the interrupt controller. Separate ICR registers are provided for each pin. Writing "1" to the ISE bit of the ICR register for a particular pin specifies DTP request operation. Writing "0" to the ISE bit specifies external interrupt request operation.



# Fig. 2.9.5 Switching Between External Interrupt Requests and DTP Requests

# 2.9.5 Notes on Use

### (1) Conditions for externally connected peripherals when using DTP

DTP only supports external peripherals that can automatically clear requests in response to the data transfer. If the transfer request is not removed within 3 machine cycles of starting data transfer, the DTP/ external interrupt resource treats the request as a new transfer request.

### (2) Recovery from standby

Specify an "H" level input request when using an external interrupt to recover from the standby state in clock stop mode. Using an "L" level request may cause misoperation. The system cannot recover from the standby state in clock stop mode by an edge request.

### (3) Operation procedure for external interrupt/DTP

Use the following procedure to set the registers in the external interrupt/DTP resource.

- 1. Set the corresponding bit in the enable register to "disabled".
- 2. Set the corresponding bits in the request level setting register.
- 3. Clear the corresponding bit in the interrupt/DTP request register.
- 4. Set the corresponding bit in the enable register to "enabled".

(Steps 3 and 4 can be performed simultaneously by a word write.)

Always set the enable register to "disabled" when setting the resource registers. Also, always clear the interrupt/DTP request register before setting the enable register to "enabled". This is to prevent generation of a source of unintended interrupt when setting registers or when enabling interrupts.

#### 2.9 DTP/External Interrupts

#### (4) External interrupt request level

- ① A pulse width of at least 3 machine cycles is required to detect an edge when the request level is set to edge detect.
- ② When the request level is set to level detect, a request to the interrupt controller remains active even if the external request input is removed. This is because external request inputs are held in an internal request hold circuit. The internal request hold circuit must be cleared to remove the request to the interrupt controller.







### Fig. 2.9.7 Interrupt Hold F/F and Interrupt Request to the Interrupt Controller When Interrupts are Enabled

**Note:** The INT4 to 7 pins are shared with other functions. Unless being done intentionally, halt input or output (A/D activation, PPG output) to these pins from other functions.

# 2.10 Delay Interrupt Generation Module

The delay interrupt generation module is used to generate the task switching interrupt. Interrupt requests to the F<sup>2</sup>MC-16L CPU can be generated and cleared by software using this module.

# 2.10.1 Register



### 2.10.2 Block Diagram



### Fig. 2.10.1 Block Diagram

### 2.10.3 Register Details

(1) DIRR (Delay interrupt source generate/clear register)■ Register layout



Register contents

The DIRR register controls generation and clearing of delay interrupt requests. Writing "1" to the register generates a delay interrupt request. Writing "0" to the register clears a delay interrupt request. The register is set to the interrupt cleared state by a reset. Either "0" or "1" can be written to the reserved bits. However, considering possible future extensions, it is recommended that the set bit and clear bit instructions are used for register access.

# 2.10.4 Operation

## (1) Delay interrupt generation

When the CPU writes "1" to the R0 bit of the DIRR register by software, a request latch in the delay interrupt generation module is set and an interrupt request to the interrupt controller generated. If no other interrupts are present, or the other interrupts have a lower priority, the interrupt controller passes the interrupt request to the F<sup>2</sup>MC-16L CPU. The F<sup>2</sup>MC-16L CPU compares the interrupt request with the ILM bits of the CCR register in the CPU. If the priority of the request is higher than the priority set in the ILM bits, the hardware interrupt processing microprogram is activated after completion of the currently executing instruction. As a result, the interrupt processing routine for this interrupt is executed.





Write "0" to the R0 bit in the DIRR register to clear the source of interrupt and perform task switching in the interrupt processing routine.

# 2.10.5 Notes on Use

## (1) Delay interrupt request latch

This latch is set when "1" is written to the R0 bit of the DIRR register and cleared by writing "0" to the R0 bit. Accordingly, interrupt processing is activated again on returning from the interrupt processing routine if the routine's software does not clear the source of interrupt. Take care when developing software that this situation does not occur.

# 2.11 Watchdog Timer and Timebase Timer Functions

The watchdog timer consists of a 2-bit watchdog counter, a control register, and a watchdog reset controller. The watchdog counter uses the carry-up signal from the 18-bit timebase timer as its clock source. In addition to the 18-bit timer, the timebase timer contains an interval interrupt control circuit. The timebase timer uses the main clock, regardless of the value of the MCS bit in the CKSCR register. Figure 2.11.1 shows the structure of the watchdog and timebase timers.

# 2.11.1 Registers

| Watchdog timer control register | 7           | 6              | 5            | 4            | 3            | 2            | 1            | 0            | 🗇 Bit No. |
|---------------------------------|-------------|----------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| Address: 0000A8H                | PON         | R STBR         | WRST         | ERST         | SRST         | WTE          | WT1          | WT0          | WDTC      |
| Read/write ⇔<br>Initial value ⇔ | (R/W<br>(X) | ) (R/W)<br>(X) | (R/W)<br>(X) | (R/W)<br>(X) | (R/W)<br>(X) | (R/W)<br>(1) | (R/W)<br>(1) | (R/W)<br>(1) | 4         |
| Timebase timer control register | 15          | 14             | 13           | 12           | 11           | 10           | 9            | 8 <          | Bit No.   |
| Address: 00000A9H               | Reserved    | -              | -            | TBIE         | TBOF         | TBR          | TBC1         | TBC0         | твтс      |
| Read/write ⇔<br>Initial value ⇔ | (-)<br>(1)  | (-)<br>(-)     | (-)<br>(-)   | (R/W)<br>(0) | (R/W)<br>(0) | (W)<br>(1)   | (R/W)<br>(0) | R/W)<br>(0)  |           |

# 2.11.2 Block Diagram



Fig. 2.11.1 Block Diagram of the Watchdog and Timebase Timers

# 2.11.3 Register Details

#### (1) WDTC (Watchdog timer control register)

Register layout

| Watchdog timer control register | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          | 🗇 Bit No. |
|---------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|-----------|
| Address: 0000A8H                | PONR       | STBR       | WRST       | ERST       | SRST       | WTE        | WT1        | WT0        | WDTC      |
| Read/write ⇔<br>Initial value ⇔ | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (R)<br>(X) | (W)<br>(1) | (W)<br>(1) | (W)<br>(1) |           |

Note 1: Do not access this register using read-modify-write instructions as this can cause misoperation.

■ Register contents

This register contains various watchdog timer control bits and reset type flag bits.

■ Bit meaning

[Bits 7 to 3] PONR, STBR, WRST, ERST, SRST

Reset type flags. When a reset occurs, these bits are set as shown in Table 2.11.1, depending on the reset type. Reading WDTC clears all these bits to "0". These bits are read-only. At power-on, the values of bits other than the power-on flag are undefined. Accordingly, when developing software, ignore the other bits if the PONR bit is "1".

| Reset Type       | PONR | STBR | WRST | ERST | SRST |
|------------------|------|------|------|------|------|
| Power-on         | 1    | -    | -    | -    | -    |
| Hardware standby | *    | 1    | *    | *    | *    |
| Watchdog timer   | *    | *    | 1    | *    | *    |
| External pin     | *    | *    | *    | 1    | *    |
| RST bit          | *    | *    | *    | *    | 1    |

Table 2.11.1 Value of the Reset Type Bits for Each Reset Type

(The values indicated by \* hold their previous values.)

## [Bit 2] WTE

Writing "0" to this bit when the watchdog timer is stopped starts the watchdog timer running. Writing "0" to this bit for the second and subsequent times clears the watchdog timer counter. Writing "1" has no meaning.

The watchdog timer stops after a power-on, hardware standby, or watchdog timer reset. Reading this bit returns "1".

#### [Bits 1, 0] WT1, 0

Interval time selection bits for the watchdog timer. Only the data set when the watchdog timer starts is used. Values set at other times have no meaning. Table 2.11.2 lists the interval times. These bits are write-only.

| WT1   | WTO | Interval Time (4 N | Number of Main    |                                         |  |  |
|-------|-----|--------------------|-------------------|-----------------------------------------|--|--|
| VVI I | WIO | Min.               | Max.              | Clock Cycles                            |  |  |
| 0     | 0   | Approx. 3.58 ms    | Approx. 4.61 ms   | 2 <sup>14</sup> ±2 <sup>11</sup> cycles |  |  |
| 0     | 1   | Approx. 14.33 ms   | Approx. 18.43 ms  | 2 <sup>16</sup> ±2 <sup>13</sup> cycles |  |  |
| 1     | 0   | Approx. 57.34 ms   | Approx. 73.73 ms  | 2 <sup>18</sup> ±2 <sup>15</sup> cycles |  |  |
| 1     | 1   | Approx. 458.75 ms  | Approx. 589.82 ms | 2 <sup>21</sup> ±2 <sup>18</sup> cycles |  |  |

Table 2.11.2 Watchdog Timer Interval Selection Bits

**Note:** The maximum interval value is for when the timebase counter is not reset while the watchdog timer is running.

# (2) TBTC (Timebase timer control register)

Register layout

| Timebase timer control register | 15         | 14         | 13         | 12           | 11           | 10         | 9            | 8            | 🗇 Bit No. |
|---------------------------------|------------|------------|------------|--------------|--------------|------------|--------------|--------------|-----------|
| Address: 00000A9H               | Reserved   | -          | -          | TBIE         | TBOF         | TBR        | TBC1         | TBC0         | твтс      |
| Read/write ⇔<br>Initial value ⇔ | (-)<br>(1) | (-)<br>(-) | (-)<br>(-) | (R/W)<br>(0) | (R/W)<br>(0) | (W)<br>(1) | (R/W)<br>(0) | (R/W)<br>(0) |           |

Note 1: Do not access this register using read-modify-write instructions as this can cause misoperation.

## Register contents

Controls the operation of the timebase timer and sets the interval interrupt time.

Bit meaning[Bit 15] Test bitTest bit. Always write "1" to this bit.

[Bits 14, 13] Unused

#### [Bit 12] TBIE

Interval interrupt enable bit for the timebase timer. Interrupts are enabled when TBIE is "1" and disabled when TBIE is "0". Cleared to "0" by a reset. The bit is readable and writable.

#### [Bit 11] TBOF

The timebase timer interrupt request flag. An interrupt request is generated if TBOF changes to "1" when TBIE is "1". TBOF is periodically set to "1" with the interval set by the TBC1, 0 bits. Writing "0", changing to stop or hardware standby mode, using the TBR bit to clear the timebase timer, or generating a reset clears TBOF. Writing "1" has no meaning.

Always read as "1" by read-modify-write type instructions.

**Note:** When clearing the TBOF bit, mask timebase timer interrupts using the TBIE bit or the ILM bits in the CPU.

[Bit 10] TBR

Clears all bits of the timebase timer counter to "0". Writing "0" clears the timebase timer counter and also clears the TBOF bit. Writing "1" has no meaning. Reading this bit returns "1".

**Note:** Mask timebase timer interrupts using the TBIE bit or the ILM bits in the CPU when clearing the TBOF bit.

[Bits 9, 8] TBC1, 0

Interval setting bits for the timebase timer. Table 2.11.3 lists the interval settings. Cleared to "00" by a reset. These bits are readable and writable.

| TBC1 | TBC0 | Interval Time for a 4 MHz<br>Clock Source | Number of Main Clock<br>Cycles |
|------|------|-------------------------------------------|--------------------------------|
| 0    | 0    | 1.024 ms                                  | 2 <sup>12</sup> cycles         |
| 0    | 1    | 4.096 ms                                  | 2 <sup>14</sup> cycles         |
| 1    | 0    | 16.384 ms                                 | 2 <sup>16</sup> cycles         |
| 1    | 1    | 131.072 ms                                | 2 <sup>19</sup> cycles         |

Table 2.11.3 Timebase Timer Interval Selection

# 2.11.4 Operation

#### (1) Watchdog Timer

The watchdog timer function can be used to detect program loop. If, due to a program runaway or similar problem, "0" is not written to the WTE bit within the required time, the watchdog timer generates a watchdog reset request.

#### Activation

To start the watchdog timer, write "0" to the WTE bit in the WDTC register when the watchdog timer is stopped. At the same time, set the watchdog timer reset interval in the WT1 and WT0 bits. Only the interval data set at the time the watchdog timer is started is used.

#### Preventing a watchdog timer reset

Once the watchdog timer has started, the program must periodically clear the 2-bit watchdog counter. Specifically, the program must periodically write "0" to the WTE bit in the WDTC register. The watchdog counter consists of a 2-bit counter that uses the carry-up signal from the 18-bit timebase counter as its clock source. Therefore, the time until a watchdog timer reset occurs is lengthened if the timebase timer is cleared.

Figure 2.11.2 shows the operation of the watchdog timer.



# Fig. 2.11.2 Watchdog Timer Operation

#### ■ Stopping the watchdog timer

Once started, the watchdog timer is only initialized and stopped by a power-on, hardware standby, or watchdog reset. External pin or software resets clear the watchdog counter but do not stop the watchdog function.

#### Other

In addition to writing to the WTE bit, the watchdog counter is also cleared by the generation of a reset, changing to sleep or stop mode, or the hold acknowledge signal.

#### (2) Timebase timer

The timebase timer functions as the watchdog counter clock source, as a delay timer to wait while the main clock and PLL clock stabilize, and as an interval timer for generating interrupts with a fixed period.

#### ■ Timebase timer

The timebase timer consists of an 18-bit counter that counts the source oscillator input used to generate the machine clock. The timebase timer counts continuously while an oscillator input is present. A power-on reset, changing to stop or hardware standby mode, using the MCS bit in the CKSCR register to change from the main clock to the PLL clock, or writing "0" to the TBR bit in the TBTC register clears the timebase timer.

The watchdog counter and interval interrupt both use the timebase timer output and are affected by clearing the timebase timer.

#### ■ Interval interrupt function

The interval interrupt function generates a fixed-period interrupt using the carry-up signal from the timebase counter. The TBOF flag is set periodically, with the interval determined by the TBC1, 0 bits of the TBTC register. When the TBOF flag is set depends on when the timebase timer was last cleared.

As the timebase timer acts as a delay timer to wait for the PLL oscillation to stabilize when changing from main clock mode to PLL clock mode, the timebase timer is cleared at this time.

As the timebase timer acts as a delay timer to wait for oscillation to stabilize when recovering from stop or hardware standby mode, the TBOF flag is cleared when changing to these modes.

# 2.12 Low Power Control Circuits (CPU Intermittent Operation Function, Oscillation Stabilization Delay Time, and Clock Multiplier Function)

The following operation modes are available: PLL clock mode, PLL sleep mode, timer mode, main clock mode, main sleep mode, stop mode, and hardware standby mode. Operation modes other than PLL clock mode are classified as low power consumption modes.

In main clock mode and main sleep mode, the device operates on the main clock only (OSC oscillator clock). The PLL clock (VCO oscillator clock) is stopped in these modes and the main clock divided by 2 is used as the operating clock.

In PLL sleep mode and main sleep mode, the CPU's operating clock only is stopped and other elements continue to operate.

In watch mode, only the timebase timer operates.

Stop mode and hardware standby mode stop the oscillator. These modes maintain existing data with minimum power consumption.

The CPU intermittent operation function provides an intermittent clock to the CPU when register, internal memory, internal resource, or external bus access is performed. This function reduces power consumption by lowering the CPU execution speed while still providing a high-speed clock to internal resources. The PLL clock multiplier ratio can be set to 1, 2, 3, or 4 by the CS1, 0 bits.

The WS1, 0 bits set the delay time to wait for the main clock oscillation to stabilize when recovering from stop mode or hardware standby mode.

# 2.12.1 Registers

| Low power mode control register | 7          | 6          | 5            | 4             | 3            | 2            | 1              | 0            | ⇔ Bit No. |
|---------------------------------|------------|------------|--------------|---------------|--------------|--------------|----------------|--------------|-----------|
| Address: 0000A0H                | STF        | 9 SLF      | SPL          | RS            | T Reserv     | ved CG       | 1 CG0          | Reserved     | LPMCR     |
| Read/write ⇔<br>Initial value ⇔ | (W)<br>(0) | (W)<br>(0) | (R/W<br>(0)  | /) (W)<br>(1) | ) (-)<br>(1) | (R/V<br>(0)  | /) (R/W<br>(0) | ) (-)<br>(0) |           |
| Clock select register           | 15         | 14         | 13           | 12            | 11           | 10           | 9              | 8            | 🗇 Bit No. |
| Address: 0000A1H                | Reserved   | MCM        | WS1          | WS0           | Reserved     | MCS          | CS1            | CS0          | CKSCR     |
| Read/write ⇔<br>Initial value ⇔ | (-)<br>(1) | (R)<br>(1) | (R/W)<br>(1) | (R/W)<br>(1)  | (-)<br>(1)   | (R/W)<br>(1) | (R/W)<br>(0)   | (R/W)<br>(0) |           |

# 2.12.2 Block Diagram



Fig. 2.12.1 Low Power Control Circuit and Clock Generators

# 2.12.3 Register Details

#### (1) LPMCR (Low power mode control register)

Register layout



Note 1: Do not access this register using read-modify-write instructions as this can cause misoperation.

#### Register contents

#### [Bit 7] STP

Writing "1" to this bit changes to timer mode (if MCS = "0" in CKSCR) or stop mode (if MCS = "1" in CKSCR). Writing "0" to this bit has no effect. STP is cleared to "0" by clearing reset or watch or stop mode. The bit is write-only. Reading always returns "0".

#### [Bit 6] SLP

Writing "1" to this bit changes to sleep mode. Writing "0" to this bit has no effect. The bit is cleared to "0" by a reset or wake-up from sleep or stop mode.

The device changes to watch or stop mode if "1" is written to both the STP and SLP bits at the same time. SLP is a write-only bit. Reading always returns "0".

#### [Bit 5] SPL

External pins hold their levels during timer or stop mode if this bit is "0". External pins go to high impedance during watch or stop mode if this bit is "1". SPL is cleared to "0" by a reset. The bit is readable and writable.

#### [Bit 4] RST

Writing "0" to this bit generates an internal reset signal for 3 machine cycles. Writing "1" to this bit has no effect. Reading always returns "1".

#### [Bits 2, 1] CG1, CG0

Sets the number of cycles to temporarily stop the clock for the CPU intermittent operation function. Initialized to "00" by a power-on, hardware standby, or watchdog timer reset. Not initialized by other resets. The bits are readable and writable.

The CPU intermittent operation function halts the CPU clock for a set period when register, internal memory, internal resource, or external bus access is performed and delays the start of the internal bus cycle. This function reduces power consumption by lowering the CPU execution speed while still providing a high-speed clock to internal resources.

| CG1 | CG0 | Number of Cycles to Stop CPU Clock                                                |
|-----|-----|-----------------------------------------------------------------------------------|
| 0   | 0   | 0 cycles (CPU clock = resource clock)                                             |
| 0   | 1   | 9 cycles (The ratio of the CPU clock to the resource clock is approx. 1:3 to 4)   |
| 1   | 0   | 17 cycles (The ratio of the CPU clock to the resource clock is approx. 1:5 to 6)  |
| 1   | 1   | 33 cycles (The ratio of the CPU clock to the resource clock is approx. 1:9 to 10) |

# Table 2.12.1 CG Bit Settings

# (2) CKSCR (Clock selection register)

Register layout

|                                 | 15         | 14         | 13           | 12           | 11         | 10           | 9            | 8            | 🗢 Bit No. |
|---------------------------------|------------|------------|--------------|--------------|------------|--------------|--------------|--------------|-----------|
| Address: 0000A1H                | Reserved   | MCM        | WS1          | WS0          | Reserved   | MCS          | CS1          | CS0          | CKSCR     |
| Read/write ⇔<br>Initial value ⇒ | (-)<br>(1) | (R)<br>(1) | (R/W)<br>(1) | (R/W)<br>(1) | (-)<br>(1) | (R/W)<br>(1) | (R/W)<br>(0) | (R/W)<br>(0) |           |

# Register content

#### [Bit 14] MCM

Indicates whether the main clock or PLL clock is selected as the machine clock. "0" indicates that the PLL clock is selected. "1" indicates that the main clock is selected. MCS = "0" and MCM = "1" indicates that the device is currently waiting for the PLL clock oscillation to stabilize. The delay time to wait for the PLL clock to stabilize is fixed at  $2^{13}$  main clock cycles.

[Bits 13, 12] WS1, WS0

Sets the delay time to wait for the main clock to stabilize after wake-up from stop mode or hardware standby mode, or after a watchdog reset.

Initialized to "11" by a power-on reset. Not initialized by other resets. The bits are readable and writable.

|     |     | -                                                                  |
|-----|-----|--------------------------------------------------------------------|
| WS1 | WS0 | Delay Time for Oscillation to Stabilize (For a 4 MHz source clock) |
| 0   | 0   | Do not delay for the main clock to stabilize.                      |
| 0   | 1   | Approx. 2.05ms (2 <sup>13</sup> source clock counts)               |
| 1   | 0   | Approx. 8.19ms (2 <sup>15</sup> source clock counts)               |
| 1   | 1   | Approx. 65.54ms (2 <sup>18</sup> source clock counts)              |

Table 2.12.2 WS Bit Settings

#### [Bit 10] MCS

Selects the main clock or PLL clock as the machine clock. Writing "0" to this bit selects the PLL clock and writing "1" selects the main clock. Writing "0" when the bit is "1" automatically clears the timebase timer and the TBOF bit in the timebase timer control register so as to generate the delay time for the PLL clock to stabilize. The delay time for the PLL clock to stabilize is fixed at 2<sup>13</sup> main clock cycles (approximately 2ms for a 4 MHz source clock).

The operating clock when the main clock is selected is the main clock divided by 2. (This gives a 2 MHz operating clock for a 4 MHz source clock.)

MCS is initialized to "1" by a power-on, hardware standby, or watchdog reset.

**Note:** When the value of MCS is "1", use the TBIE bit or the ILM bits in the CPU to mask the timebase timer interrupt before writing "0" to MCS.

Also, you may not be able to write "0" to the MCS bit for 8 machine cycles after setting the bit to "1". Always wait for at least 8 machine cycles before writing.

#### [Bits 9, 8] CS1, CS0

Selects the multiplier ratio for the PLL clock. The bits are initialized to "00" by a power-on reset but are not initialized by resets triggered by the external pin or RST bit.

Writing to these bits is not allowed when the MCS bit is "0". To set the CS bits, first set the MCS bit to "1" (main clock mode).

The bits are readable and writable.

| CS1 | CS0 | Machine Clock (For a 4 MHz source clock)                     |
|-----|-----|--------------------------------------------------------------|
| 0   | 0   | 4 MHz (Operating frequency = OSC oscillation frequency)      |
| 0   | 1   | 8 MHz (Operating frequency = OSC oscillation frequency * 2)  |
| 1   | 0   | 12 MHz (Operating frequency = OSC oscillation frequency * 3) |
| 1   | 1   | 16 MHz (Operating frequency = OSC oscillation frequency * 4) |

Table 2.12.3 CS Bit Settings

#### 2.12 Low Power Control Circuits

# 2.12.4 Operation

See Section 3.5 "Low Power Modes" for details on the operation of low power consumption modes.

## (1) State transitions for clock switching

Figure 2.12.2 shows the state transitions for clock switching.

The oscillation stabilization delay time for the PLL clock is fixed at 2<sup>13</sup> main clock cycles (approximately 2ms for a 4 MHz source clock).

**Note:** When operating on 5V, the OSC source clock can be in the range 3MHz to 16 MHz. However, the maximum operating frequency for the CPU and peripheral resource circuits is 16 MHz. The device will not operate correctly if the multiplier setting results in this maximum being exceeded. For example, always set the multiplier to 1 if using a 16 MHz source clock.

Also, the minimum operating frequency for the VCO is 4 MHz. Do not specify an oscillation less than this frequency.



① MCS bit cleared.

② PLL clock oscillation stabilization delay complete and CS1/0 = "00"

3 PLL clock oscillation stabilization delay complete and CS1/0 = "01"

 $\textcircled{\sc 0}$  PLL clock oscillation stabilization delay complete and CS1/0 = "10"

S PLL clock oscillation stabilization delay complete and CS1/0 = "11"

⑥ MCS bit set (including a hardware standby or watchdog reset)

 $\ensuremath{\textcircled{O}}$  PLL clock and main clock synchronized timing

# Fig. 2.12.2 State Transition Diagram for Clock Switching

# 2.13 External Bus Pin Control Circuit

The external bus pin control circuit controls the external bus pins that extend the CPU's address/data bus outside the device.

# 2.13.1 Registers

Auto-ready function select register

|                                 | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 🗇 Bit No. |
|---------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|-----------|
| Address: 0000A5H                | IOR1       | IOR0       | HMR1       | HMR0       | -          | -          | LMR1       | LMR0       | ARSR      |
| Read/write ⇔<br>Initial value ⇔ | (W)<br>(0) | (W)<br>(0) | (W)<br>(1) | (W)<br>(1) | (-)<br>(-) | (-)<br>(-) | (W)<br>(0) | (W)<br>(0) |           |

External address output control register

|                                 | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          | 🗇 Bit No. |
|---------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|-----------|
| Address: 0000A6H                | E23        | E22        | E21        | E20        | E19        | E18        | E17        | E16        | HACR      |
| Read/write ⇔<br>Initial value ⇔ | (W)<br>(0) |           |

Bus control signal select register

|                                 | 15         | 14         | 13         | 12           | 11         | 10         | 9          | 8          | 🗢 Bit No. |
|---------------------------------|------------|------------|------------|--------------|------------|------------|------------|------------|-----------|
| Address: 0000A7H                | -          | LMBS       | WRE        | HMBS         | IOBS       | HDE        | RYE        | CKE        | ECSR      |
| Read/write ⇔<br>Initial value ⇒ | (-)<br>(-) | (W)<br>(0) | (W)<br>(0) | (W)<br>(1/0) | (W)<br>(0) | (W)<br>(0) | (W)<br>(0) | (W)<br>(0) |           |

# 2.13.2 Block Diagram





# 2.13.3 Register Details

# (1) Auto-ready function select register

■ Register layout

|                                  | 15   | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 🗇 Bit No. |
|----------------------------------|------|------------|------------|------------|------------|------------|------------|------------|-----------|
| Address: 0000A5H                 | IOR1 | IOR0       | HMR1       | HMR0       | -          | -          | LMR1       | LMR0       | ARSR      |
| Read/write<br>Initial value<br>⇔ |      | (W)<br>(0) | (W)<br>(1) | (W)<br>(1) | (-)<br>(-) | (-)<br>(-) | (W)<br>(0) | (W)<br>(0) |           |

## ■ Register contents

[Bits 15, 14] IOR1, IOR0

These two bits specify the automatic wait function for external access of the area between 0000C0H and 0000FFH. The settings are as follows.

Table 2.13.1 Automatic Wait Function Selection for the External I/O Area

| IOR1 | IOR0 | Setting                                                              |
|------|------|----------------------------------------------------------------------|
| 0    | 0    | Automatic wait disabled                                              |
| 0    | 1    | Insert an automatic wait of 1 machine cycle during external access.  |
| 1    | 0    | Insert an automatic wait of 2 machine cycles during external access. |
| 1    | 1    | Insert an automatic wait of 3 machine cycles during external access. |

The bits are initialized to "00B".

## [Bits 13, 12] HMR1, HMR0

These two bits specify the automatic wait function for external access of the area between 800000H and FFFFFFH. The settings are as follows.

## Table 2.13.2 Automatic Wait Function Selection for the Upper Memory Area

| HMR1 | HMR0 | Setting                                                              |
|------|------|----------------------------------------------------------------------|
| 0    | 0    | Automatic wait disabled                                              |
| 0    | 1    | Insert an automatic wait of 1 machine cycle during external access.  |
| 1    | 0    | Insert an automatic wait of 2 machine cycles during external access. |
| 1    | 1    | Insert an automatic wait of 3 machine cycles during external access. |

The bits are initialized to "11B".

## [Bits 9, 8] LMR1, LMR0

These two bits specify the automatic wait function for external access of the area between 002000H and 7FFFFFH. The settings are as follows.

| LMR1 | LMR0 | Setting                                                              |
|------|------|----------------------------------------------------------------------|
| 0    | 0    | Automatic wait disabled                                              |
| 0    | 1    | Insert an automatic wait of 1 machine cycle during external access.  |
| 1    | 0    | Insert an automatic wait of 2 machine cycles during external access. |
| 1    | 1    | Insert an automatic wait of 3 machine cycles during external access. |

 Table 2.13.3 Automatic Wait Function Selection for the Lower Memory Area

The bits are initialized to "00B".

# (2) External address output control register

Register layout



## Register contents

This register controls external output of address bits A23 to A16. Each bit controls its corresponding address bit (A23 to A16) as follows.

# Table 2.13.4 Output Control Selection for the Upper Address Bits

| 1 | Set the corresponding pin as an address output (AXX). |
|---|-------------------------------------------------------|
| 0 | Set the corresponding pin as an I/O port (PXX).       |

This register cannot be accessed when the device is in single-chip mode. In single-chip mode, all the pins are set as I/O ports regardless of the contents of this register.

All bits in this register are write-only. Reading always returns "1". The bits are initialized to "0" by a reset.

## (3) Bus control signal select register

Register layout

|                                 | 15         | 14         | 13         | 12           | 11         | 10         | 9          | 8          | 🗇 Bit No. |
|---------------------------------|------------|------------|------------|--------------|------------|------------|------------|------------|-----------|
| Address: 0000A7H                | -          | LMBS       | WRE        | HMBS         | IOBS       | HDE        | RYE        | CKE        | ECSR      |
| Read/write ⇔<br>Initial value ⇔ | (-)<br>(-) | (W)<br>(0) | (W)<br>(0) | (W)<br>(1/0) | (W)<br>(0) | (W)<br>(0) | (W)<br>(0) | (W)<br>(0) |           |

Register contents

This register sets the bus operation control functions for external bus mode.

The register cannot be accessed when the device is in single-chip mode. In single-chip mode, all the pins are set as I/O ports regardless of the contents of this register.

All bits in this register are write-only. Reading always returns "1".

#### [Bit 14] LMBS

Specifies the bus size for external access of the area between 002000H and 7FFFFFH in 16-bit external data bus mode. The settings are as follows.

## Table 2.13.5 Bus Size Selection for the Lower Memory Area

| 0 | 16-bit bus size access [Initial value] |
|---|----------------------------------------|
| 1 | 8-bit bus size access                  |

The bit is initialized to "0" by a reset.

#### [Bit 13] WRE

Controls the output of the external write signal (the WRHX and WRLX pins in 16-bit bus mode and the WRX pin in 8-bit bus mode) as follows.

## Table 2.13.6 Output Control Selection for External Writes

| 0 | Operate as I/O ports (P54, P55). (Output of write signals is disabled.) [Initial value] |
|---|-----------------------------------------------------------------------------------------|
| 1 | Enable output of write strobe signals (WRHX/WRLX or WRX)                                |

In 8-bit external data bus mode, P54 operates as an I/O port regardless of the value of this bit.

The bit is initialized to "0" by a reset.

#### [Bit 12] HMBS

Specifies the bus size for external access of the area between 800000H and FFFFFFH in 16-bit external data bus mode. The settings are as follows.

## Table 2.13.7 Bus Size Selection for the Upper Memory Area

| 0 | 16-bit bus size access (Initial value for external vector modes 1 and 3) |
|---|--------------------------------------------------------------------------|
| 1 | 8-bit bus size access (Initial value for external vector modes 0 and 2)  |

In external vector modes 0 and 2, the bit is initialized to "1" by a reset. In external vector modes 1 and 3, the bit is initialized to "0" by a reset.

#### [Bit 11] IOBS

Specifies the bus size for external access of the area between 0000C0H and 0000FFH in 16-bit external data bus mode. The settings are as follows.

| Table 2.13.8 | Bus Size Selection for the External I/O Area | а |
|--------------|----------------------------------------------|---|
|--------------|----------------------------------------------|---|

| 0 | 16-bit bus size access [Initial value] |
|---|----------------------------------------|
| 1 | 8-bit bus size access                  |

The bit is initialized to "0" by a reset.

#### [Bit 10] HDE

This bit enables or disables I/O for the hold request input (HRQ) and hold acknowledge output (HAKX) pins as follows.

# Table 2.13.9 Hold I/O Control Selection

| 0 | Operate as I/O ports (P53, P52). (Disable hold function I/O.) [Initial value] |
|---|-------------------------------------------------------------------------------|
| 1 | Enable hold request (HRQ) input and hold acknowledge (HAKX) output            |

The bit is initialized to "0" by a reset.

[Bit 9] RYE

Controls the external ready (RDY) input as follows.

# Table 2.13.10 Input Control Selection for the External Ready

| 0 | Operate as an I/O port (P51). (Disable the external RDY input.) [Initial value] |
|---|---------------------------------------------------------------------------------|
| 1 | Enable the external ready (RDY) input.                                          |

The bit is initialized to "0" by a reset.

#### [Bit 8] CKE

Controls the external clock (CLK) output as follows.

## Table 2.13.11 Output Control Selection for the External Clock

| 0 | Operate as an I/O port (P50). (Disable clock output.) |
|---|-------------------------------------------------------|
| 1 | Enable output of the clock signal (CLK).              |

The bit is initialized to "0" by a reset.

# 2.13.4 Operation

The MB90610A has various modes for different access methods and access areas. See 3.3 "Memory Access Modes" for details.

See 3.4 "External Memory Access" for details on the operation of external bus mode.

# 2.14 Interrupt Controller

The interrupt control registers are located in the interrupt controller. An interrupt control register is provided for each I/O with an interrupt function. The registers have the following three functions.

- Set the interrupt level of the corresponding peripheral.
- Select whether to treat interrupts from the corresponding peripheral as standard interrupts or to activate the extended intelligent I/O service.
- Select the extended intelligent I/O service channel.

# 2.14.1 Registers



Note: Do not access these registers using read-modify-write instructions as this can cause misoperation.

# 2.14.2 Block Diagram



Fig. 2.14.1 Block Diagram of the Interrupt Controller

# 2.14.3 Register Details

- (1) ICR (Interrupt control register)
- Register layout



- **Note:** ICS3 to 0 are only meaningful when EI<sup>2</sup>OS is active. Set ISE to "1" when using EI<sup>2</sup>OS and set ISE to "0" when not using EI<sup>2</sup>OS. Any values can be set to ICS3 to 0 if EI<sup>2</sup>OS is not used. \* Reading returns "1".
- Note: ICS1 and ICS0 are write-only. S1 and S0 are read-only.
- Note: Do not access these registers using read-modify-write instructions as this can cause misoperation.

#### Register contents

## (1) Interrupt level setting bits: IL0, IL1, IL2

The interrupt level setting bits specify the interrupt level of the corresponding internal resource. The bits are readable and writable. The bits are initialized to level 7 (no interrupt) by a reset. Table 2.14.1 lists the relationship between the interrupt level setting bits and each interrupt level.

| IL2 | IL1 | IL0 | Level                       |
|-----|-----|-----|-----------------------------|
| 0   | 0   | 0   | 0 (Highest interrupt level) |
| 0   | 0   | 1   | 1                           |
| 0   | 1   | 0   | 2                           |
| 0   | 1   | 1   | 3                           |
| 1   | 0   | 0   | 4                           |
| 1   | 0   | 1   | 5                           |
| 1   | 1   | 0   | 6 (Lowest interrupt level)  |
| 1   | 1   | 1   | 7 (No interrupt)            |

# Table 2.14.1 Correspondence Between Interrupt Level Setting Bits and Interrupt Levels

# (2) Extended intelligent I/O service enable bit: ISE

The processor activates EI<sup>2</sup>OS if the ISE bit is "1" when an interrupt request occurs. If the ISE bit is "0", the processor activates the interrupt sequence. The bit is readable and writable. The ISE bit changes to "0" when EI<sup>2</sup>OS completes. If the peripheral does not have an EI<sup>2</sup>OS function, set the ISE bit to "0" by software.

Initialized to "0" by a reset.

## (3) Extended intelligent I/O service channel select bits: ICS3 to 0

These bits specify the EI<sup>2</sup>OS channel. The bits are write-only. The value set in these bits determines the memory address of the intelligent I/O service descriptor, as described later. ICS is initialized by a reset. Table 2.14.2 lists the correspondence between ICS, the channel number, and the descriptor address.

| ICS3 | ICS2 | ICS1 | ICS0 | Channel | Descriptor Address |
|------|------|------|------|---------|--------------------|
| 0    | 0    | 0    | 0    | 0       | 000100н            |
| 0    | 0    | 0    | 1    | 1       | 000108н            |
| 0    | 0    | 1    | 0    | 2       | 000110н            |
| 0    | 0    | 1    | 1    | 3       | 000118н            |
| 0    | 1    | 0    | 0    | 4       | 000120н            |
| 0    | 1    | 0    | 1    | 5       | 000128н            |
| 0    | 1    | 1    | 0    | 6       | 000130н            |
| 0    | 1    | 1    | 1    | 7       | 000138н            |
| 1    | 0    | 0    | 0    | 8       | 000140н            |
| 1    | 0    | 0    | 1    | 9       | 000148н            |
| 1    | 0    | 1    | 0    | 10      | 000150н            |
| 1    | 0    | 1    | 1    | 11      | 000158н            |
| 1    | 1    | 0    | 0    | 12      | 000160н            |
| 1    | 1    | 0    | 1    | 13      | 000168н            |
| 1    | 1    | 1    | 0    | 14      | 000170н            |
| 1    | 1    | 1    | 1    | 15      | 000178н            |

Table 2.14.2 Correspondence Between ICS, Channel Number, and Descriptor Address

# (4) Extended intelligent I/O service completion status: S0, S1

When EI<sup>2</sup>OS completes, these bits can be referenced to determine the completion status. The bits are readonly. The bits are initialized to "00" by a reset.

Table 2.14.3 lists the relationship between the S bits and the completion status.

| S1 | S0 | Completion Status                             |  |  |  |
|----|----|-----------------------------------------------|--|--|--|
| 0  | 0  | Reserved                                      |  |  |  |
| 0  | 1  | Stopped due to count completion               |  |  |  |
| 1  | 0  | Reserved                                      |  |  |  |
| 1  | 1  | Stopped by request from the internal resource |  |  |  |

 Table 2.14.3
 S Bits and Completion Status

#### 2.14 Interrupt Controller

# (5) Interrupt vector allocation

Table 2.14.4 lists the allocation of MB90610A interrupt vectors.

| Interrupt                         | I <sup>2</sup> OS | I   | nterrupt    | Vector  | Interrupt Co | Interrupt Control Register |  |  |
|-----------------------------------|-------------------|-----|-------------|---------|--------------|----------------------------|--|--|
| Interrupt                         | Support           | Num | nber        | Address | ICR          | Address                    |  |  |
| Reset                             | х                 | #08 | 08н         | FFFFDCH | -            | -                          |  |  |
| INT 9 instruction                 | х                 | #09 | 09н         | FFFFD8H | -            | -                          |  |  |
| Exception                         | Х                 | #10 | 0Ан         | FFFFD4H | -            | -                          |  |  |
| External interrupt #0             | 0                 | #11 | 0Вн         | FFFFD0H | ICR00        | 0000В0н                    |  |  |
| External interrupt #1             | 0                 | #13 | 0Dн         | FFFFC8H | ICR01        | 0000В1н                    |  |  |
| External interrupt #2             | 0                 | #15 | 0Fн         | FFFFC0H | ICR02        | 0000В2н                    |  |  |
| External interrupt #3             | 0                 | #17 | 11н         | FFFFB8H | ICR03        | 0000ВЗн                    |  |  |
| External interrupt #4             | 0                 | #19 | 13н         | FFFFB0H | ICR04        | 0000В4н                    |  |  |
| External interrupt #5             | 0                 | #21 | 15н         | FFFFA8н | ICR05        | 0000В5н                    |  |  |
| External interrupt #6             | 0                 | #23 | 17н         | FFFFA0H | 10000        | 0000000                    |  |  |
| UART0 transmit complete           | 0                 | #24 | <b>1</b> 8н | FFFF9CH | ICR06        | 0000В6н                    |  |  |
| External interrupt #7             | 0                 | #25 | 19н         | FFFF98H | ICR07        | 0000В7н                    |  |  |
| UART1 transmit complete           | 0                 | #26 | 1Ан         | FFFF94н |              |                            |  |  |
| PPG #0                            | х                 | #27 | 1Вн         | FFFF90н | ICR08        | 0000000                    |  |  |
| PPG #1                            | х                 | #28 | 1Сн         | FFFF8CH |              | 0000В8н                    |  |  |
| 16-bit reload timer #0            | 0                 | #29 | 1Dн         | FFFF88H | ICR09        | 0000000                    |  |  |
| 16-bit reload timer #1            | 0                 | #30 | 1Ен         | FFFF84H | ICRU9        | 0000В9н                    |  |  |
| A/DC measurement complete         | 0                 | #31 | 1Fн         | FFFF80H | ICR10        | 0000ВАн                    |  |  |
| UART2 transmit complete           | 0                 | #33 | 21н         | FFFF78н |              |                            |  |  |
| Timebase timer interval interrupt | х                 | #34 | 22н         | FFFF74H | ICR11        | 0000ВВн                    |  |  |
| UART2 receive complete            | 0                 | #35 | 23н         | FFFF70н | ICR12        | 0000ВСн                    |  |  |
| UART1 receive complete            | 0                 | #37 | 25н         | FFFF68H | ICR13        | 0000BDн                    |  |  |
| UART 0receive complete            | 0                 | #39 | 27н         | FFFF60H | ICR14        | 0000ВЕн                    |  |  |
| Delay interrupt generation module | х                 | #42 | 2Ан         | FFFF54н | ICR15        | 0000BFн                    |  |  |

# Table 2.14.4 MB90610A Interrupt Vector Allocation

Note: O indicates I<sup>2</sup>OS support (no stop request), o indicates I<sup>2</sup>OS support (with stop request), and  $\times$  indicates no I<sup>2</sup>OS support.

Do not set I<sup>2</sup>OS activation in ICRxx for resources that do not support I<sup>2</sup>OS.

# 2.14.4 Operation

See 3.3 "Interrupts" for details on the operation of interrupts and EI<sup>2</sup>OS.

# Chapter 3: Operation

# 3.1 Clock Generator

The clock generator controls operation of the internal clock including the PLL clock multiplier, sleep, timer, and stop functions. The internal clock is called the machine clock and one clock cycle is called a machine cycle. The clock from the source oscillator is called the main clock and the clock from the internal VCO is called the PLL clock.

**Note:** When operating on 5V, the OSC source oscillation can be in the range 3MHz to 16 MHz. However, the maximum operating frequency for the CPU and peripheral resource circuits is 16 MHz. The device will not operate correctly if the multiplier setting results in this maximum being exceeded. For example, always set the multiplier to 1 if using a 16 MHz source oscillation.

Also, the minimum operating frequency for the VCO is 4 MHz. Do not specify an oscillation less than this frequency.

Figure 3.1.1 shows a block diagram of the clock generator circuit.



Fig. 3.1.1 Block Diagram of the Clock Generator Circuit

3.2 Resets

# 3.2 Resets

# 3.2.1 Generating a Reset

On generation of a reset source, the F<sup>2</sup>MC-16L interrupts the currently executing processing and waits for the reset to be cleared. The following events trigger a reset.

- O Generation of a power-on reset
- O Release of the hardware standby state
- O Watchdog timer overflow
- O External reset request from the RSTX pin
- O Software reset request

After a power-on reset or wake-up from stop mode, operation starts after a delay for the oscillation to stabilize.

**Note:** Other than in stop mode, sampling of the external reset input is synchronized by the internal clock. Therefore, reset inputs cannot be detected if the externally supplied clock is halted.

When using an external bus, the address generated by the device during a reset is indeterminate. All the external bus access signals (RDX, WRLX, etc.) become inactive.

# 3.2.2 Operation After the Reset is Cleared

On removal of the reset trigger, the F<sup>2</sup>MC-16L outputs the address of the reset vector and reads the reset vector and mode data. The reset vector and mode data are located in the 4 bytes from FFFFDCH to FFFFDFH. On release of the reset, the data at these locations are moved by hardware to the registers shown in Figure 3.2.1.

The bus mode after reading the reset vector and mode data is determined by the mode data.



# Fig. 3.2.1 Storage Location and Destination of the Reset Vector and Mode Data

**Note:** The mode register shown in the diagram becomes indeterminate immediately after a reset. Always store the optional mode data in memory so that the data can be set in the register.

# 3.2.3 Reset Types

Table 3.2.1 lists the five different reset types. The machine clock and watchdog timer initialization depends on the reset type.

The reset type can be determined from the reset type register.

| Reset            | Reset Cause                                         | Machine Clock            | Watchdog Timer           | Delay for<br>Oscillation<br>to Stabilize? |
|------------------|-----------------------------------------------------|--------------------------|--------------------------|-------------------------------------------|
| Power-on         | Power supply turned on                              | Main clock               | Stopped                  | Yes                                       |
| Hardware standby | Input of an "L" level to the HSTX pin               | Main clock               | Stopped                  | Yes                                       |
| Watchdog timer   | Watchdog timer overflow                             | Main clock               | Stopped                  | Yes                                       |
| External pin     | Input of an "L" level to the RSTX pin               | Holds the previous state | Holds the previous state | No                                        |
| Software         | Writing "0" to the RST bit<br>in the STBYC register | Holds the previous state | Holds the previous state | No                                        |

Table 3.2.1 Reset Types

\* If a reset occurs in stop or hardware standby mode, the device waits for oscillation to stabilize regardless of the reset type.

\* The delay for oscillation to stabilize after a power-on reset is fixed at 2<sup>18</sup> source oscillator cycles. For other resets, the delay for oscillation to stabilize depends on CS1 and CS0 in the clock selection register.

Figure 3.2.2 shows the flip-flops for the various reset types. The content of these flip-flops can be read from the watchdog timer control register. Therefore, if it is necessary to determine the reset cause after the reset is cleared, read the watchdog timer control register by software and branch to the appropriate program based on the register content. For reference, Figure 3.2.3 shows the structure of the watchdog timer control register.



Fig. 3.2.2 Block Diagram of the Reset Type Bits

|                  | 7     | 6    | 5    | 4    | 3    | 2   | 1   | 0   | ⇔Bit No. |
|------------------|-------|------|------|------|------|-----|-----|-----|----------|
| Address: 0000А8н | PONR  | STBR | WRST | ERST | SRST | WTE | WT1 | WT0 | WDTC     |
| Read/write       | ( )   | (R)  | (R)  | (R)  | (R)  | (W) | (W) | (W) |          |
| Initial value    | ⇒ (X) | (X)  | (X)  | (X)  | (X)  | (1) | (1) | (1) |          |

# Fig. 3.2.3 WDTC (Watchdog Timer Control Register)

If more than one reset type occurs, the reset type bits are set in the watchdog timer control register for each reset type that occurred. Accordingly, if an external reset request and watchdog reset occur simultaneously, both the ERST and WRST bits are set to"1".

However, the power-on reset is an exception to this rule. When the PONR bit is "1", the values of the other bits do not indicate correctly whether their respective reset types occurred or not. Therefore, when developing software, ignore the values of the other reset type bits if the PONR bit is "1".

| Reset Type       | PONR | STBR | WRST | ERST | SRST |
|------------------|------|------|------|------|------|
| Power-on         | 1    | -    | -    | -    | -    |
| Hardware standby | *    | 1    | *    | *    | *    |
| Watchdog timer   | *    | *    | 1    | *    | *    |
| External pin     | *    | *    | *    | 1    | *    |
| RST bit          | *    | *    | *    | *    | 1    |

Table 3.2.2 Value of the Reset Type Bits for Each Reset Type

(The values indicated by \* hold their previous values.)

The reset type bits are only cleared by reading the watchdog timer control register. Therefore, once a particular reset type occurs, the corresponding reset type bit maintains the value "1", even if a different type of reset subsequently occurs.

# 3.3 Memory Access Modes

# 3.3.1 Modes

The F<sup>2</sup>MC-16L has various modes for the different access methods, access areas, and test operation. The modes for this module are classified as follows.



## ■ Operation mode

The operation mode controls the device operating status and is set by the mode setting pins (MD $\times$ ) and the M $\times$  bits in the mode data. The operation mode can select normal operation, activation of the internal test program, or activation of the special test functions.

#### Bus mode

The bus mode controls the operation of the external access function. The mode setting pins (MD×) and the M× bits in the mode data determine the bus mode. The mode setting pins (MD×) specify the bus mode for reading the reset vector and mode data. The M× bits in the mode data specify the bus mode for normal operation.

## ■ Access mode

The access mode specifies the external data bus width and the address/data bus operation. The mode setting pins (MD×) and the S× bit in the mode data determine the access mode. The access mode specifies the external data bus width (8-bit or 16-bit) and whether the address/data bus operates in non-multiplex or multiplex mode.

#### 3.3 Memory Access Modes

# 3.3.2 Mode Pins

Table 3.3.1 lists the operations specified by the different MD2 to MD0 external pin combinations.

| S | Mode Pin<br>Settings<br>MD2 MD1 MD0 |   | Mode Reset Vector External Data<br>Access Area Bus Width |                              | Address/<br>Data Bus | Remarks       |                                            |
|---|-------------------------------------|---|----------------------------------------------------------|------------------------------|----------------------|---------------|--------------------------------------------|
| 0 | 0 0 0                               |   | External vector mode 0                                   | vector mode 0 External 8-bit |                      | Multiplex     |                                            |
| 0 | 0                                   | 1 | External vector mode 1                                   | External                     | 16-bit               | mode          | Reset vector is accessed via a 16-bit bus. |
| 0 | 1                                   | 0 | External vector mode 2                                   | External                     | 8-bit                | Non-multiplex |                                            |
| 0 | 1                                   | 1 | External vector mode 3                                   | External                     | 16-bit               | mode          | Reset vector is accessed via a 16-bit bus. |
| 1 | 0                                   | 0 |                                                          |                              | ·                    |               |                                            |
| 1 | 0                                   | 1 | (Drobibited pattings)                                    |                              |                      |               |                                            |
| 1 | 1                                   | 0 | (Prohibited settings)                                    |                              |                      |               |                                            |
| 1 | 1                                   | 1 | 1                                                        |                              |                      |               |                                            |

 Table 3.3.1 Relationship Between Mode Pins and Setting Modes

# 3.3.3 Mode Data

The mode data controls CPU operation and is located at FFFFDFH in main memory. The reset sequence reads the mode data and loads it to the "mode register" in the device. Only the reset sequence can change the content of the mode register.

The settings in the mode register apply after the completion of the reset sequence.

Always set the reserved bits to "0".

Figure 3.3.1 shows the settings for each bit.





#### ■ Mode setting bits

These bits specify the bus mode and access mode after completion of the reset sequence. Table 3.3.3 lists the functions set by the mode setting bits.

## Table 3.3.3 Functions Set by the Mode Setting Bits

| <b>S</b> 1 | S0 | Fi                            | Remarks                         |  |
|------------|----|-------------------------------|---------------------------------|--|
| 0          | 0  | 8-bit external data bus mode  | Address/data bus multiplex mode |  |
| 0          | 1  | 16-bit external data bus mode | Address/data bus multiplex mode |  |
| 1          | 0  | 8-bit external data bus mode  | Address/data bus non-multiplex  |  |
| 1          | 1  | 16-bit external data bus mode | mode                            |  |

■ Bus mode setting bits

These bits specify the operation mode after completion of the reset sequence. Table 3.3.4 lists the functions set by the bus mode setting bits.

| M1 | MO | Function                        | Remarks |
|----|----|---------------------------------|---------|
| 0  | 0  | (Prohibited setting)            |         |
| 0  | 1  | (Prohibited setting)            |         |
| 1  | 0  | External ROM, external bus mode |         |
| 1  | 1  | (Prohibited setting)            |         |

Figure 3.3.2 shows the correspondence between the access area and physical address for each bus mode setting.



External ROM, external bus Note: The addresses marked "Differs by model type" depend on the model type.

# Fig. 3.3.2 Relationship Between Access Areas and Physical Addresses for Each Bus Mode

■ Recommended setting example

Table 3.3.5 shows examples of recommended mode pin and mode data settings.

| Table 3.3.5 | <b>Recommended Mode Pin and Mode Data Settings</b> |
|-------------|----------------------------------------------------|
|-------------|----------------------------------------------------|

| Setting Example                                                                                                | MD2 | MD1 | MD0 | M1 | MO | S1 | S0 |
|----------------------------------------------------------------------------------------------------------------|-----|-----|-----|----|----|----|----|
| External ROM/external bus mode, 16-bit bus, 16-bit bus for vector access (Address/data bus multiplex mode)     | 0   | 0   | 1   | 1  | 0  | 0  | 1  |
| External ROM/external bus mode, 8-bit bus (Address/data bus multiplex mode)                                    | 0   | 0   | 0   | 1  | 0  | 0  | 0  |
| External ROM/external bus mode, 16-bit bus, 16-bit bus for vector access (Address/data bus non-multiplex mode) | 0   | 1   | 1   | 1  | 0  | 1  | 1  |
| External ROM/external bus mode, 8-bit bus (Address/data bus non-multiplex mode)                                | 0   | 1   | 0   | 1  | 0  | 1  | 0  |

**Note:** In the MB90610A series, a maximum area of 64KB can be accessed when output of the upper address (A23 to A16) is disabled.

The signals input or output via the external pins connected to this module vary depending on the mode. Table 3.3.5 lists the operation of the mode-dependent external pins.

|                                       | Function                  |           |                           |                |                           |                      |                        |            |  |
|---------------------------------------|---------------------------|-----------|---------------------------|----------------|---------------------------|----------------------|------------------------|------------|--|
|                                       | Non-Multiplex Mode        |           |                           | Multiplex Mode |                           |                      |                        |            |  |
|                                       | External Address Control  |           |                           |                | External Address Control  |                      |                        |            |  |
| Pin                                   | Enabled (Address) Disable |           |                           | ed (Port)      | Enabled                   | (Address)            | Disabled (Port)        |            |  |
|                                       | External Bus<br>Expansion |           | External Bus<br>Expansion |                | External Bus<br>Expansion |                      | External Bus Expansion |            |  |
|                                       | 8-Bit                     | 16-Bit    | 8-Bit                     | 16-Bit         | 8-Bit                     | 16-Bit               | 8-Bit                  | 16-Bit     |  |
| D07 to 00/<br>AD07 to 00              | D07 to 00                 |           |                           | AD07 to 00     |                           |                      |                        |            |  |
| P17 to 10/<br>D15 to 08<br>AD15 to 08 | Port                      | D15 to 08 | Port                      | D15 to 08      | A15 to 08                 | A15 to 08 AD15 to 08 |                        | AD15 to 08 |  |
| P27 to 20/<br>A07 to 00               | A07 to 00                 |           | A07 to 00                 |                |                           |                      |                        |            |  |
| P37 to 30/<br>A15 to 08               | A15                       | i to 08   | A15 to 08                 |                | - Port                    |                      |                        |            |  |
| P47 to 40/<br>A23 to 16               | A23 to 16                 |           | Port                      |                | A23 to 16                 |                      | Port                   |            |  |
| ALE                                   | ALE                       |           |                           | ALE            |                           |                      |                        |            |  |
| RDX                                   | RDX                       |           |                           | RDX            |                           |                      |                        |            |  |
| P55/WRLX                              | WRLX                      |           | WRLX                      |                |                           |                      |                        |            |  |
| P54/WRHX                              | Port                      | WRHX      | Port                      | WRHX           | Port WRHX                 |                      | Port                   | WRHX       |  |
| P53/HRQ                               | HRQ                       |           |                           | HRQ            |                           |                      |                        |            |  |
| P52/HAKX                              | НАКХ                      |           |                           | НАКХ           |                           |                      |                        |            |  |
| P51/RDY                               | RDY                       |           |                           | RDY            |                           |                      |                        |            |  |
| P50/CLK                               | CLK                       |           |                           | CLK            |                           |                      |                        |            |  |

 Table 3.3.5
 Operation of Mode-Dependent External Pins

**Note:** The upper address, WRLX, WRHX, HAKX, HRQ, RDY, and CLK can be set for use as ports by function selection.

#### 3.4 External Memory Access

# 3.4 External Memory Access

The F<sup>2</sup>MC-16L provides the following address, data, and control signals for accessing external memory or peripherals.

| CLK (P50):    | Outputs the machine cycle clock (KBP)             |
|---------------|---------------------------------------------------|
| ▷RDY (P51):   | External ready input pin                          |
| ♦ WRHX (P54): | Write signal for the upper 8 bits of the data bus |
| WRLX (P55):   | Write signal for the lower 8 bits of the data bus |
| RDX:          | Read signal                                       |
| >ALE:         | Address latch enable signal (in multiplex mode)   |

# 3.4.1 External Memory Access Control Signals

External memory access is performed in 3 cycles if the ready function is not used. Figure 3.4.1 shows an overview of the external access timings.

A function is available to perform 8-bit bus access in 16-bit external bus mode. This allows reading and writing of 8-bit peripheral chips in systems where both 8 and 16-bit peripheral chips are connected to the external bus. As 8-bit bus access uses the lower 8 bits of the data bus, connect 8-bit peripheral chips to the lower 8 bits of the data bus.

In 16-bit external bus mode, the HMBS, LMBS, and IOBS bits in EPCR specify whether to perform 8 or 16-bit bus access.

In multiplex mode, it is possible that only the address output and ALE assert output are performed and, by not asserting RDX, WRLX, and WRHX, actual bus operation is not performed. Do not perform peripheral chip access using the ALE signal only.

External 8-bit bus mode (Non-multiplex mode)



External 8-bit bus mode (Multiplex mode)



Fig. 3.4.1 Timing Chart for External Memory Access

#### 3.4 External Memory Access

□ External 16-bit bus mode (Non-multiplex mode)



\*Design external circuits to always perform word reads.

External 16-bit bus mode (Multiplex mode)



\*Design external circuits to always perform word reads.



#### 3.4.2 Ready Function

Access to low-speed memory or peripheral circuits can be performed by using the P51/RDY pin and by setting the auto-ready function selection register (ARSR).

When the RYE bit in the bus control signal selection register (EPCR) is set to "1", the access cycle can be extended during access of an external area by treating the period while an "L" level is input to the P51/ RDY pin as wait cycles.

□ Non-multiplex mode



Fig. 3.4.2 Ready Timing Chart

#### 3.4 External Memory Access

#### □ Multiplex mode



Fig. 3.4.2 Ready Timing Chart

The F<sup>2</sup>MC-16L has two built-in auto-ready functions for external memory. Auto-ready functions are provided for accessing the lower address external area located between addresses 002000H and 7FFFFH and for accessing the upper address external area located between addresses 800000H and FFFFFFH. The auto-ready function can extend the access cycle automatically by inserting between 1 and 3 wait cycles, without the need for an external circuit. This function is activated by setting the LMR1 and LMR0 bits (for the lower external address area) and the HMR1 and HMR0 bits (for the upper external address area) in the ARSR register.

The F<sup>2</sup>MC-16L also has a built-in auto-ready function for external I/O that is independent of the autoready function for memory. The auto-ready function can extend the access cycle automatically by inserting between 1 and 3 wait cycles, without the need for an external circuit, when an external area between addresses 0000C0H and 0000FFH is accessed. The function is activated by the IOR1 and IOR0 bits of the ARSR register. For both the external memory and external I/O auto-ready functions, if the RYE bit in the EPCR register is set to "1", the wait cycles continue after the wait cycles inserted by the auto-ready function are complete for as long as an "L" level is input to the P51/RDY pin.

| Auto-ready function<br>selection registerr<br>(ARSR) | 15   | 14   | 13   | 12    | 11   | 10  | 9    | 8    | ⇔Bit No. |
|------------------------------------------------------|------|------|------|-------|------|-----|------|------|----------|
| Address: 0000А5н                                     | IOR1 | IOR0 | HMR1 | HMR0  | -    | -   | LMR1 | LMR0 | ARSR     |
| Read/write ⇒                                         | (W)  | (W)  | (W)  | (W)   | (-)  | (-) | (W)  | (W)  |          |
| Initial value ⇒                                      | (0)  | (0)  | (1)  | (1)   | (-)  | (-) | (0)  | (0)  |          |
| Bus control signal<br>selection register<br>(EPCR)   | 15   | 14   | 13   | 12    | 11   | 10  | 9    | 8    | ⇔Bit No. |
| Address: 0000A7н                                     | -    | LMBS | WRE  | HMBS  | IOBS | HDE | RYE  | CKE  | EPCR     |
| Read/write ⇔                                         | (-)  | (W)  | (W)  | (W)   | (W)  | (W) | (W)  | (W)  |          |
| Initial value ⇒                                      | (-)  | (0)  | (0)  | (1/0) | (0)  | (0) | (0)  | (0)  |          |

Figure 3.4.3 shows the structure of the ARSR and EPCR registers.

#### Fig. 3.4.3 Structure of the Auto-Ready Function Selection Register and Bus Control Signal Selection Register

#### 3.4.3 Hold Function

The external bus hold function is activated by the P53/HRQ and P52/HAKX pins if the HDE bit of the EPCR register is set to "1". Inputting an "H" level to the P53/HRQ pin initiates the hold state after completion of the current CPU instruction (or after completing one data element in a string instruction). In the hold state, the device outputs an "L" level from the P52/HAKX pin and sets the following pins to high impedance.

O Non-multiplex mode

- Address output P47/A23 to P40/A16, P37/A15 to P30/A08, P27/A07 to P20/A00
- Data I/O P17/D15/AD15 to P10/D08/AD08, D07/AD07 to D00/AD00
- Bus control signals RDX, P55/WRLX, P54/WRHX

#### O Multiplex mode

| • Address output   | P47/A23 to P40/A16                                 |
|--------------------|----------------------------------------------------|
| • Address/data I/O | P17/D15/AD15 to P10/D08/AD08, D07/AD07 to D00/AD00 |
|                    |                                                    |

• Bus control signals RDX, P55/WRLX, P54/WRHX

This enables external circuits to use the external bus.

Inputting an "L" level to the P53/HRQ pin changes the output of the P52/HAKX pin to the "H" level, restores the external pin statuses, and restarts CPU operation.

Hold request inputs are ignored in stop mode.



☐ Hold timing (external 16-bit bus mode) Non-multiplex mode



## 3.5 Low Power Modes

The following operation modes are available: PLL clock mode, PLL sleep mode, timer mode, main clock mode, main sleep mode, stop mode, and hardware standby mode. Operation modes other than PLL clock mode are classified as low power consumption modes.

In main clock mode and main sleep mode, the device operates on the main clock only (OSC oscillator clock). The PLL clock (VCO oscillator) is halted in these modes and the main clock divided by 2 is used as the operating clock. In PLL sleep mode and main sleep mode, the CPU's operating clock only is halted and other elements continue to operate. In timer mode, only the timebase timer operates. Stop mode and hardware standby mode halt the oscillator, maintaining existing data with minimum power consumption.

The CPU intermittent operation function provides an intermittent clock to the CPU when register, internal memory, internal resource, or external bus access is performed. This function reduces power consumption by lowering the CPU execution speed while still providing a high-speed clock to internal resources.

The PLL clock multiplier can be selected as 1, 2, 3, or 4 by the CS1, 0 bits.

Table 3.5.1 shows the state of each chip section in each operation mode.

| State Trans<br>Condition |                | Oscillation | Clock     | CPU    | Peripheral<br>s | Pins                | How to Exit        |  |
|--------------------------|----------------|-------------|-----------|--------|-----------------|---------------------|--------------------|--|
| Main sleep               | MCS=1<br>SLP=1 | Operating   | Operating | Halted | Operating       | Operating           | Reset<br>Interrupt |  |
| PLL sleep                | MCS=0<br>SLP=1 | Operating   | Operating | Halted | Operating       | Operating           | Reset<br>Interrupt |  |
| Timer (SPL=0)            | MCS=0<br>STP=1 | Operating   | Halted    | Halted | Halted          | Hold current levels | Reset<br>Interrupt |  |
| Timer (SPL=1)            | MCS=0<br>STP=1 | Operating   | Halted    | Halted | Halted          | HI-Z                | Reset<br>Interrupt |  |
| Stop (SPL=0)             | MCS=1<br>STP=1 | Halted      | Halted    | Halted | Halted          | Hold current levels | Reset<br>Interrupt |  |
| Stop (SPL=1)             | MCS=1<br>STP=1 | Halted      | Halted    | Halted | Halted          | HI-Z                | Reset<br>Interrupt |  |
| Hardware<br>standby      | HSTX=L         | Halted      | Halted    | Halted | Halted          | HI-Z                | HSTX=H             |  |

 Table 3.5.1 Operating States in Low Power Modes

#### 3.5 Low Power Modes

Figure 3.5.1 shows the structure of the low power mode control register and clock selection register.

| Address:                        | 7   | 6          | 5            | 4          | 3          | 2            | 1            | 0          | ⇔Bit No. |
|---------------------------------|-----|------------|--------------|------------|------------|--------------|--------------|------------|----------|
| 0000А0н                         | STP | SLP        | SPL          | RST        | Reserved   | CG1          | CG0          | Reserved   | LPMCR    |
| Read/write □<br>Initial value □ | ( ) | (W)<br>(0) | (R/W)<br>(0) | (W)<br>(1) | (-)<br>(1) | (R/W)<br>(0) | (R/W)<br>(0) | (-)<br>(0) |          |

■ LPMCR (Low power mode control register)

■ CKSCR (Clock selection register)

| Address:   | 15       | 14         | 13           | 12           | 11         | 10           | 9            | 8            | ⇔Bit No. |
|------------|----------|------------|--------------|--------------|------------|--------------|--------------|--------------|----------|
| 0000A1н    | Reserved | MCM        | WS1          | WS2          | Reserved   | MCS          | CS1          | CS0          | CKSCR    |
| Read/write | ( )      | (R)<br>(1) | (R/W)<br>(1) | (R/W)<br>(1) | (-)<br>(1) | (R/W)<br>(1) | (R/W)<br>(0) | (R/W)<br>(0) |          |

#### Fig. 3.5.1 LPMCR and CKSCR

Note: Accessing the low power mode control register:

Writing to the low power mode control register changes to the specified low power mode (stop mode or sleep mode). However, when changing to a low power mode, always use one of the instructions listed in Table 3.5.2. Using instructions other than those listed in Table 3.5.2 can cause misoperation. However, any instruction can be used on the low power mode control register when controlling functions other than changing to a low power mode.

Always write to an even-numbered address when performing a word-length write to the low power mode control register. Changing to a low power mode by writing to an odd-numbered address may cause misoperation.

| Table 3.5.2 Instructions to Use When Changing to a Low Power Mode |
|-------------------------------------------------------------------|
|-------------------------------------------------------------------|

| MOV io,#imm8      | MOV dir,#imm8   | MOV eam,#imm8   | MOV eam,Ri   |
|-------------------|-----------------|-----------------|--------------|
| MOV io,A          | MOV dir,A       | MOV addr16,A    | MOV eam,A    |
| MOV @RLi+disp8,A  | MOVP addr24,A   |                 |              |
| MOVW io,#imm16    | MOVW dir,#imm16 | MOVW eam,#imm16 | MOVW eam,RWi |
| MOVW io,A         | MOVW dir,A      | MOVW addr16,A   | MOVW eam,A   |
| MOVW @RLi+disp8,A | MOVPW addr24,A  |                 |              |
| SETB io:bp        | SETB dir:bp     | SETB addr16:bp  |              |

The following describes the operation for each mode.

#### (1) Sleep mode

• Transition to sleep mode

Writing "1" to the SLP bit and "0" to the STP bit in the low power mode control register sets the standby control circuit to sleep mode. In sleep mode, only the clock supplied to the CPU stops. The CPU halts but the peripheral circuits continue to operate.

If an interrupt request is present when "1" is written to the SLP bit, the standby control circuit does not change to sleep mode. Therefore, if the CPU cannot receive the interrupt, the CPU proceeds to execute the next instruction. If the CPU can receive the interrupt, execution immediately branches to the interrupt processing routine.

Sleep mode maintains the contents of internal RAM and the contents of the accumulator and other special registers. The external bus hold function continues to operate in sleep mode. The device goes to the hold state if a hold request is received.

• Wake-up from sleep mode

The standby control circuit exits sleep mode when a reset input or interrupt occurs. When sleep mode is cleared by a reset, the device enters the reset state after waking up from sleep mode.

The standby control circuit exits sleep mode when an interrupt request with a higher priority than level 7 is generated by a peripheral circuit or other source. Normal interrupt processing starts after exiting sleep mode. The CPU executes interrupt processing if the I flag, ILM, and interrupt control register (ICR) settings allow the interrupt to be received. If the CPU cannot receive the interrupt, execution continues from the next instruction after the instruction that entered sleep mode.

**Note:** When executing interrupt processing, the device normally enters interrupt processing after executing the next instruction after the instruction that entered sleep mode. However, the device may enter interrupt processing before execution of the next instruction if an external bus hold request was received at the same time as the device changed to sleep mode.

#### (2) Watch mode

• Transition to watch mode

Writing "1" to the STP bit in the low power mode control register when the MCS bit in the clock selection register is "0" sets the standby control circuit to watch mode. In watch mode, all operation halts except for the source oscillator and timebase timer. This halts almost all chip functions.

The SPL bit in the low power mode control register controls whether I/O pins hold their existing states or change to high impedance during watch mode.

If an interrupt request is present when "1" is written to the STP bit, the standby control circuit does not change to watch mode.

#### 3.5 Low Power Modes

Watch mode maintains the contents of internal RAM and the contents of the accumulator and other dedicated registers. The external bus hold function halts in watch mode and hold request inputs are not accepted. It is possible that the bus changes to the Hi-Z state but the HAKX signal does not change to "L" if a hold request is input during transition to watch mode.

• Releasing watch mode

The standby control circuit releases watch mode when a reset input or interrupt occurs. When watch mode is released by a reset, the device enters the reset state after releasing watch mode.

When recovering from watch mode, the standby control circuit first releases watch mode, then delays for the PLL clock oscillation to stabilize. As the MCS bit is not cleared by an external reset, the reset sequence is executed using the main clock if the duration of the reset is shorter than the PLL clock oscillation stabilization delay. As the timebase timer is not cleared, the PLL clock oscillation stabilization delay time will vary between  $2^{13}$  and  $3 * 2^{13}$  main clock cycles, depending on the state of the timebase timer.

The standby control circuit releases watch mode when an interrupt request with a higher priority than level 7 is generated by a peripheral circuit or other source. Normal interrupt processing starts after releasing watch mode. The CPU executes interrupt processing if the I flag, ILM, and interrupt control register (ICR) settings allow the interrupt to be received. If the CPU cannot receive the interrupt, execution continues from the next instruction after the instruction that entered watch mode.

- **Note:** When executing interrupt processing, the device normally enters interrupt processing after executing the next instruction after the instruction that entered watch mode. However, the device may enter interrupt processing before execution of the next instruction if an external bus hold request was received at the same time as the device changed to watch mode.
- **Note:** The device enters the PLL clock oscillation stabilization delay state after releasing watch mode. Therefore, if not using the PLL clock, change the MCS bit to "1" immediately after the reset or in the first instruction at the interrupt destination.

#### (3) Stop mode

• Transition to stop mode

Writing "1" to the STP bit in the low power mode control register when the MCS bit in the clock selection register is "1" sets the standby control circuit to stop mode. Stop mode stops the source oscillator, halting all chip functions. Therefore, this mode can maintain data with minimum power consumption.

The SPL bit in the LPMCR register controls whether I/O pins hold their existing states or change to high impedance during stop mode.

If an interrupt request is present when "1" is written to the STP bit, the standby control circuit does not change to stop mode.

Stop mode maintains the contents of internal RAM and the contents of the accumulator and other special registers. The external bus hold function halts in stop mode and hold request inputs are not accepted. It is possible that the bus changes to the Hi-Z state but the HAKX signal does not change to "L" if a hold request is input during transition to stop mode.

• Wake-up from stop mode

The standby control circuit exits stop mode when a reset input or interrupt occurs. When stop mode is cleared by a reset, the device enters the reset state after waking up from stop mode.

When recovering from stop mode, the standby control circuit first delays for the oscillation to stabilize, then exits stop mode. Therefore, if stop mode is exited by a reset, the reset sequence does not execute until after the oscillation stabilization delay.

The standby control circuit clears stop mode when an interrupt request with a higher priority than level 7 is generated by a peripheral circuit or other source. After wake-up from stop mode, normal interrupt processing starts after the delay for the main clock oscillation to stabilize. The duration of the delay is specified in the WS1 and WS0 bits in the CKSCR register. The CPU executes interrupt processing if the I flag, ILM, and interrupt control register (ICR) settings allow the interrupt to be received. If the CPU cannot receive the interrupt, execution continues from the next instruction after the instruction that entered stop mode.

**Note:** When executing interrupt processing, the device normally enters interrupt processing after executing the next instruction after the instruction that entered stop mode. However, the device may enter interrupt processing before execution of the next instruction if an external bus hold request was received at the same time as the device changed to stop mode.

#### (4) Hardware standby mode

• Entering hardware standby mode

Applying an "L" level to the HSTX pin sets the standby control circuit to hardware standby mode, regardless of the current state. Hardware standby mode halts the oscillator and sets all I/O pins to high impedance. The mode continues for as long as the HSTX pin is "L" and is unaffected by other states, including resets.

Hardware standby mode maintains the contents of internal RAM, but initializes the accumulator and other special registers.

• Wake-up from hardware standby mode

Hardware standby mode can only be cleared by the HSTX pin. When the HSTX pin changes to the "H" level, the standby control circuit clears hardware standby mode, asserts the internal reset signal, and enters the oscillation stabilization delay state. After the oscillation stabilization delay completes, the standby control circuit clears the internal reset and the CPU starts execution from the reset sequence.

#### (5) CPU intermittent operation function

The CPU intermittent operation function halts the clock to the CPU for a fixed duration when register, internal memory (ROM, RAM, I/O, or resource), or external bus access is performed and delays the start of the internal bus cycle. This function reduces power consumption by lowering the CPU execution speed while still providing a high-speed clock to internal resources. The CG1 and CG0 bits specify the number of clock cycles that the CPU clock is stopped.

External bus operation uses the same clock as the resources.

The instruction execution time when the CPU intermittent operation function is used is calculated by adding a correction value to the normal execution time. The correction value is determined by multiplying the number of cycles that the clock is stopped by the number of register, internal memory, internal resource, or external bus accesses.



#### (6) Setting the oscillation stabilization delay time

The WS1 and WS0 bits select the oscillation stabilization delay time used on release of stop mode or hardware standby mode, or when a watchdog reset occurs. Set the oscillation stabilization delay time based on the type and characteristics of the oscillator circuit and oscillator element connected to the X0 and X1 pins.

These bits are not initialized by resets other than the power-on reset. The bits are initialized to "11" by a power-on reset. Therefore, the oscillation stabilization delay after power-on is approximately 2<sup>18</sup> counts of the source oscillator.

#### (7) Switching the machine clock

• Switching between the main clock and PLL clock

Operation can be switched between the main clock and the PLL clock by writing to the MCS bit in the CKSCR register.

If the MCS bit is changed from "1" to "0", the device switches from the main clock to the PLL clock after the oscillation stabilization delay for the PLL clock (2<sup>13</sup> machine clocks).

If the MCS bit is changed from "0" to "1", the device switches from the PLL clock to the main clock at the next timing when the PLL and main clock edges match (after between 1 and 8 PLL clocks).

Note that the machine clock does not switch immediately after changing the MCS bit. Therefore, when using resources that depend on the machine clock, check the MCM bit to confirm that the clock switch has occurred before using the resource.

• Initializing the machine clock

The MCS bit is not initialized by external pin and RST bit resets. Other resets initialize MCS to "1".

Chapter 3: Operation

#### (8) State transitions

Figure 3.5.2 shows the state transitions for the low power modes.



- (4) SLP = "1", MCS = "1"
- (5) Interrupt input
- (6) STP = "1", MCS = "1"
- (7) Hardware standby input

- (10) MCS = "1"
- (11) STP = "1", MCS = "0"
- (12) SLP = "1", MCS = "0"
- (13) Reset released, MCS = "0"

### Fig. 3.5.2 State Transitions for Low Power Modes

# 3.6 Pin States During Sleep, Stop, Hold, and Reset

Tables 3.6.1 to 3.6.4 list the pin states for each bus mode during stop, hold, and reset.

| Pin                                    | Sleep                                                 | Sto                                           | р                                                                                                                                                                                                                                                                                                                                              | Hold                            | Reset                         | Hardware                                         |
|----------------------------------------|-------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------|--------------------------------------------------|
| FIII                                   | Sleep                                                 | SPL=0                                         | SPL=1                                                                                                                                                                                                                                                                                                                                          | поіа                            | Reset                         | Standby                                          |
| D07 to D00<br>D15 to D08               | Input disabled<br>Hi-Z output                         | Input disabled<br>Hi-Z output                 |                                                                                                                                                                                                                                                                                                                                                | Input disabled                  | Input disabled<br>Hi-Z output |                                                  |
| A07 to A00<br>A15 to A08               | Output<br>(Note 1)                                    | Output<br>(Note 1)                            | Imput disabled         Imput disabled         Hi-Z output         Imput disabled         Hi-Z output         Imput disabled         Hi-Z output         Imput disabled         Output enabled         (Note 2) (Note 4)         Imput disabled         Output enabled         Output "H"         (Note 6)         Imput "I"         Output "H" | Output                          |                               |                                                  |
| A23 to A16                             | Output<br>(Note 1) (Note 4)                           | Output<br>(Note 1) (Note 4)                   |                                                                                                                                                                                                                                                                                                                                                | Hi-Z output                     | (Note 1)                      |                                                  |
| P50 (CLK)                              | Input disabled<br>Output enabled<br>(Note 2) (Note 4) | Input disabled<br>Output<br>(Note 1) (Note 4) |                                                                                                                                                                                                                                                                                                                                                | Output enabled                  |                               |                                                  |
| P51 (RDY)                              | Hold previous state                                   | Hold previous state                           |                                                                                                                                                                                                                                                                                                                                                | Output "H"                      | Output "H"<br>(Note 3)        | Input<br>disconnected<br>Hi-Z output<br>(Note 6) |
| P52 (HAKX)                             | (Note 5)                                              | (Note 5)                                      |                                                                                                                                                                                                                                                                                                                                                | Output "L"                      | (                             |                                                  |
| P53 (HRQ)                              |                                                       |                                               | (Note 6)                                                                                                                                                                                                                                                                                                                                       | Input "1"                       |                               |                                                  |
| P54 (WRHX)<br>P55 (WRLX)               | Output "H"<br>(Note 4)                                | Output "H"<br>(Note 4)                        |                                                                                                                                                                                                                                                                                                                                                | Output "H"<br>(Note 3) (Note 4) |                               |                                                  |
| RDX                                    | Output "H"                                            | Output "H"                                    |                                                                                                                                                                                                                                                                                                                                                | Output III II                   | Output "H"                    |                                                  |
| ALE                                    | Output "L"                                            | Output "L"                                    |                                                                                                                                                                                                                                                                                                                                                | Output "H"<br>(Note 3)          | Output enabled (Note 2)       |                                                  |
| P67 to P60<br>P86 to P81<br>P95 to P90 |                                                       | Hold previous state                           | -                                                                                                                                                                                                                                                                                                                                              | Hold previous                   | Input disabled<br>Hi-Z output |                                                  |
| PA7 to PA1<br>CS0                      | Hold previous state (Note 5)                          | (Note 5)                                      |                                                                                                                                                                                                                                                                                                                                                | state<br>(Note 5)               | Output "H"<br>(Note 3)        |                                                  |
| P76 to P70<br>P80                      |                                                       | Input enabled                                 | ·                                                                                                                                                                                                                                                                                                                                              | ]                               | Input disabled<br>Hi-Z output |                                                  |

| Table 3.6.1 Pin States in External Bus/16-Bit Data Bus Mode and Non-Multiplex Mode |
|------------------------------------------------------------------------------------|
|------------------------------------------------------------------------------------|

operating and uses the output function. The output does not change during a reset.

- **Note 2:** "Output enabled" means that, as the drive for the pin driver transistor is enabled and operation of the internal circuit is enabled, output from the internal circuit appears at the pin.
- **Note 3:** Operates as a pulled-up output.
- Note 4: When used as an output port, the pin holds its previous state.
- **Note 5:** "Hold previous state" means the pin continues to output the state output immediately before entering this mode. For input pins, this means that input is disabled. For output pins belonging to internal peripherals that continue to operate, continuing to output the current output state means that the pin continues to output the value set by the internal peripheral. For port or similar output pins, it means that the pin holds its current output level. "Input disabled" means that, although operation of the input gate for the pin is enabled, the pin value is not recognized internally because the internal circuit is not operating.
- **Note 6:** "Input disconnected" means that operation of the input gate for the pin is disabled. "Hi-Z output" means that drive is enabled for the pin driver transistor and the pin goes to the high impedance state.

**Note 1:** The "output" state means that drive is enabled for the pin driver transistor but, as the internal circuit is not operating, the output is fixed at the "H" or "L" level. The output may change at timings other than during a reset if the internal peripheral circuit is

| Pin                                                  | Sleep                                                 | St                                            | ор       | Hold                                                  | Reset                         | Hardware                |  |  |  |              |           |           |                       |
|------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------|----------|-------------------------------------------------------|-------------------------------|-------------------------|--|--|--|--------------|-----------|-----------|-----------------------|
| FIII                                                 | Sleep                                                 | SPL=0                                         | SPL=1    | noid                                                  | Reset                         | Standby                 |  |  |  |              |           |           |                       |
| D07 to D00                                           | Input disabled<br>Hi-Z output                         | Input disabled<br>Hi-Z output                 |          | Input disabled<br>Hi-Z output                         | Input disable<br>Hi-Z output  |                         |  |  |  |              |           |           |                       |
| A07 to A00<br>A15 to A08                             | Output<br>(Note 1)                                    | Output<br>(Note 1)                            |          | Input disabled<br>Hi-Z output                         | Output                        |                         |  |  |  |              |           |           |                       |
| A23 to A16                                           | Output<br>(Note 1) (Note 4)                           | Output<br>(Note 1) (Note 4)                   |          | Input disabled<br>Hi-Z output<br>(Note 4)             | (Note 1)                      |                         |  |  |  |              |           |           |                       |
| P50 (CLK)                                            | Input disabled<br>Output enabled<br>(Note 2) (Note 4) | Input disabled<br>Output<br>(Note 1) (Note 4) | us Input | Input disabled<br>Output enabled<br>(Note 2) (Note 4) |                               |                         |  |  |  |              |           |           |                       |
| P51 (RDY)                                            |                                                       |                                               |          | Input disabled<br>Output "H"<br>(Note 3) (Note 4)     |                               |                         |  |  |  |              |           |           |                       |
| P52 (HAKX)                                           | Hold previous<br>state                                | Hold previous                                 |          | Output "L"                                            | Output "H"<br>(Note 3)        |                         |  |  |  |              |           |           |                       |
| P53 (HRQ)                                            | (Note 5)                                              | (1) (1) (1)                                   |          |                                                       |                               |                         |  |  |  | disconnected | Input "1" | (11010-0) | Input<br>disconnected |
| P54 (WRHX)                                           |                                                       |                                               |          | Hold previous<br>state<br>(Note 5)                    |                               | Hi-Z output<br>(Note 6) |  |  |  |              |           |           |                       |
| P55 (WRLX)                                           | Output "H"<br>(Note 4)                                | Output "H"<br>(Note 4)                        |          | Output "H"<br>(Note 3) (Note 4)                       |                               |                         |  |  |  |              |           |           |                       |
| RDX                                                  | Output "H"                                            | Output "H"                                    |          | Output "H"                                            | Output "H"                    |                         |  |  |  |              |           |           |                       |
| ALE                                                  | Output "L"                                            | Output "L"                                    | -        | (Note 3)                                              | Output enabled (Note 2)       |                         |  |  |  |              |           |           |                       |
| P17 to P10<br>P67 to P60<br>P86 to P81<br>P95 to P90 | Hold previous                                         | Hold previous<br>state<br>(Note 5)            |          | Hold previous                                         | Input disabled<br>Hi-Z output |                         |  |  |  |              |           |           |                       |
| PA7 to PA1<br>CS0                                    | state<br>(Note 5)                                     |                                               |          | state<br>(Note 5)                                     | Output "H"<br>(Note 3)        |                         |  |  |  |              |           |           |                       |
| P77 to P70<br>P80                                    |                                                       | Input enabled                                 |          |                                                       | Input disabled<br>Hi-Z output |                         |  |  |  |              |           |           |                       |

#### Table 3.6.2 Pin States in External Bus/8-Bit Data Bus Mode and Non-Multiplex Mode

**Note 1:** The "output" state means that drive is enabled for the pin driver transistor but, as the internal circuit is not operating, the output is fixed at the "H" or "L" level. The output may change at timings other than during a reset if the internal peripheral circuit is

operating and uses the output function. The output does not change during a reset.

- **Note 2:** "Output enabled" means that, as the drive for the pin driver transistor is enabled and operation of the internal circuit is enabled, output from the internal circuit appears at the pin.
- **Note 3:** Operates as a pulled-up output.
- Note 4: When used as an output port, the pin holds its previous state.
- **Note 5:** "Hold previous state" means the pin continues to output the state output immediately before entering this mode. For input pins, this means that input is disabled. For output pins belonging to internal peripherals that continue to operate, continuing to output the current output state means that the pin continues to output the value set by the internal peripheral. For port or similar output pins, it means that the pin holds its current output level. "Input disabled" means that, although operation of the input gate for the pin is enabled, the pin value is not recognized internally because the internal circuit is not operating.
- **Note 6:** "Input disconnected" means that operation of the input gate for the pin is disabled. "Hi-Z output" means that drive is enabled for the pin driver transistor and the pin goes to the high impedance state.

| Pin                                                                | Sleep                                                 | St                                            | ор       | Hold                                                  | Reset                         | Hardware                |  |  |  |                             |           |
|--------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------|----------|-------------------------------------------------------|-------------------------------|-------------------------|--|--|--|-----------------------------|-----------|
| r                                                                  | Jieep                                                 | SPL=0                                         | SPL=1    |                                                       | Reset                         | Standby                 |  |  |  |                             |           |
| AD07 to AD00<br>AD15 to AD08                                       | Input disabled<br>Hi-Z output                         | Input disabled<br>Hi-Z output                 |          | Input disabled<br>Hi-Z output                         | Input disabled<br>Hi-Z output |                         |  |  |  |                             |           |
| A23 to A16                                                         | Output<br>(Note 1) (Note 4)                           | Output<br>(Note 1) (Note 4)                   |          | Input disabled<br>Hi-Z output<br>(Note 4)             | Output<br>(Note 1)            |                         |  |  |  |                             |           |
| P50 (CLK)                                                          | Input disabled<br>Output enabled<br>(Note 2) (Note 4) | Input disabled<br>Output<br>(Note 1) (Note 4) | -        | Input disabled<br>Output enabled<br>(Note 2) (Note 4) |                               |                         |  |  |  |                             |           |
| P51 (RDY)                                                          | Hold previous state                                   | Hold previous state                           |          | Input disabled<br>Output "H"<br>(Note 3) (Note 4)     | Output "H"<br>(Note 3)        |                         |  |  |  |                             |           |
| P52 (HAKX)                                                         | (Note 5)                                              | (Note 5)                                      | (Note 5) | Input<br>disconnected                                 | Output "L"                    |                         |  |  |  |                             |           |
| P53 (HRQ)                                                          |                                                       |                                               |          |                                                       |                               |                         |  |  |  | disconnected<br>Hi-Z output | Input "1" |
| P54 (WRHX)<br>P55 (WRLX)                                           | Output "H"<br>(Note 4)                                | Output "H"<br>(Note 4)                        | (Note 6) | Output "H"<br>(Note 3) (Note 4)                       |                               | Hi-Z output<br>(Note 6) |  |  |  |                             |           |
| RDX                                                                | Output "H"                                            | Output "H"                                    |          | Output "H"                                            | Output "H"                    |                         |  |  |  |                             |           |
| ALE                                                                | Output "L"                                            | Output "L"                                    |          | (Note 3)                                              | Output enabled (Note 2)       |                         |  |  |  |                             |           |
| P27 to P20<br>P37 to P30<br>P67 to P60<br>P86 to P81<br>P95 to P90 | Hold previous state                                   | Hold previous<br>state<br>(Note 5)            |          | Hold previous state                                   | Input disabled<br>Hi-Z output |                         |  |  |  |                             |           |
| PA7 to PA1<br>CS0                                                  | (Note 5)                                              |                                               |          | (Note 5)                                              | Output "H"<br>(Note 3)        |                         |  |  |  |                             |           |
| P76 to P70<br>P80                                                  |                                                       | Input enabled                                 |          |                                                       | Input disabled<br>Hi-Z output |                         |  |  |  |                             |           |

#### Table 3.6.3 Pin States in External Bus/16-Bit Data Bus Mode and Multiplex Mode

- **Note 1:** The "output" state means that drive is enabled for the pin driver transistor but, as the internal circuit is not operating, the output is fixed at the "H" or "L" level. The output may change at timings other than during a reset if the internal peripheral circuit is
- operating and uses the output function. The output does not change during a reset. Note 2: "Output enabled" means that, as the drive for the pin driver transistor is enabled and operation
- of the internal circuit is enabled, output from the internal circuit appears at the pin.
- **Note 3:** Operates as a pulled-up output.
- Note 4: When used as an output port, the pin holds its previous state.
- **Note 5:** "Hold previous state" means the pin continues to output the state output immediately before entering this mode. For input pins, this means that input is disabled. For output pins belonging to internal peripherals that continue to operate, continuing to output the current output state means that the pin continues to output the value set by the internal peripheral. For port or similar output pins, it means that the pin holds its current output level. "Input disabled" means that, although operation of the input gate for the pin is enabled, the pin value is not recognized internally because the internal circuit is not operating.
- **Note 6:** "Input disconnected" means that operation of the input gate for the pin is disabled. "Hi-Z output" means that drive is enabled for the pin driver transistor and the pin goes to the high impedance state.

| Pin                                                                | Sleep                                                 | St                                            | ор                                      | Hold                                                  | Reset                         | Hardware                                |  |  |              |           |  |
|--------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------|-----------------------------------------|-------------------------------------------------------|-------------------------------|-----------------------------------------|--|--|--------------|-----------|--|
| FIII                                                               | Sleep                                                 | SPL=0                                         | SPL=1                                   | Поїд                                                  | Reset                         | Standby                                 |  |  |              |           |  |
| AD07 to AD00                                                       | Input disabled<br>Hi-Z output                         | Input disabled<br>Hi-Z output                 |                                         | Input disabled                                        | Input disabled<br>Hi-Z output |                                         |  |  |              |           |  |
| AD15 to AD08                                                       | Output<br>(Note 1)                                    | Output<br>(Note 1)                            |                                         | Hi-Z output                                           | Output                        |                                         |  |  |              |           |  |
| A23 to A16                                                         | Output<br>(Note 1) (Note 4)                           | Output<br>(Note 1) (Note 4)                   |                                         | Input disabled<br>Hi-Z output<br>(Note 4)             | (Note 1)                      |                                         |  |  |              |           |  |
| P50 (CLK)                                                          | Input disabled<br>Output enabled<br>(Note 2) (Note 4) | Input disabled<br>Output<br>(Note 1) (Note 4) |                                         | Input disabled<br>Output enabled<br>(Note 2) (Note 4) |                               |                                         |  |  |              |           |  |
| P51 (RDY)                                                          |                                                       |                                               |                                         | Input disabled<br>Output "H"<br>(Note 3) (Note 4)     |                               |                                         |  |  |              |           |  |
| P52 (HAKX)                                                         | Hold previous<br>state                                | (Note 5)                                      | Input                                   | Output "L"                                            | Output "H"<br>(Note 3)        |                                         |  |  |              |           |  |
| P53 (HRQ)                                                          | (Note 5)                                              |                                               |                                         |                                                       |                               |                                         |  |  | disconnected | Input "1" |  |
| P54 (WRHX)                                                         |                                                       |                                               | disconnected<br>Hi-Z output<br>(Note 6) | Hold previous<br>state<br>(Note 5)                    |                               | disconnected<br>Hi-Z output<br>(Note 6) |  |  |              |           |  |
| P55 (WRLX)                                                         | Output "H"<br>(Note 4)                                | Output "H"<br>(Note 4)                        |                                         | Output "H"<br>(Note 3) (Note 4)                       |                               |                                         |  |  |              |           |  |
| RDX                                                                | Output "H"                                            | Output "H"                                    |                                         | Output "H"                                            | Output "H"                    |                                         |  |  |              |           |  |
| ALE                                                                | Output "L"                                            | Output "L"                                    |                                         | (Note 3)                                              | Output enabled (Note 2)       |                                         |  |  |              |           |  |
| P27 to P20<br>P37 to P30<br>P67 to P60<br>P86 to P81<br>P95 to P90 | Hold previous state                                   | Hold previous<br>state<br>(Note 5)            |                                         |                                                       | Input disabled<br>Hi-Z output |                                         |  |  |              |           |  |
| PA7 to PA1<br>CS0                                                  | (Note 5)                                              |                                               |                                         | (Note 5)                                              | Output "H"<br>(Note 3)        | ]                                       |  |  |              |           |  |
| P77 to P70<br>P80                                                  |                                                       | Input enabled                                 |                                         |                                                       | Input disabled<br>Hi-Z output |                                         |  |  |              |           |  |

Table 3.6.4 Pin States in External Bus/8-Bit Data Bus Mode and Multiplex Mode

**Note 1:** The "output" state means that drive is enabled for the pin driver transistor but, as the internal circuit is not operating, the output is fixed at the "H" or "L" level. The output may change at timings other than during a reset if the internal peripheral circuit is

operating and uses the output function. The output does not change during a reset.

- Note 2: "Output enabled" means that, as the drive for the pin driver transistor is enabled and operation of the internal circuit is enabled, output from the internal circuit appears at the pin.
- **Note 3:** Operates as a pulled-up output.
- Note 4: When used as an output port, the pin holds its previous state.
- **Note 5:** "Hold previous state" means the pin continues to output the state output immediately before entering this mode. For input pins, this means that input is disabled. For output pins belonging to internal peripherals that continue to operate, continuing to output the current output state means that the pin continues to output the value set by the internal peripheral. For port or similar output pins, it means that the pin holds its current output level. "Input disabled" means that, although operation of the input gate for the pin is enabled, the pin value is not recognized internally because the internal circuit is not operating.
- Note 6: "Input disconnected" means that operation of the input gate for the pin is disabled. "Hi-Z

# Chapter 4: Instructions

# 4.1 Addressing

In the  $F^2MC-16L$ , the address format is determined by either the instruction's effective address specification, or by the instruction code itself (implied addressing).

## 4.1.1 Effective address field

The address formats specified in the effective address field are shown in Table 4.1.1.

| Code | Notation    |            |       | Address format                                                                  | Default bank |
|------|-------------|------------|-------|---------------------------------------------------------------------------------|--------------|
| 00   | R0          | R0 RW0 RL0 |       |                                                                                 |              |
| 01   | R1          | RW1        |       |                                                                                 |              |
| 02   | R2          | RW2        | RL1   | Degister direct                                                                 |              |
| 03   | R3          | RW3        | (RL1) | Register direct                                                                 | None         |
| 04   | R4          | RW4        | RL2   | Starting from the left, "ea" corresponds to the byte, word and long-word types. |              |
| 05   | R5          | RW5        | (RL2) | byte, word and long-word types.                                                 |              |
| 06   | R6          | RW6        | RL3   |                                                                                 |              |
| 07   | R7          | RW7        | (RL3) |                                                                                 |              |
| 08   |             | @RW0       |       |                                                                                 | DTB          |
| 09   |             | @RW1       |       | Register indirect                                                               | DTB          |
| 0A   |             | @RW2       |       | Register mullect                                                                | ADB          |
| 0B   |             | @RW3       |       |                                                                                 | SPB          |
| 0C   | @RW0+       |            |       |                                                                                 | DTB          |
| 0D   | @RW1+       |            |       | Register indirect with post-incrementing                                        | DTB          |
| 0E   | @RW2+       |            |       |                                                                                 | ADB          |
| 0F   | @RW3+       |            |       |                                                                                 | SPB          |
| 10   | @RW0*disp8  |            |       |                                                                                 | DTB          |
| 11   | @RW1+disp8  |            |       | Register indirect with 8-bit displacement                                       | DTB          |
| 12   | @RW2+disp8  |            |       |                                                                                 | ADB          |
| 13   | @RW3+disp8  |            |       |                                                                                 | SPB          |
| 14   | @RW4+disp8  |            | sp8   |                                                                                 | DTB          |
| 15   | @RW5+disp8  |            | sp8   | Register indirect with 8-bit displacement                                       | DTB          |
| 16   | @RW6+disp8  |            |       | Register multeet with 8-bit displacement                                        | ADB          |
| 17   | @RW7+disp8  |            |       |                                                                                 | SPB          |
| 18   | @RW0+disp16 |            |       |                                                                                 | DTB          |
| 19   | @RW1+disp16 |            |       | Register indirect with 16-bit displacement                                      | DTB          |
| 1A   | @RW2+disp16 |            |       | Register multeet with 10-bit displacement                                       | ADB          |
| 1B   | @RW3+disp16 |            |       |                                                                                 | SPB          |
| 1C   | @RW0+RW7    |            |       | Register indirect with index                                                    | DTB          |
| 1D   | @RW1+RW7    |            |       | Register indirect with index                                                    | DTB          |
| 1E   | @PC+disp16  |            |       | PC indirect with 16-bit displacement                                            | PCB          |
| 1F   | addr16      |            |       | Direct address                                                                  | DTB          |

#### Table 4.1.1 Table 4.1.1 Effective Address Field

## 4.1.2 Addressing Details

#### (1) Immediate value (#imm)

This format specifies the operand value directly.

- #imm4
- #imm8
- #imm6
- #imm32

#### (2) Compressed direct address (dir)

In this format, the operand specifies the low-order 8 bits of the memory address. Bits 8 to 15 of the address are specified by the DPR. Bits 16 to 23 of the address are indicated by the DTB.

#### (3) Direct address (addr16)

In this format, the operand specifies the low-order 16 bits of the memory address. Bits 16 to 23 of the address are indicated by the DTB.

#### (4) Register direct

This format specifies a direct register as the operand.

General-purpose registers

| Byte:      | R0, R1, R2, R3, R4, R5, R6, R7         |
|------------|----------------------------------------|
| Word:      | RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7 |
| Long word: | RL0, RL1, RL2, RL3                     |

Dedicated registers

| Accumulator: | A, AL                   |
|--------------|-------------------------|
| Pointer:     | SP                      |
| Bank:        | PCB, DTB, USB, SSB, ADB |
| Page:        | DPR                     |
| Control:     | PS, CCR, RP, ILM        |

\* Regarding the SP, either the USP or the SSP is selected and used, depending on the value of the S bit in the CCR. In addition, in a branching instruction, the PC is implicitly specified, and is not described in the instruction operand.

#### (5) Register indirect (@RWj j = 0 to 3)

This format accesses the memory address indicated by the contents of the general-purpose register RWj. When RW0/RW1 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 is used, bits 16 to 23 of the address are indicated by ADB.

#### (6) Register indirect with post-incrementing (@RWj + j = 0 to 3)

This format accesses the memory address indicated by the contents of the general-purpose register RWj. After the operand operation, RWj is incremented by the data length of the operand (by 1 for a byte, 2 for a word, and 4 for a long-word). When RW0/RW1 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 is used, bits 16 to 23 of the address are indicated by ADB. Note that if the post-incremented result is the address of the register for which the increment specification was made, the value that is referenced subsequently is the incremented value. In addition, in such a case, if the instruction was a write instruction, the data written by the instruction is given priority, so the register that was to have been incremented contains the write data in the end.

(7) Register indirect with displacement 
$$\begin{pmatrix} @RWi + disp8 & i = 0 \text{ to } 7 \\ @RWj + disp16 & j = 0 \text{ to } 3 \end{pmatrix}$$

This format accesses the memory address indicated by the sum of the contents of the general-purpose register RWj and the displacement value. The displacement value can be one of two types, either a byte or a word, and is added as a signed value. When RW0, RW1, RW4, or RW5 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 or RW7 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 or RW6 is used, bits 16 to 23 of the address are indicated by ADB.

#### (8) Register indirect with base index (@RW0 + RW7, @RW1 + RW7)

This format accesses the memory address indicated by the sum of the contents of the general-purpose register and either RW0 or RW1. Bits 16 to 23 of the address are indicated by DTB.

#### (9) Program counter indirect with displacement (@PC + disp16)

This format accesses the memory address indicated by the sum of the "instruction address + 4 + disp16". The displacement value is a word length value. Bits 16 to 23 of the address are indicated by PCB.

The operand address is generally regarded as "the next instruction address + disp16", but note that this does not hold true for the instructions indicated below:

- DBNZ eam, rel
- DWBNZ eam, rel
- MOV eam, #imm8
- MOVW eam, #imm16
- CBNE eam, #imm8, rel
- CWBNE eam, #imm16, rel

#### 4.1 Addressing

#### (10) Accumulator indirect (@A)

This format has two types: one in which the contents of AL specify bits 00 to 15 of the address and DTB indicates bits 16 to 23; and one in which the low-order 24 bits of A specify bits 00 to 23 of the address.

#### (11) I/O direct (io)

In this format, the memory address of the operand is specified directly by the 8-bit displacement value. Regardless of the value of DTB and DPR, the I/O space from 000000H to 0000FFH is accessed. The access space specification prefix has no effect on this addressing format.

#### (12) Long register indirect with displacement (@RLi + disp8 i = 0 to 3)

This format accesses the memory address indicated by the low-order 24 bits of the sum of the contents of the general-purpose register RLi plus the displacement value. The displacement value is 8 bits, and is added as a signed numeral.

#### (13) Compressed direct bit address (dir:bp)

This format specifies the low-order 8 bits of the memory address with the operand. In addition, bits 8 to 15 of the address are indicated by DPR. Finally, bits 16 to 23 of the address are indicated by DTB. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.

#### (14) I/O direct bit address (io:bp)

This format directly specifies a bit within a physical address from 000000H to 0000FFH. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.

#### (15) Direct bit address (addr16:bp)

This format directly specifies any bit within a 64-kilobyte region. Bits 16 to 23 of the address are indicated by DTB. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.

#### (16) Register list (rlst)

This format specifies the register that is the target of a stack push/pop instruction.

MSB

LSB

A register is selected when the corresponding bit is "1", and is not selected when the corresponding bit is "0".

#### Fig. 4.1.1 Register List Configuration

#### (17) Program counter relative branching address (rel)

With this format, the address of the destination of a branching instruction is the sum of the value of the PC and the 8-bit displacement value. If the result exceeds 16 bits, the amount of the overflow is ignored and the bank register is not incremented or decremented; therefore, the address is kept within a 64-kilobyte bank. This format is used in unconditional and conditional branching instructions. Bits 16 to 23 of the address are indicated by PCB.

#### (18) Direct branching address (addr16)

With this format, the address of the destination of a branching instruction is specified directly by the displacement value. The displacement value is 16 bits, and indicates the branching destination within a logical memory space. This format is used in unconditional branching instructions and subroutine call instructions. Bits 16 to 23 of the address are indicated by PCB.

#### (19) Physical direct branching address (addr24)

With this format, the address of the destination of a branching instruction is specified directly by the displacement value. The displacement value is 24 bits, and specifies the physical address of the branching destination. This format is used in unconditional branching instructions, subroutine call instructions, and software interrupt instructions.

#### (20) Accumulator indirect branching address (@A)

In this format, the 16 bits of the accumulator AL specify the branching destination address. This address indicates a branching destination within a bank space; in this case, bits 16 to 23 of the address are indicated by the PCB. In the case of JCTX, however, bits 16 to 23 of the address are indicated by DTB. This format is used in unconditional branching instructions.

#### (21) Vector address (#vct)

The contents of the specified vector become the branching destination address. There are two data lengths for vector numbers: 4 bits and 8 bits. This format is used in subroutine call instructions and software interrupt instructions.

#### (22) Indirect specification branching address (@ear)

The word data in the address indicated by "ear" is the branching destination address.

#### (23) Indirect specification branching address (@eam)

The word data in the address indicated by "eam" is the branching destination address.

# 4.2 Instruction Set

# Table 4.2.1 Explanation of Items in Table of Instructions

| Item      | Explanation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mnemonic  | Upper-case letters and symbols: Described as they appear in assembler.<br>Lower-case letters: Replaced when described in assembler.<br>Numbers after lower-case letters: Indicate the bit width within the instruction.                                                                                                                                                                                                                                                                      |
| #         | Indicates the number of bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ~         | Indicates the number of cycles.<br>See Table 4.2.4 for details about meanings of letters in items.                                                                                                                                                                                                                                                                                                                                                                                           |
| RG        | Indicates the register access count during execution of instruction. This number is used to compensation the correction value when using the CPU clock gear function.                                                                                                                                                                                                                                                                                                                        |
| В         | Indicates the compensation value for calculating the number of actual cycles during execution of instruction.<br>The number of actual cycles during execution of instruction is the compensation value summed with the value in the "~" column.                                                                                                                                                                                                                                              |
| Operation | Indicates operation of instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LH        | Indicates special operations involving bits 15 through 08 of the accumulator.<br>Z:Transfers "0".<br>X:Sign-extended transfer through sign extension.<br>-:Transfers nothing.                                                                                                                                                                                                                                                                                                                |
| АН        | Indicates special operations involving the high-order 16 bits in the accumulator.<br>*:Transfers from AL to AH.<br>-:No transfer.<br>Z:Transfers 00 to AH.<br>X:Transfers 00 <sub>H</sub> or FF <sub>H</sub> to AH using sign extension AL.                                                                                                                                                                                                                                                  |
| Ι         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| S         | Indicates the status of each of the following flags: I (interrupt enable), S (stack), T (sticky bit),                                                                                                                                                                                                                                                                                                                                                                                        |
| Т         | N (negative), Z (zero), V (overflow), and C (carry).                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Ν         | *:Changes due to execution of instruction.<br>-:No change.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Ζ         | S:Set by execution of instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V         | R:Reset by execution of instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| С         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RMW       | <ul> <li>Indicates whether the instruction is a read-modify-write instruction (a single instruction that reads data from memory, etc., processes the data, and then writes the result to memory.).</li> <li>*:Instruction is a read-modify-write instruction</li> <li>-:Instruction is not a read-modify-write instruction</li> <li>Note: A read-modify-write instruction cannot be used on addresses that have different meanings depending on whether they are read or written.</li> </ul> |

#### ■ Number of execution cycles

The number of cycles required for the execution of an instruction is obtained by summing the value shown in the table for the "number of cycles" for the instruction in question, the compensation value (which depends on certain conditions), and the "number of cycles" needed for the program fetch.

When fetching a program in memory connected to the 16-bit bus, such as on-chip ROM, a program fetch is performed for each two-byte (word) boundary crossed by the instruction being executed; therefore, if there is any interference with data access, etc., the number of execution cycles increases.

When fetching a program in memory connected to the 8-bit external data bus, a program fetch is performed for each byte of the instruction being executed; therefore, if there is any interference with data access, etc., the number of execution cycles increases.

The CPU intermittent operation function halts the clock to the CPU for a specified number of cycles when general purpose register, internal ROM, internal RAM, internal I/O, or external bus access is performed. The CG1 and CG0 bits in the low power mode control register set the number of cycles that the clock is halted.

Therefore, the number of cycles required to execute an instruction when the CPU intermittent operation function is used is calculated by adding a correction value to the normal number of execution cycles. The correction value is the number of accesses multiplied by the number of cycles that the clock is halted.

| Symbol                                             | Explanation                                                                                                                                                                                             |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| А                                                  | 32-bit accumulator<br>The bit length varies according to the instruction.<br>Byte:Low-order 8 bits of AL<br>Word:                                                                                       |
| AH                                                 | High-order 16 bits of A                                                                                                                                                                                 |
| AL                                                 | Low-order 16 bits of A                                                                                                                                                                                  |
| SP                                                 | Stack pointer (USP or SSP)                                                                                                                                                                              |
| PC                                                 | Program counter                                                                                                                                                                                         |
| РСВ                                                | Program bank register                                                                                                                                                                                   |
| DTB                                                | Data bank register                                                                                                                                                                                      |
| ADB                                                | Additional data bank register                                                                                                                                                                           |
| SSB                                                | System stack bank register                                                                                                                                                                              |
| USB                                                | User stack bank register                                                                                                                                                                                |
| SPB                                                | Current stack bank register (SSB or USB)                                                                                                                                                                |
| DPR                                                | Direct page register                                                                                                                                                                                    |
| brg1                                               | DTB, ADB, SSB, USB, DPR, PCB, SPB                                                                                                                                                                       |
| brg2                                               | DTB, ADB, SSB, USB, DPR, SPB                                                                                                                                                                            |
| Ri                                                 | R0, R1, R2, R3, R4, R5, R6, R7                                                                                                                                                                          |
| RWi                                                | RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7                                                                                                                                                                  |
| RWj                                                | RW0, RW1, RW2, RW3                                                                                                                                                                                      |
| RLi                                                | RL0, RL1, RL2, RL3                                                                                                                                                                                      |
| dir<br>addr16<br>addr24<br>ad24 0-15<br>ad24 16-23 | Compact direct addressing<br>Direct addressing<br>Physical direct addressing<br>Bits 0 to 15 of addr24<br>Bits 16 to 23 of addr24                                                                       |
| io                                                 | I/O area (000000н to 0000FFн)                                                                                                                                                                           |
| #imm4<br>#imm8<br>#imm16<br>#imm32<br>ext(imm8)    | <ul> <li>4-bit immediate data</li> <li>8-bit immediate data</li> <li>16-bit immediate data</li> <li>32-bit immediate data</li> <li>16-bit data signed and extended from 8-bit immediate data</li> </ul> |
| disp8<br>disp16                                    | 8-bit displacement<br>16-bit displacement                                                                                                                                                               |

# Table 4.2.2 Explanation of Symbols in Table of Instructions

| Symbol            | Explanation                                                                                                           |
|-------------------|-----------------------------------------------------------------------------------------------------------------------|
| bp                | Bit offset value                                                                                                      |
| vct4<br>vct8      | Vector number (0 to 15)<br>Vector number (0 to 255)                                                                   |
| ( )b              | Bit address                                                                                                           |
| rel<br>ear<br>eam | Branch specification relative to PC<br>Effective addressing (codes 00 to 07)<br>Effective addressing (codes 08 to 1F) |
| rlst              | Register list                                                                                                         |

Table 4.2.2 Explanation of Symbols in Table of Instructions (Continued)

| Code                                         | Notation                                                                                                                                                                                                                                                                                              |  |                                              | Address format                                                                                                                                 | Number of<br>bytes for<br>address<br>extension * |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| 00<br>01<br>02<br>03<br>04<br>05<br>06<br>07 | R0         RW0         RL0           R1         RW1         (RL0)           R2         RW2         RL1           R3         RW3         (RL1)           R4         RW4         RL2           R5         RW5         (RL2)           R6         RW6         RL3           R7         RW7         (RL3) |  | (RL0)<br>RL1<br>(RL1)<br>RL2<br>(RL2)<br>RL3 | Register direct<br>The ea (effective address) corresponds<br>to the following types (from the left, in<br>order):<br>byte<br>word<br>long word | -                                                |
| 08<br>09<br>0A<br>0B                         | @RW0<br>@RW1<br>@RW2<br>@RW3                                                                                                                                                                                                                                                                          |  |                                              | Register indirect                                                                                                                              | 0                                                |
| 0C<br>0D<br>0E<br>0F                         | @RW0+<br>@RW1+<br>@RW2+<br>@RW3+                                                                                                                                                                                                                                                                      |  |                                              | Register indirect with post increment                                                                                                          | 0                                                |
| 10<br>11<br>12<br>13<br>14<br>15<br>16<br>17 | <ul> <li>@ RW0+disp8</li> <li>@ RW1+disp8</li> <li>@ RW2+disp8</li> <li>@ RW3+disp8</li> <li>@ RW4+disp8</li> <li>@ RW5+disp8</li> <li>@ RW6+disp8</li> <li>@ RW7+disp8</li> </ul>                                                                                                                    |  |                                              | Register indirect with 8-bit<br>displacement                                                                                                   | 1                                                |
| 18<br>19<br>1A<br>1B                         | @RW0+disp16<br>@RW1+disp16<br>@RW2+disp16<br>@RW3+disp16                                                                                                                                                                                                                                              |  |                                              | Register indirect with 16-bit<br>displacement                                                                                                  | 2                                                |
| 1C<br>1D<br>1E                               | @RW0+RW7<br>@RW1+RW7<br>@PC+disp16                                                                                                                                                                                                                                                                    |  |                                              | Register indirect with base index<br>Register indirect with base index<br>Program counter indirect with 16-bit<br>displacement                 | 0<br>0<br>2                                      |
| 1F                                           | addr16                                                                                                                                                                                                                                                                                                |  |                                              | Direct address                                                                                                                                 | 2                                                |

Table 4.2.3 Effective Address Fields

\*: The number of bytes in the address extension are added for instructions with "+" in the "#" (number of bytes) column in the instruction set tables.

|               |                  | (a)*                                                      | Number of accesses for<br>each form of<br>addressing |  |
|---------------|------------------|-----------------------------------------------------------|------------------------------------------------------|--|
| Code          | Operand          | Number of execution<br>cycles for each<br>addressing type |                                                      |  |
| 00<br> <br>07 | Ri<br>RWi<br>RLi | Listed in the instruction set table                       | Listed in the instruction set table                  |  |
| 08<br> <br>0B | @RWj             | 2                                                         | 1                                                    |  |
| 0C<br> <br>0F | @RWj+            | 4                                                         | 2                                                    |  |
| 10<br> <br>17 | @RWi+disp8       | 2                                                         | 1                                                    |  |
| 18<br> <br>1B | @RWj+disp16      | 2                                                         | 1                                                    |  |
| 1C            | @RW0+RW7         | 4                                                         | 2                                                    |  |
| 1D            | @RW1+RW7         | 4                                                         | 2                                                    |  |
| 1E            | @PC+disp16       | 2                                                         | 0                                                    |  |
| 1F            | addr16           | 1                                                         | 0                                                    |  |

## Table 4.2.4 Number of Execution Cycles for Each Form of Addressing

\*: (a) corresponds to (a) in the "~" (number of cycles) column "B" (correction value) colum and in the instructions.

|                                             | (b) byte  |           | (c)word   |           | (d)long   |           |
|---------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|
| Operand                                     | Number of |
|                                             | Cycles    | Accesses  | Cycles    | Accesses  | Cycles    | Accesses  |
| Internal register                           | +0        | 1         | +0        | 1         | +0        | 2         |
| Internal RAM even address                   | +0        | 1         | +0        | 1         | +0        | 2         |
| Internal RAM odd address                    | +0        | 1         | +2        | 2         | +4        | 4         |
| Even address on external data bus (16 bits) | +1        | 1         | +1        | 1         | +2        | 2         |
| Odd address on external data bus (16 bits)  | +1        | 1         | +4        | 2         | +8        | 4         |
| External data bus (8 bits)                  | +1        | 1         | +4        | 2         | +8        | 4         |

# Table 4.2.5 Compensation Values for Number of Cycles Used to Calculate Number of Actual Cycles

**Note1:** (b), (c), and (d)correspond to the "~" (number of cycles) column in the instructions.

#### Table 4.2.6 Compensation Values for Number of Cycles Used to Calculate Number of Program Fetch Cycles

| Instruction                 | Byte boundary | Word boundary |
|-----------------------------|---------------|---------------|
| Internal memory             | _             | +2            |
| External data bus (16 bits) | _             | +3            |
| External data bus (8 bits)  | +3            | _             |

- **Note1:** When the external data bus is used, it is necessary to add in the number of weighted cycles used for ready input and automatic ready.
- **Note2:** Because instruction execution is not slowed down by all program fetches in actuality, these compensation values should be used for "worst case" calculations.

# 4.2.1 F<sup>2</sup>MC-16L Instruction Set (340 Instructions)

## Table 4.2.7 ransfer Instructions (Byte) (41 Instructions)

| Table 0.0a | Move Instructions (Byte) 41 Instructions |
|------------|------------------------------------------|
|------------|------------------------------------------|

|                                                                    | Mnemonic                                                                                                                                                                                                                                                                                                                                                                                                        | #                                                                                   | ~                                                                                  | RG                                                                      | В                                                                  | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | LH                                                  | AH                | Ι                          | S    | Т                          | Ν                         | Ζ                         | V                          | С    | RMW |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------------|----------------------------|------|----------------------------|---------------------------|---------------------------|----------------------------|------|-----|
| MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV        | A, dir<br>A, addr16<br>A, Ri<br>A, ear<br>A, eam<br>A, io<br>A, #imm8<br>A, @A<br>A, @RLi+disp8<br>A, #imm4                                                                                                                                                                                                                                                                                                     | 2<br>3<br>1<br>2<br>2+<br>2<br>2<br>3<br>1                                          | 3<br>4<br>2<br>3+(a)<br>3<br>2<br>3<br>10<br>1                                     | 0<br>0<br>1<br>1<br>0<br>0<br>0<br>0<br>2<br>0                          | (b)<br>(b)<br>0<br>(b)<br>(b)<br>(b)<br>0<br>(b)<br>0              | $\begin{array}{l} \text{byte (A)} \leftarrow (\text{dir})\\ \text{byte (A)} \leftarrow (\text{addr16})\\ \text{byte (A)} \leftarrow (\text{Ri})\\ \text{byte (A)} \leftarrow (\text{ear})\\ \text{byte (A)} \leftarrow (\text{earn})\\ \text{byte (A)} \leftarrow (\text{io})\\ \text{byte (A)} \leftarrow (\text{io})\\ \text{byte (A)} \leftarrow ((A))\\ \text{byte (A)} \leftarrow ((AL)) + \text{disp8})\\ \text{byte (A)} \leftarrow \text{imm4} \end{array}$                                                                                                                                                                                                                                                    | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z      | * * * * * *   * * | -<br>-<br>-<br>-<br>-<br>- |      | -<br>-<br>-<br>-<br>-<br>- | * * * * * * * <b>R</b>    | * * * * * * * *           | -<br>-<br>-<br>-<br>-<br>- |      |     |
| MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX       | A, dir<br>A, addr16<br>A, Ri<br>A, ear<br>A, eam<br>A, io<br>A, #imm8<br>A, @A<br>A, @RWi+disp8<br>A, @RLi+disp8                                                                                                                                                                                                                                                                                                | 2<br>3<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3                                 | 3<br>4<br>2<br>3+(a)<br>3<br>2<br>3<br>5<br>10                                     | 0<br>1<br>1<br>0<br>0<br>0<br>1<br>2                                    | (b)<br>(b)<br>0<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)                 | $\begin{array}{l} \text{byte (A)} \leftarrow (\text{dir}) \\ \text{byte (A)} \leftarrow (\text{addr16}) \\ \text{byte (A)} \leftarrow (\text{Ri}) \\ \text{byte (A)} \leftarrow (\text{ear}) \\ \text{byte (A)} \leftarrow (\text{earm}) \\ \text{byte (A)} \leftarrow (\text{ion}) \\ \text{byte (A)} \leftarrow (\text{imm8}) \\ \text{byte (A)} \leftarrow ((\text{RWi}) + \text{disp8}) \\ \text{byte (A)} \leftarrow ((\text{RLi}) + \text{disp8}) \end{array}$                                                                                                                                                                                                                                                   | X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | * * * * * *   * * |                            |      |                            | * * * * * * * * *         | * * * * * * * * *         |                            |      |     |
| MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV | dir, A<br>addr16, A<br>Ri, A<br>ear, A<br>ear, A<br>am, A<br>io, A<br>@RLi+disp8, A<br>Ri, ear<br>Ri, ear<br>Ri, ear<br>ear, Ri<br>ear, Ri<br>ear, Ri<br>Ri, #imm8<br>io, #imm8<br>dir, #imm8<br>ear, #imm8 | 2<br>3<br>1<br>2<br>2+<br>2<br>3<br>2<br>2+<br>2<br>3<br>3<br>3<br>3<br>3<br>+<br>2 | 3<br>4<br>2<br>3+(a)<br>3<br>4+(a)<br>4<br>5+(a)<br>2<br>5<br>5<br>2<br>4+(a)<br>3 | 0<br>1<br>1<br>0<br>2<br>2<br>1<br>2<br>1<br>1<br>0<br>0<br>1<br>0<br>0 | (b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b) | byte (dir) $\leftarrow$ (A)<br>byte (addr16) $\leftarrow$ (A)<br>byte (Ri) $\leftarrow$ (A)<br>byte (ear) $\leftarrow$ (A)<br>byte (ear) $\leftarrow$ (A)<br>byte (ear) $\leftarrow$ (A)<br>byte (Ri) $\leftarrow$ (ear)<br>byte (Ri) $\leftarrow$ (ear)<br>byte (Ri) $\leftarrow$ (ear)<br>byte (ear) $\leftarrow$ (Ri)<br>byte (ear) $\leftarrow$ (Ri)<br>byte (Ri) $\leftarrow$ imm8<br>byte (io) $\leftarrow$ imm8<br>byte (dir) $\leftarrow$ imm8<br>byte (ear) $\leftarrow$ imm8<br>byte ((A)) $\leftarrow$ (AH) |                                                     |                   |                            |      |                            | * * * * * * * * * * * - * | * * * * * * * * * * * - * |                            |      |     |
| XCH<br>XCH<br>XCH<br>XCH                                           | A, ear<br>A, eam<br>Ri, ear<br>Ri. eam                                                                                                                                                                                                                                                                                                                                                                          | 2<br>2+<br>2<br>2+                                                                  | 4<br>7+(a)<br>4<br>9+(a)                                                           | 2<br>0<br>4<br>2                                                        | 0<br>2×(b)<br>0<br>2×(b)                                           | byte (A) $\leftrightarrow$ (ear)<br>byte (A) $\leftrightarrow$ (eam)<br>byte (Ri) $\leftrightarrow$ (ear)<br>byte (Ri) $\leftrightarrow$ (eam)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Z<br>Z<br>-                                         |                   |                            | 1111 |                            |                           |                           |                            | 1111 |     |

## Table 4.2.8 Transfer Instructions (Word/Long-Word) (38 Instructions)

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |               |    |       |    |       |                                      |    |    |   |   |   |   | -        |   |   |     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|----|-------|----|-------|--------------------------------------|----|----|---|---|---|---|----------|---|---|-----|
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      | Mnemonic      | #  | ~     | RG | В     | Operation                            | LH | AH | Ι | S | Т | Ν | Z        | V | С | RMW |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MOVW | A. dir        | 2  | 3     | 0  | (c)   | word (A) $\leftarrow$ (dir)          | -  | *  | - | - | - | * | *        | 1 | - | -   |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MOVW |               | 3  | 4     | 0  |       |                                      | _  | *  | - | - | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |               |    |       | -  |       |                                      | _  | *  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |               | 1  |       | -  | -     |                                      | _  | *  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |               |    |       | -  |       |                                      |    | *  |   |   | _ |   | *        |   |   | _   |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |               |    |       | -  |       |                                      | _  |    | _ |   | _ |   |          | _ | _ | _   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |               |    |       | -  |       |                                      | _  |    |   |   |   |   |          |   |   | _   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |               |    |       | -  |       |                                      | _  |    | _ |   | _ | * |          | _ |   | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    |       |                                      |    |    |   |   |   |   |          | _ |   | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       | -  |       |                                      |    |    |   |   |   |   |          |   |   |     |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    |       |                                      |    |    |   |   |   |   |          |   |   |     |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | A, WRLI+UIPSO | 3  | 10    | 2  | (0)   | word (A) $\leftarrow$ ((RLI)+disp8)  | -  | *  | - | - | - | * | *        | _ | _ | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       | 0  |       |                                      | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      | addr16, A     | 3  | 4     | 0  | (c)   | word (addr16) $\leftarrow$ (A)       | -  | -  | - |   | - | * | *        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW | SP, A         | 1  | 1     | 0  | 0     | word (SP) $\leftarrow$ (A)           | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW | RWi, A        | 1  | 2     | 1  | 0     | word (RWi) $\leftarrow$ (A)          | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVW | ear, A        | 2  | 2     | 1  | 0     | word (ear) $\leftarrow$ (A)          | -  | -  | - |   | - | * | *        | - | - | -   |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVW | eam, A        | 2+ | 3+(a) | 0  | (c)   | word (eam) $\leftarrow$ (A)          | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW | io, A         | 2  | 3     | 0  | (c)   | word (io) $\leftarrow$ (A)           | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVW | @RWi+disp8, A | 2  | 5     | 1  | (c)   | word $((RWi)+disp8)) \leftarrow (A)$ | -  | -  | - | - | - | * | *        | - | - | _   |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVW | @RLi+disp8, A | 3  | 10    | 2  | (c)   |                                      | -  | -  | - | - | - | * | *        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW | RWi, ear      | 2  | 3     | 2  | Ó     | word (RWi) ← (ear)                   | -  | -  | - | - | - | * | *        | _ | - | -   |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVW | RWi, eam      | 2+ | 4+(a) | 1  | (c)   | word (RWi ← (eam)                    | -  | -  | - | - | - | * | *        | _ | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW | ear. RWi      | 2  |       | 2  |       |                                      | _  | _  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MOVW |               |    | 5+(a) | 1  | (c)   |                                      | _  | -  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    |       |                                      | _  | -  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       | 0  |       |                                      | _  | -  | _ | _ | _ | _ | _        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    | -     | -  |       |                                      | _  | _  | _ | _ | _ | * | *        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       | -  |       |                                      | _  | _  | _ |   | _ | _ | _        | _ | _ | _   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    |       |                                      | _  | _  | _ |   | _ |   | *        | _ | _ | _   |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |               | -  | Ū     | Ŭ  | (0)   |                                      |    |    |   |   |   |   |          |   |   |     |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |               |    |       |    |       |                                      |    |    |   |   | - |   |          |   |   | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    | -     |                                      | -  |    | - |   | - |   | -        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       | -  |       |                                      | -  |    | - |   | - |   |          | - |   | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |               |    |       |    | -     |                                      | -  | -  | - | - | - | - | -        | - | - | -   |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | XCHW | RWi, eam      | 2+ | 9+(a) | 2  | 2×(c) | word (RWi) $\leftrightarrow$ (eam)   | -  | -  | - | - |   | - | -        | - | - |     |
| MOVL       A, #imm32       5       3       0       0       long (A) $\leftarrow$ imm32       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       < | MOVL | A, ear        | 2  | 4     | 2  | 0     | long (A) $\leftarrow$ (ear)          | -  | -  | - | - | - | * | *        | - | - | -   |
| MOVL     ear, A     2     3     2     0     long (ear) $\leftarrow$ (A)     -     -     -     -     +     *     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MOVL | A, eam        | 2+ | 5+(a) | 0  | (d)   | long (A) $\leftarrow$ (eam)          | -  | -  | - | - | - | * | *        | - | - | -   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MOVL | A, #imm32     | 5  | 3     | 0  |       | $long(A) \leftarrow imm32$           | -  | -  | - | - | - | * | *        | - | - | -   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MOVI | oor A         | 2  | 2     | 2  | 0     | long (oar) ( (A)                     |    |    |   |   |   | * | *        |   |   |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |               |    |       |    |       |                                      |    |    |   |   |   |   |          |   |   |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | NOVL | caill, A      | 2+ | 0+(a) | U  | (u)   | iony (ean) $\leftarrow$ (A)          | _  |    | - | _ | _ | * | <b>^</b> | - | - | _   |

| Mr                                                                                                                   | nemonic                                                                                                                                                                                                | #                                                                                                                  | ~                                                                                                                                       | RG                                                                                                    | В                                                                                                                                                                                                                                                                                                                                                                                                                                                | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LH                                                                                          | AH | Ι | S                | Т                | Ν                                   | Z                                 | V                                  | С                                 | RMV                   |
|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----|---|------------------|------------------|-------------------------------------|-----------------------------------|------------------------------------|-----------------------------------|-----------------------|
| ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADDC<br>ADDC<br>ADDC                                                       | A, #imm8<br>A ,dir<br>A ,ear<br>A, eam<br>ear, A<br>eam, A<br>A<br>A ,ear<br>A, ear<br>A, ear<br>A, ear<br>A, ean<br>ear, A<br>eam, A<br>A<br>A, ear<br>A, ear<br>A, ear<br>A, ear<br>A, ear<br>A, ear | 2<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1 | $\begin{array}{c} 2\\ 5\\ 3\\ 4+(a)\\ 2\\ 3\\ 4+(a)\\ 3\\ 2\\ 5\\ 3\\ 4+(a)\\ 3\\ 5+(a)\\ 2\\ 3\\ 5+(a)\\ 2\\ 3\\ 4+(a)\\ 3\end{array}$ | 0<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0      | 0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>2×(b)<br>0<br>2×(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>0<br>(b)<br>0<br>0<br>0<br>(b)<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>2×(b)<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | $\begin{array}{l} byte (A) \leftarrow (A) + imm8\\ byte (A) \leftarrow (A) + (dir)\\ byte (A) \leftarrow (A) + (ear)\\ byte (A) \leftarrow (A) + (ear)\\ byte (a) \leftarrow (ear) + (A)\\ byte (ear) \leftarrow (ear) + (A)\\ byte (ear) \leftarrow (ear) + (A)\\ byte (A) \leftarrow (AH) + (AL) + (c)\\ byte (A) \leftarrow (A) + (ear) + (c)\\ byte (A) \leftarrow (A) + (ear) + (c)\\ byte (A) \leftarrow (A) + (ar) + (c)\\ (decimal)\\ byte (A) \leftarrow (A) - (ear)\\ byte (a) \leftarrow (A) - (ear) - (A)\\ byte (a) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (ear) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (A) - (aar) - (c)\\ byte (A) \leftarrow (A) - (aar) - (aar) - (aar) - (aar)\\ byte (A) \leftarrow (A) - (aar) - (aar) - (aar) - (aar) - (aar)\\ byte (A) \leftarrow (A) - (aar) - ($ | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z |    |   |                  |                  | * * * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * | ** * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * |                       |
| ADDW<br>ADDW<br>ADDW<br>ADDW<br>ADDW<br>ADDW<br>ADDCW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUB | A<br>A, ear<br>A, eam<br>A, #imm16<br>ear, A<br>eam, A<br>A, ear<br>A, eam<br>A, eam<br>A, eam<br>A, eam<br>A, #imm16<br>ear, A<br>eam, A<br>A, ear<br>A, ear<br>A, eam                                | 1<br>2+<br>3<br>2<br>2+<br>2<br>2+<br>2<br>2+<br>3<br>2<br>2+<br>3<br>2<br>2+<br>2<br>2+                           | $\begin{array}{c} 2\\ 3\\ 4+(a)\\ 2\\ 3\\ 5+(a)\\ 3\\ 4+(a)\\ 2\\ 2\\ 4+(a)\\ 2\\ 3\\ 5+(a)\\ 3\\ 4+(a)\end{array}$                     | 0<br>1<br>0<br>2<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>2<br>0<br>1<br>0<br>0<br>1<br>0 | $ \begin{array}{c} 0 \\ 0 \\ (c) \\ 0 \\ 0 \\ 2 \times (c) \\ 0 \\ (c) \\ 0 \\ (c) \\ 0 \\ (c) \\ 0 \\ 2 \times (c) \\ 0 \\ (c) \\ (c) \\ 0 \\ (c) \\ \end{array} $                                                                                                                                                                                                                                                                              | $\begin{array}{l} \text{word } (A) \leftarrow (AH) + (AL) \\ \text{word } (A) \leftarrow (A) + (ear) \\ \text{word } (A) \leftarrow (A) + (ear) \\ \text{word } (A) \leftarrow (A) + imm16 \\ \text{word } (ear) \leftarrow (ear) + (A) \\ \text{word } (eam) \leftarrow (ear) + (A) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) + (ear) + (c) \\ \text{word } (A) \leftarrow (A) - (ear) \\ \text{word } (A) \leftarrow (A) - (ear) \\ \text{word } (A) \leftarrow (A) - (ear) \\ \text{word } (ear) \leftarrow (ear) - (A) \\ \text{word } (a) \leftarrow (A) - (ear) - (c) \\ \text{word } (A) \leftarrow (A) - (eam) - (c) \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                             |    |   |                  |                  | * * * * * * * * * * * * *           | * * * * * * * * * * * * *         | * * * * * * * * * * * * *          | * * * * * * * * * * * *           |                       |
| ADDL<br>ADDL<br>ADDL<br>SUBL<br>SUBL<br>SUBL                                                                         | A, ear<br>A, eam<br>A, #imm32<br>A, ear<br>A, eam<br>A, #imm32                                                                                                                                         | 2<br>2+<br>5<br>2<br>2+<br>5                                                                                       | 6<br>7+(a)<br>4<br>6<br>7+(a)<br>4                                                                                                      | 2<br>0<br>2<br>0<br>0                                                                                 | 0<br>(d)<br>0<br>(d)<br>0                                                                                                                                                                                                                                                                                                                                                                                                                        | $\begin{array}{l} \text{long (A)} \leftarrow (A) + (\text{ear}) \\ \text{long (A)} \leftarrow (A) + (\text{eam}) \\ \text{long (A)} \leftarrow (A) + \text{imm32} \\ \text{long (A)} \leftarrow (A) - (\text{ear}) \\ \text{long (A)} \leftarrow (A) - (\text{eam}) \\ \text{long (A)} \leftarrow (A) - \text{imm32} \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -<br>-<br>-<br>-                                                                            |    |   | -<br>-<br>-<br>- | -<br>-<br>-<br>- | * * * * *                           | * * * * * *                       | * * * * *                          | * * * * * *                       | -<br>-<br>-<br>-<br>- |

# Table 4.2.9 Addition and Subtraction Instructions (Byte/Word/Long-Word) (42 Instructions)Table 0.0b Addition and Subtraction Instructions (Byte, Word, Long Word) 42 Instructions

|              | Mnemonic   | #       | ~          | RG     | В          | Operation                                                                                                                     | LH     | AH     | Ι | S | Т | Ν   | Z   | V | С | RMW    |
|--------------|------------|---------|------------|--------|------------|-------------------------------------------------------------------------------------------------------------------------------|--------|--------|---|---|---|-----|-----|---|---|--------|
| INC<br>INC   | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(b) | byte (ear) $\leftarrow$ (ear) + 1<br>byte (ear) $\leftarrow$ (eam) + 1                                                        | -      |        |   | - | - | *   | *   | * | - | <br>*  |
| DEC<br>DEC   | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(b) | byte (ear) $\leftarrow$ (ear) - 1<br>byte (ear) $\leftarrow$ (eam) - 1                                                        | -<br>- |        | - | - | - | *   | *   | * | - | -<br>* |
| INCW<br>INCW | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(c) | word (ear) $\leftarrow$ (ear) + 1<br>word (ear) $\leftarrow$ (eam) + 1                                                        |        | -      | - | - | - | * * | * * | * | - | - *    |
| DECW<br>DECW | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(c) | word(ear) $\leftarrow$ (ear) - 1<br>word(ear) $\leftarrow$ (eam) -1                                                           | -      | _<br>_ | - | - | - | *   | *   | * | - | -<br>* |
| INCL<br>INCL | ear<br>eam | 2<br>2+ | 7<br>9+(a) | 4<br>0 | 0<br>2×(d) | $\begin{array}{l} \text{long (ear)} \leftarrow (\text{ear}) + 1 \\ \text{long (ear)} \leftarrow (\text{eam}) + 1 \end{array}$ | -      | -      | - | - | - | * * | * * | * | - | <br>*  |
| DECL<br>DECL | ear<br>eam | 2<br>2+ | 7<br>9+(a) | 4<br>0 | 0<br>2×(d) | long (ear) ← (ear) - 1<br>long (ear) ← (eam) - 1                                                                              | -      |        | - | - |   | *   | *   | * |   | -<br>* |

# Table 4.2.10 Increment and Decrement Instructions (Byte/Word/Long-Word) (12Instructions)

## Table 4.2.11 Compare Instructions (Byte/Word/Long-Word) (11 Instructions)

|                              | Mnemonic                          | #                 | ~                    | RG               | В                  | Operation                                                                    | LH               | AH          | Ι           | S           | Т           | Ν       | Ζ       | V       | С       | RMW         |
|------------------------------|-----------------------------------|-------------------|----------------------|------------------|--------------------|------------------------------------------------------------------------------|------------------|-------------|-------------|-------------|-------------|---------|---------|---------|---------|-------------|
| CMP<br>CMP<br>CMP<br>CMP     | A<br>A ,ear<br>A ,eam<br>A, #imm8 | 1<br>2<br>2+<br>2 | 1<br>2<br>3+(a)<br>2 | 0<br>1<br>0<br>0 | 0<br>0<br>(b)<br>0 | byte (AH) - (AL)<br>byte (A) - (ear)<br>byte (A) - (eam)<br>byte (A) - imm8  | _<br>_<br>_<br>_ | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | * * *   | * * * * | * * *   | * * * * | -<br>-<br>- |
| CMPW<br>CMPW<br>CMPW<br>CMPW | A<br>A, ear<br>A, eam<br>A, #im16 | 1<br>2<br>2+<br>3 | 1<br>2<br>3+(a)<br>2 | 0<br>1<br>0<br>0 | 0<br>0<br>(c)<br>0 | word (AH) - (AL)<br>word (A) - (ear)<br>word (A) - (eam)<br>word (A) - imm16 | -<br>-<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- |             | * * * * | * * * * | * * * * | * * * * | -<br>-<br>- |
| CMPL<br>CMPL<br>CMPL         | A, ear<br>A, eam<br>A, #imm32     | 2<br>2+<br>5      | 6<br>7+(a)<br>3      | 2<br>0<br>0      | 0<br>(d)<br>0      | long (A) - (ear)<br>long (A) - (eam)<br>long (A) - imm32                     |                  | _<br>_<br>_ |             | -<br>-<br>- |             | * * *   | * * *   | * * *   | * * *   | -<br>-<br>- |

| Mnem  | nonic  | #  | ~   | RG | В   | Operation                                                                                                                                                          | LH | AH | Ι | S | Т | Ν | Ζ | V | С | RMW |
|-------|--------|----|-----|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| DIVU  | А      | 1  | *1  | 0  | 0   | word (AH) ÷ byte (AL)                                                                                                                                              | -  | -  | Ι | - | - | - | - | * | * | -   |
| DIVU  | A ,ear | 2  | *2  | 1  | 0   | byte (AL) $\leftarrow$ quotient byte (AH) $\leftarrow$ remainder<br>word (A) $\div$ byte (ear)<br>byte (A) $\leftarrow$ quotient byte (ear) $\leftarrow$ remainder | -  | -  | - | - | - | - | - | * | * | -   |
| DIVU  | A ,eam | 2+ | *3  | 0  | *6  | word (A) $\leftarrow$ quotient byte (ear) $\leftarrow$ remainder<br>byte (A) $\leftarrow$ quotient byte (ear) $\leftarrow$ remainder                               | -  | -  | - | - | - | - | - | * | * | -   |
| DIVUW | A, ear | 2  | *4  | 1  | 0   | long ÷ word (ear)                                                                                                                                                  | -  | -  | - | - | - | - | - | * | * | -   |
| DIVUW | A, eam | 2+ | *5  | 0  | *7  | word (A) $\leftarrow$ quotient word (ear) $\leftarrow$ remainder<br>long $\div$ word (eam)<br>word (A) $\leftarrow$ quotient word (eam) $\leftarrow$ remainder     | -  | -  | - | - | - | - | - | * | * | -   |
|       |        |    |     |    |     |                                                                                                                                                                    | -  | -  | - | - | - | - | - | - | - | -   |
| MUL   | A      | 1  | *8  | 0  | 0   | word (A) $\leftarrow$ byte (AH) x byte (AL)                                                                                                                        | -  | -  | - | - | - | - | - | - | - | -   |
| MUL   | A, ear | 2  | *9  | 1  | 0   | word (A) $\leftarrow$ byte (A) x byte (ear)                                                                                                                        | -  | -  | - | - | - | - | - | - | - | -   |
| MUL   | A, eam | 2+ | *10 | 0  | (b) | word (A) $\leftarrow$ byte (A) x byte (eam)                                                                                                                        |    |    |   |   |   |   |   |   |   |     |
| MULUW | A      | 1  | *11 | 0  | 0   | long (A) $\leftarrow$ word (AH) x word (AL)                                                                                                                        | -  | -  | - | - | - | - | - | - | - | -   |
| MULUW | A, ear | 2  | *12 | 1  | 0   | long (A) $\leftarrow$ word (A) x word (ear)                                                                                                                        | -  | -  | - | - | - | - | - | - | - | -   |
| MULUW | A, eam | 2+ | *13 | 0  | (c) | long $(A) \leftarrow$ word $(A) \times$ word $(earm)$                                                                                                              | -  | -  | - | - | - | - | - | - | - | -   |

#### Table 4.2.12 Unsigned Multiplication and Division Instructions (Word/Long-Word) (11 Instructions)

\*1: 3 when dividing into zero, 7 when an overflow occurs, and 15 normally.

\*2: 4 when dividing into zero, 8 when an overflow occurs, and 16 normally.

\*3: 6 + (a) when dividing into zero, 9 + (a) when an overflow occurs, and 19 + (a) normally.

\*4: 4 when dividing into zero, 7 when an overflow occurs, and 22 normally.

\*5: 6 + (a) when dividing into zero, 8 + (a) when an overflow occurs, and 26 + (a) normally.

\*6: (b) when dividing into zero or when an overflow occurs, and 2 x (b) normally.

\*7: (c) when dividing into zero or when an overflow occurs, and 2 x (c) normally.

\*8: 3 when byte (AH) is zero, and 7 when byte (AH) is not 0.

\*9: 4 when byte (ear) is zero, and 8 when byte (ear) is not 0.

\*10: 5 + (a) when byte (eam) is zero, and 9 + (a) when byte (eam) is not 0.

\*11: 3 when word (AH) is zero, and 11 when word (AH) is not 0.

\*12: 4 when word (ear) is zero, and 12 when word (ear) is not 0.

\*13: 5 + (a) when word (eam) is zero, and 13 + (a) when word (eam) is not 0.

| N                                                    | Inemonic                                                            | #                                  | ~                                                | RG                                   | В                                         | Operation                                                                                                                                                                                                                                                                                                     | LH               | AH                    | Ι | S                | Т                | Ν           | Ζ             | V                                         | С                | RMW            |
|------------------------------------------------------|---------------------------------------------------------------------|------------------------------------|--------------------------------------------------|--------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------|---|------------------|------------------|-------------|---------------|-------------------------------------------|------------------|----------------|
| AND<br>AND<br>AND<br>AND<br>AND                      | A, #imm8<br>A ,ear<br>A ,eam<br>ear, A<br>eam, A                    | 2<br>2<br>2+<br>2<br>2+            | 2<br>3<br>4+(a)<br>3<br>5+(a)                    | 0<br>1<br>0<br>2<br>0                | 0<br>(b)<br>0<br>2×(b)                    | byte (A) $\leftarrow$ (A) and imm8<br>byte (A) $\leftarrow$ (A) and (ear)<br>byte (A) $\leftarrow$ (A) and (ear)<br>byte (ear) $\leftarrow$ (A) and (earm)<br>byte (ear) $\leftarrow$ (ear) and (A)<br>byte (earm) $\leftarrow$ (earm) and (A)                                                                | -<br>-<br>-<br>- | -<br>-<br>-<br>-      |   | -<br>-<br>-<br>- | -<br>-<br>-<br>- | * * * *     | * * * *       | R<br>R<br>R<br>R<br>R                     | -<br>-<br>-<br>- | *              |
| OR<br>OR<br>OR<br>OR<br>OR                           | A, #imm8<br>A, ear<br>A, eam<br>ear, A<br>eam, A                    | 2<br>2<br>2+<br>2<br>2+            | 2<br>3<br>4+(a)<br>3<br>5+(a)                    | 0<br>1<br>0<br>2<br>0                | 0<br>(b)<br>0<br>2×(b)                    | byte (A) $\leftarrow$ (A) or imm8<br>byte (A) $\leftarrow$ (A) or (ear)<br>byte (A) $\leftarrow$ (A) or (eam)<br>byte (ear) $\leftarrow$ (ear) or (A)<br>byte (eam) $\leftarrow$ (eam) or (A)                                                                                                                 | -<br>-<br>-<br>- | _<br>_<br>_<br>_      |   | -<br>-<br>-<br>- | -<br>-<br>-<br>- | * * * *     | * * * *       | R<br>R<br>R<br>R<br>R                     | -<br>-<br>-<br>- | -<br>-<br>*    |
| XOR<br>XOR<br>XOR<br>XOR<br>XOR<br>NOT<br>NOT<br>NOT | A, #imm8<br>A, ear<br>A, eam<br>ear, A<br>eam, A<br>A<br>ear<br>eam | 2<br>2+<br>2<br>2+<br>1<br>2<br>2+ | 2<br>3<br>4+(a)<br>3<br>5+(a)<br>2<br>3<br>5+(a) | 0<br>1<br>0<br>2<br>0<br>0<br>2<br>0 | 0<br>(b)<br>0<br>2×(b)<br>0<br>0<br>2×(b) | byte (A) $\leftarrow$ (A) xor imm8<br>byte (A) $\leftarrow$ (A) xor (ear)<br>byte (A) $\leftarrow$ (A) xor (ear)<br>byte (ear) $\leftarrow$ (ear) xor (A)<br>byte (ear) $\leftarrow$ (ear) xor (A)<br>byte (A) $\leftarrow$ not (A)<br>byte (ear) $\leftarrow$ not (ear)<br>byte (ear) $\leftarrow$ not (ear) |                  | -<br>-<br>-<br>-<br>- |   |                  |                  | * * * * * * | * * * * * * * | R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R | -<br>-<br>-<br>- | <br>  *  <br>* |
| ANDW<br>ANDW<br>ANDW<br>ANDW<br>ANDW<br>ANDW         | A<br>A, #imm16<br>A, ear<br>A, eam<br>ear, A<br>eam, A              | 1<br>3<br>2<br>2+<br>2<br>2+       | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)               | 0<br>0<br>1<br>0<br>2<br>0           | 0<br>0<br>(c)<br>0<br>2×(c)               | word (A) $\leftarrow$ (AH) and (A)<br>word (A) $\leftarrow$ (A) and imm16<br>word (A) $\leftarrow$ (A) and (ear)<br>word (A) $\leftarrow$ (A) and (eam)<br>word (ear) $\leftarrow$ (ear) and (A)<br>word (eam) $\leftarrow$ (eam) and (A)                                                                     |                  |                       |   |                  |                  | * * * * * * | * * * * * *   | R R R R R R                               |                  | * *            |
| ORW<br>ORW<br>ORW<br>ORW<br>ORW<br>ORW               | A<br>A, #imm16<br>A, ear<br>A, eam<br>ear, A<br>eam, A              | 1<br>3<br>2<br>2+<br>2<br>2+       | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)               | 0<br>0<br>1<br>0<br>2<br>0           | 0<br>0<br>(c)<br>0<br>2×(c)               | word (A) $\leftarrow$ (AH) or (A)<br>word (A) $\leftarrow$ (A) or imm16<br>word (A) $\leftarrow$ (A) or (ear)<br>word (A) $\leftarrow$ (A) or (ear)<br>word (ear) $\leftarrow$ (ear) or (A)<br>word (ear) $\leftarrow$ (ear) or (A)                                                                           | -<br>-<br>-<br>- | -<br>-<br>-<br>-      |   | -<br>-<br>-<br>- | -<br>-<br>-<br>- | * * * * *   | * * * * *     | R<br>R<br>R<br>R<br>R<br>R                | -<br>-<br>-<br>- | <br>*          |
| XORW<br>XORW<br>XORW<br>XORW<br>XORW<br>XORW         | A<br>A , #imm16<br>A, ear<br>A, eam<br>ear, A<br>eam, A             | 1<br>3<br>2<br>2+<br>2<br>2+       | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)               | 0<br>0<br>1<br>0<br>2<br>0           | 0<br>0<br>(c)<br>0<br>2×(c)               | word (A) $\leftarrow$ (AH) xor (A)<br>word (A) $\leftarrow$ (A) xor imm16<br>word (A) $\leftarrow$ (A) xor (ear)<br>word (A) $\leftarrow$ (A) xor (ear)<br>word (ear) $\leftarrow$ (ear) xor (A)<br>word (ear) $\leftarrow$ (ear) xor (A)                                                                     | -<br>-<br>-<br>- | -<br>-<br>-<br>-      |   | -<br>-<br>-<br>- | -<br>-<br>-<br>- | * * * * *   | * * * * *     | R<br>R<br>R<br>R<br>R<br>R                | -<br>-<br>-<br>- | * *            |
| NOTW<br>NOTW<br>NOTW                                 | A<br>ear<br>eam                                                     | 1<br>2<br>2+                       | 2<br>2<br>5+(a)                                  | 0<br>2<br>0                          | 0<br>0<br>2×(c)                           | word (A) $\leftarrow$ not (A)<br>word (ear) $\leftarrow$ not (ear)<br>word (eam) $\leftarrow$ not (eam)                                                                                                                                                                                                       | -<br>-<br>-      | -<br>-<br>-           |   | -<br>-<br>-      | -<br>-<br>-      | *<br>*<br>* | *<br>*<br>*   | R<br>R<br>R                               | -<br>-<br>-      | *              |

Table 4.2.13 Logical 1 Instructions (Byte/Word) (39 Instructions)

| Table 4.2.14 Logical 2 Instructions (Long-Word) (6 Instruction | ns) |
|----------------------------------------------------------------|-----|
|----------------------------------------------------------------|-----|

| М            | Inemonic         | #       | ~          | RG     | В        | Operation                                                                  | LH | AH | Ι | S | Т | Ν   | Ζ   | V      | С | RMW    |
|--------------|------------------|---------|------------|--------|----------|----------------------------------------------------------------------------|----|----|---|---|---|-----|-----|--------|---|--------|
| ANDL<br>ANDL | A ,ear<br>A ,eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) $\leftarrow$ (A) and (ear)<br>long (A) $\leftarrow$ (A) and (eam) | -  |    |   |   |   | * * | * * | R<br>R |   | -      |
| ORL<br>ORL   | A, ear<br>A, eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) $\leftarrow$ (A) or (ear)<br>long (A) $\leftarrow$ (A) or (eam)   | -  | -  | - | - | - | *   | *   | R<br>R | - | -<br>- |
| XORL<br>XORL | A, ear<br>A, eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) $\leftarrow$ (A) xor (ear)<br>long (A) $\leftarrow$ (A) xor (eam) | -  | -  |   | - |   | *   | *   | R<br>R | - | -      |

## Table 4.2.15 Sign Inversion Instructions (Byte/Word) (6 Instructions)

| Mn           | nemonic    | #       | ~          | RG     | В          | Operation                                                              | LH | AH | Ι | S | Т | Ν | Ζ | V | С | RMW |
|--------------|------------|---------|------------|--------|------------|------------------------------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| NEG          | А          | 1       | 2          | 0      | 0          | byte (A) $\leftarrow$ 0 - (A)                                          | Х  | -  | - | I | - | * | * | * | * | -   |
| NEG<br>NEG   | ear<br>eam | 2<br>2+ | 2<br>5+(a) | 2<br>0 | 0<br>2×(b) | byte (ear) $\leftarrow$ 0 - (ear)<br>byte eam) $\leftarrow$ 0 - (eam)  | -  | -  | - | - | - | * | * | * | * | *   |
| NEGW         | А          | 1       | 2          | 0      | 0          | word (A) $\leftarrow$ 0 - (A)                                          | -  | -  | - | - | - | * | * | * | * | -   |
| NEGW<br>NEGW | ear<br>eam | 2<br>2+ | 2<br>5+(a) | 2<br>0 | 0<br>2×(c) | word (ear) $\leftarrow$ 0 - (ear)<br>word (eam) $\leftarrow$ 0 - (eam) | -  | -  | - | - | - | * | * | * | * | *   |

## Table 4.2.16 Normalize Instruction (Long-Word) (1 Instruction)

| Mnemonic   | # | ~  | RG | В | Operation                                                                      | LH | AH | Ι | S | Т | Ν | Ζ | V | С | RMW |
|------------|---|----|----|---|--------------------------------------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| NRML A, RO | 2 | *1 |    | 0 | long (A) ←Shift until first digit<br>is "1"<br>byte (R0) ← Current shift count | -  | -  | - | - | - | - | * | 1 | - | -   |

\*1: 4 when the contents of the accumulator are all zeroes, 6 + (R0) in all other cases.

| M                    | nemonic                 | #           | ~              | RG          | В           | Operation                                                                                                                                                                                                                                                                           | LH | AH | Ι | S | Т   | Ν     | Z     | V | С     | RMW |
|----------------------|-------------------------|-------------|----------------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|-----|-------|-------|---|-------|-----|
| RORC                 | А                       | 2           | 2              | 0           | 0           | byte (A) ← Right rotation with<br>carry                                                                                                                                                                                                                                             | -  | -  | - | - | -   | *     | *     | - | *     | -   |
| RORC                 | A                       | 2           | 2              | 0           | 0           | byte (A) $\leftarrow$ Left rotation with carry                                                                                                                                                                                                                                      | -  | -  | - | - | -   | *     | *     | - | *     | -   |
| RORC                 | ear                     | 2           | 3              | 2           | 0           | byte (ear) ←Right rotation with<br>carry                                                                                                                                                                                                                                            | -  | -  | - | - | -   | *     | *     | - | -     | -   |
| RORC                 | eam                     | 2+          | 5+(a)          | 0           | 2×(b)       | byte (eam) ← Right rotation<br>with carry                                                                                                                                                                                                                                           | -  | -  | - | - | -   | *     | *     | - | *     | *   |
| ROLC                 | ear                     | 2           | 3              | 2           | 0           | byte (ear) $\leftarrow$ Left rotation with carry                                                                                                                                                                                                                                    | -  | -  | - | - | -   | *     | *     | - | -     | -   |
| ROLC                 | eam                     | 2+          | 5+(a)          | 0           | 2×(b)       | byte (eam) ←Left rotation with carry                                                                                                                                                                                                                                                | -  | -  | - | - | -   | *     | *     | - | *     | *   |
| ASR                  | A, R0                   | 2           | *1             | 1           | 0           | byte (A) ← Arithmetic right<br>barrel shift (A, R0)                                                                                                                                                                                                                                 | -  | -  | - | - | *   | *     | *     | - | *     | -   |
| LSR                  | A, R0                   | 2           | *1             | 1           | 0           | byte (A) $\leftarrow$ Logical right barrel shift (A, R0)                                                                                                                                                                                                                            | -  | -  | - | - | *   | *     | *     | - | *     | -   |
| LSL                  | A, R0                   | 2           | *1             | 1           | 0           | byte (A) $\leftarrow$ Logical left barrel shift (A, R0)                                                                                                                                                                                                                             | -  | -  | - | - | -   | *     | *     | - | *     | -   |
| ASRW                 | A                       | 1           | 2              | 0           | 0           | word (A) ← Arithmetic right<br>shift (A, 1-bit)                                                                                                                                                                                                                                     | -  | -  | - | - | *   | R     | *     | - | *     | -0  |
| LSRW                 | A / SHRW                | 1           | 2              | 0           | 0           | word (A) $\leftarrow$ Logical right shift (A, 1-bit)                                                                                                                                                                                                                                | -  | -  | - | - | -   | *     | *     | - | *     | -   |
| LSLW                 | A/SHLW A                | 1           | 2              | 0           | 0           | word (A) $\leftarrow$ Logical left shift (A, 1-bit)                                                                                                                                                                                                                                 | -  | -  | - | - | *   | *     | *     | - | *     | -   |
| ASRW                 | A, R0                   | 2           | *1             | 1           | 0           | word (A) ← Arithmetic right<br>barrel shift (A, R0)                                                                                                                                                                                                                                 | -  | -  | - | - | *   | *     | *     | - | *     | -   |
| LSRW                 | A, R0                   | 2           | *1             | 1           | 0           | word (A) $\leftarrow$ Logical right barrel shift (A, R0)                                                                                                                                                                                                                            | -  | -  | - | - | *   | *     | *     | - | *     | -   |
| LSLW                 | A, R0                   | 2           | *1             | 1           | 0           | word (A) $\leftarrow$ Logical left barrel shift (A, R0)                                                                                                                                                                                                                             | -  | -  | - | - | -   | *     | *     | - | *     | -   |
| ASRL<br>LSRL<br>LSLL | A, R0<br>A, R0<br>A, R0 | 2<br>2<br>2 | *2<br>*2<br>*2 | 1<br>1<br>1 | 0<br>0<br>0 | $\begin{array}{l} \text{long (A)} \leftarrow \text{Arithmetic right} \\ \text{barrel shift (A, R0)} \\ \text{long (A)} \leftarrow \text{Logical right barrel} \\ \text{shift (A, R0)} \\ \text{long (A)} \leftarrow \text{Logical left barrel} \\ \text{shift (A, R0)} \end{array}$ |    |    |   |   | * - | * * * | * * * |   | * * * |     |

# Table 4.2.17 Shift Instructions (Byte/Word/Long-Word) (18 Instructions)

\*1: 6 when R0 is 0, 5 + (R0) in all other cases.

\*2: 6 when R0 is 0, 6 + (R0) in all other cases.

#### 4.2 Instruction Set

| Table 4.2.18 Branch 1 Instructions | s <mark>(</mark> 31 | Instructions) |
|------------------------------------|---------------------|---------------|
|------------------------------------|---------------------|---------------|

| N         | nemonic |       | #  | ~      | RG | В     | Operation                                                        | LH | AH | Ι | S | Т | Ν | Ζ | V | С | RMW |
|-----------|---------|-------|----|--------|----|-------|------------------------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| BZ / BEQ  | rel     |       | 2  | *1     | 0  | 0     | Branch if (Z) = 1                                                | -  | -  | - | - | - | 1 | - | - | - | -   |
| BNZ / BNE | rel     |       | 2  | *1     | 0  | 0     | Branch if (Z) = 0                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BC / BLO  | rel     |       | 2  | *1     | 0  | 0     | Branch if (c) = 1                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BNC / BHS | rel     |       | 2  | *1     | 0  | 0     | Branch if (c) = 0                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BN        | rel     |       | 2  | *1     | 0  | 0     | Branch if (N) = 1                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BP        | rel     |       | 2  | *1     | 0  | 0     | Branch if (N) = 0                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BV        | rel     |       | 2  | *1     | 0  | 0     | Branch if (V) = 1                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BNV       | rel     |       | 2  | *1     | 0  | 0     | Branch if $(V) = 0$                                              | -  | -  | - | - | - | - | - | - | - | -   |
| BT        | rel     |       | 2  | *1     | 0  | 0     | Branch if (T) = 1                                                | -  | -  | - | - | - | - | - | - | - | -   |
| BNT       | rel     |       | 2  | *1     | 0  | 0     | Branch if $(T) = 0$                                              | -  | -  | - | - | _ | _ | _ | _ | _ | -   |
| BLT       | rel     |       | 2  | *1     | 0  | 0     | Branch if (V) xor (N) = 1                                        | -  | -  | - | - | _ | _ | _ | _ | _ | -   |
| BGE       | rel     |       | 2  | *1     | 0  | 0     | Branch if (V) xor (N) = $0$                                      | -  | -  | _ | - | _ | _ | _ | _ | _ | -   |
| BLE       | rel     |       | 2  | *1     | 0  | 0     | Branch if $((V) \text{ xor } (N))$ or $(Z) = 1$                  | -  | -  | - | - | - | - | _ | - | - | -   |
| BGT       | rel     |       | 2  | *1     | 0  | 0     | Branch if $((V) \text{ xor } (N))$ or $(Z) = 0$                  | -  | -  | _ | - | _ | _ | _ | _ | _ | -   |
| BLS       | rel     |       | 2  | *1     | 0  | 0     | Branch if (c) or (Z) = 1                                         | -  | -  | _ | - | _ | _ | _ | _ | _ | -   |
| BHI       | rel     |       | 2  | *1     | 0  | 0     | Branch if (c) or $(Z) = 0$                                       | -  | -  | - | - | - | - | _ | - | - | -   |
| BRA       | rel     |       | 2  | *1     | 0  | 0     | Branch unconditionally                                           | -  | -  | - | - | - | - | - | - | - | -   |
| JMP       | @A      |       | 1  | 2      | 0  | 0     | word (PC) $\leftarrow$ (A)                                       | -  | -  | - | - | - | - | - | - | - | -   |
| JMP       | addr16  |       | 3  | 3      | 0  | 0     | word (PC) ← addr16                                               | -  | -  | - | - | - | - | - | - | - | -   |
| JMP       | @ear    |       | 2  | 2      | 1  | 0     | word (PC) $\leftarrow$ (ear)                                     | -  | -  | - | - | - | - | - | - | - | -   |
| JMP       | @eam    |       | 2+ | 4+(a)  | 0  | (c)   | word (PC) $\leftarrow$ (eam)                                     | -  | -  | - | - | - | - | - | - | - | -   |
| JMPP      | @ear    | Note1 | 2  | 3      | 2  | 0     | word (PC) $\leftarrow$ (ear), (PCB) $\leftarrow$ (ear+2)         | -  | -  | - | - | - | - | - | - | - | -   |
| JMPP      | @eam    | Note1 | 2+ | 6+(a)  | 0  | (d)   | word (PC) $\leftarrow$ (eam), (PCB) $\leftarrow$ (eam+2)         | -  | -  | - | - | - | - | - | - | - | -   |
| JMPP      | addr24  |       | 4  | 4      | 0  | 0     | word (PC) $\leftarrow$ ad24 0-15, (PCB) $\leftarrow$ ad24 16-23  | -  | -  | - | - | - | - | - | - | - | -   |
| CALL      | @ear    | Note3 | 2  | 5      | 1  | (c)   | word (PC) $\leftarrow$ (ear)                                     | -  | -  | - | - | - | - | - | - | - | -   |
| CALL      | @eam    | Note3 | 2+ | 7+(a)  | 0  | 2×(c) | word (PC) $\leftarrow$ (eam)                                     | -  | -  | - | - | - | - | - | - | - | -   |
| CALL      | addr16  | Note4 | 3  | 6      | 0  | (c)   | word (PC) $\leftarrow$ addr16                                    | -  | -  | - | - | - | - | - | - | - | -   |
| CALLV     | #vct4   | Note4 | 1  | 7      | 0  | 2×(c) | Vector call instruction                                          | -  | -  | - | - | - | - | - | - | - | -   |
| CALLP     | @ear    | Note5 | 2  | 8      | 2  | 2×(c) | word (PC) $\leftarrow$ (ear) 0-15, (PCB) $\leftarrow$ (ear)16-23 | -  | -  | - | - | - | - | - | - | - | -   |
| CALLP     | @eam    | Note5 | 2+ | 11+(a) | 0  | *2    | word (PC) $\leftarrow$ (ear) 0-15, (PCB) $\leftarrow$ (ear)16-23 | -  | -  | - | - | - | - | - | - | - | -   |
| CALLP     | addr24  | Note6 | 4  | 10     | 0  | 2×(c) | word (PC) $\leftarrow$ addr0-15, (PCB) $\leftarrow$ addr16-23    | -  | -  | - | - | - | - | - | - | - | -   |

\*1: 4 when branching, 3 when not branching.

\*2:  $3 \times (c) + (b)$ 

Note1: Read (word) branch address.

Note2: W: Save (word) into stack; R: read (word) branch address.

Note3: Save (word) into stack.

Note4: W: Save (long-word) into W stack; R: read (long-word) R branch address.

**Note5:** Save (long-word) into stack.

|        | Mnemonic         | #  | ~  | RG | В              | Operation                                                                                                                           | LH | AH | Т | S | Т | Ν | Ζ | V | С | RMW |
|--------|------------------|----|----|----|----------------|-------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| CBNE   | A, #imm8, rel    | 3  | *1 | 0  | 0              | Branch if byte (A) ≠ imm8                                                                                                           | -  | -  | _ | - | * | * | * | * | * | -   |
| CWBNE  | A, #imm16, rel   | 4  | *1 | 0  | 0              | Branch if word (A) ≠ imm16                                                                                                          | -  | -  | - | - | * | * | * | * | * | -   |
| CBNE   | ear, #imm8, rel  | 4  | *2 | 1  | 0              | Branch if byte (ear) ≠ imm8                                                                                                         | -  | -  | _ | _ | * | * | * | * | * | -   |
| CBNE   | eam, #imm8, rel  | 4+ | *3 | 0  | (b)            | Branch if byte (eam) ≠ imm8                                                                                                         | -  | -  | - | - | * | * | * | * | * | -   |
| CWBNE  | ear, #imm16, rel | 5  | *4 | 1  | 0              | Branch if word (ear) ≠ imm16                                                                                                        | -  | -  | - | - | * | * | * | * | * | -   |
| CWBNE  | eam, #imm16, rel | 5+ | *3 | 0  | (c)            | Branch if word (eam) ≠ imm16                                                                                                        | -  | -  | - | - | * | * | * | * | * | -   |
| DBNZ   | ear, rel         | 3  | *5 | 2  | 0              | Branch if byte (ear) = (ear)-1, (ear) $\neq 0$                                                                                      | _  | _  | _ | _ | * | * | * | * | _ | -   |
| DBNZ   | eam, rel         | 3+ | *6 | 2  | 2×(b)          | Branch if byte (eam) = (eam)-1, (eam) $\neq 0$                                                                                      | -  | -  | - | - | * | * | * | * | - | *   |
| DWBNZ  | ear, rel         | 3  | *5 | 0  | 0              | Branch if word (ear) = (ear)-1, (ear) $\neq 0$                                                                                      | _  | _  | _ | _ | * | * | * | * | _ | _   |
| DWBNZ  | eam, rel         | 3+ | *6 | 0  | $2 \times (c)$ | Branch if word (eam) = (eam)-1, (eam) $\neq 0$                                                                                      | -  | -  | - | - | * | * | * | * | - | *   |
| INT    | #vct8            | 2  | 20 | 0  | 8×(c)          | Software interrupt                                                                                                                  | _  | _  | R | s | _ | _ | _ | _ | _ | _   |
| INT    | addr16           | 3  | 16 | 0  | 6×(c)          | Software interrupt                                                                                                                  | _  | _  | R | s | _ | _ | _ | _ | _ | _   |
| INTP   | addr24           | 4  | 17 | 0  | 6×(c)          | Software interrupt                                                                                                                  | _  | -  | R | S | - | - | _ | - | - | -   |
| INT9   |                  | 1  | 20 | 0  | 8×(c)          | Software interrupt                                                                                                                  | _  | -  | R | s | - | - | _ | - | - | -   |
| RETI   |                  | 1  | 15 | 0  | 6×(c)          | Return from interrupt processing                                                                                                    | -  | -  | * | * | * | * | * | * | * | -   |
| LINK   | #imm8            | 2  | 6  | 0  | (c)            | At function entry, saves the old frame pointer<br>to the stack, sets the new frame pointer, and<br>reserves the local pointer area. | -  | -  | - | - | - | - | - | - | - | -   |
| UNLINK |                  | 1  | 5  | 0  | (c)            | At function exit, restores the old frame pointer from the stack.                                                                    | -  | -  | - | - | - | - | - | - | - | -   |
| RET    | Note1            | 1  | 4  | 0  | (c)            | Return from subroutine                                                                                                              | -  | -  | _ | _ | _ | - | _ | _ | _ | -   |
| RETP   | Note2            | 1  | 6  | 0  | (d)            | Return from subroutine                                                                                                              | -  | -  | - | - | - | - | - | - | - | -   |

Table 4.2.19 Branch 2 Instructions (19 Instructions)

\*1: 5 when branching, 4 when not branching

\*2: 13 when branching, 12 when not branching

- \*3: 7 + (a) when branching, 6 + (a) when not branching
- \*4: 8 when branching, 7 when not branching
- \*5: 7 when branching, 6 when not branching
- \*6: 8 + (a) when branching, 7 + (a) when not branching

**Note1:** Return from stack (word)

Note2: Return from stack (long)

Note3: Do not use the RWj+ addressing mode for the CBNE or CWBNE instructions.

|       |            |    |       |        |       |                                                            |    |    | - |   | · · · | - |   |   |   |     |
|-------|------------|----|-------|--------|-------|------------------------------------------------------------|----|----|---|---|-------|---|---|---|---|-----|
| Mr    | nemonic    | #  | ~     | RG     | В     | Operation                                                  | LH | AH | I | S | Т     | Ν | Ζ | V | С | RMW |
| PUSHW | А          | 1  | 4     | 0      | (c)   | word (SP) $\leftarrow$ (SP) - 2, ((SP)) $\leftarrow$ (A)   | -  | -  | - | 1 | -     | - | 1 | - | - | -   |
| PUSHW | AH         | 1  | 4     | 0      | (c)   | word (SP) $\leftarrow$ (SP) - 2, ((SP)) $\leftarrow$ (AH)  | -  | -  | - | - | -     | - | - | - | - | -   |
| PUSHW | PS         | 1  | 4     | 0      | (c)   | word (SP) $\leftarrow$ (SP) - 2, ((SP)) $\leftarrow$ (PS)  | -  | -  | - | - | -     | - | - | - | - | -   |
| PUSHW | rist       | 2  | *3    | +&     | *4    | $(SP) \gets (SP) \text{ - } 2n,  ((SP)) \gets (rlst)$      | -  | -  | - | - | -     | - | - | - | - | -   |
| POPW  | A          | 1  | 3     | 0      | (c)   | word (A) $\leftarrow$ ((SP)) , (SP) $\leftarrow$ (SP) + 2  | -  | *  | - | - | -     | - | - | - | - | -   |
| POPW  | AH         | 1  | 3     | 0      | (c)   | word (AH) $\leftarrow$ ((SP)) , (SP) $\leftarrow$ (SP) + 2 | -  | -  | - | - | -     | - | - | - | - | -   |
| POPW  | PS         | 1  | 4     | 0      | (c)   | word (PS) $\leftarrow$ ((SP)) , (SP) $\leftarrow$ (SP) + 2 | -  | -  | * | * | *     | * | * | * | * | -   |
| POPW  | rlst       | 2  | *2    | +&     | *4    | $(rlst) \gets ((SP)) \;,  (SP) \gets (SP)$                 | -  | -  | - | - | -     | - | - | - | - | -   |
| JCTX  | @A         | 1  | 14    | 0      | 6×(c) | Context switch (process switch) instruction                | -  | -  | * | * | *     | * | * | * | * | -   |
| AND   | CCR, #imm8 | 2  | 3     | 0      | 0     | byte (CCR) $\leftarrow$ (CCR) and imm8                     | _  | _  | * | * | *     | * | * | * | * | _   |
| OR    | CCR, #imm8 | 2  | 3     | 0      | 0     | byte (CCR) $\leftarrow$ (CCR) or imm8                      | -  | -  | * | * | *     | * | * | * | * | -   |
| MOV   | RP, #imm8  | 2  | 2     | 0      | 0     | byte (RP) ← imm8                                           | _  | _  | _ | _ | _     | _ | _ | _ | _ | -   |
| MOV   | ILM, #imm8 | 2  | 2     | 0      | 0     | byte (ILM) $\leftarrow$ imm8                               | -  | -  | - | - | -     | - | - | - | - | -   |
| MOVEA | RWi, ear   | 2  | 3     | 1      | 0     | word (RWi) ← ear                                           | _  | -  | _ | _ | _     | _ | _ | _ | _ | _   |
| MOVEA | RWi, eam   | 2+ | 2+(a) | 1      | 0     | word (RWi) ← eam                                           | -  | -  | - | - | -     | - | - | - | - | _   |
| MOVEA | A, ear     | 2  | 1     | 0      | 0     | word (A) $\leftarrow$ ear                                  | -  | *  | - | - | _     | - | - | - | _ | _   |
| MOVEA | A, eam     | 2+ | 1+(a) | 0      | 0     | word $(A) \leftarrow eam$                                  | -  | *  | - | - | -     | - | - | - | - | -   |
| ADDSP | #imm8      | 2  | 3     | 0      | 0     | word (SP) $\leftarrow$ (SP)+ext(imm8)                      | _  | -  | _ | _ | _     | _ | _ | _ | _ | _   |
| ADDSP | #imm16     | 3  | 3     | 0      | 0     | word (SP) $\leftarrow$ (SP)+imm16                          | -  | -  | - | - | -     | - | - | - | - | -   |
| MOV   | A, brg1    | 2  | *1    | 0      | 0     | byte (A) $\leftarrow$ (brg1)                               | z  | *  | _ | _ | _     | * | * | _ | _ | _   |
| MOV   | brg2, A    | 2  | 1     | 0      | 0     | byte (brg2) $\leftarrow$ (A)                               | -  | -  | - | - | -     | * | * | - | - | -   |
| NOP   |            | 1  | 1     | 0      | 0     | No operation                                               | _  | _  | _ | _ | _     | _ | _ | _ | _ | _   |
| ADB   |            | 1  | 1     | 0<br>0 | 0     | Prefix code for auxiliary AD access                        | -  | _  | _ | _ | _     | _ | _ | _ | _ | -   |
| DTB   |            | 1  | 1     | 0      | 0     | Prefix code for data DT access                             | -  | -  | - | - | -     | - | - | _ | - | -   |
| PCB   |            | 1  | 1     | 0      | 0     | Prefix code for program PC access                          | -  | -  | - | - | -     | - | - | _ | - | -   |
| SPB   |            | 1  | 1     | 0      | 0     | Prefix code for stack SP access                            | -  | -  | - | - | -     | - | - | _ | - | -   |
| NCC   |            | 1  | 1     | 0      | 0     | Prefix code for no flag change                             | -  | -  | - | - | -     | - | - | _ | _ | -   |
| CMR   |            | 1  | 1     | 0      | 0     | Prefix for common register bank                            | -  | -  | - | - | -     | - | - | - | - | -   |
| CIVIR |            |    |       | U      | U     | Frenk for common register bank                             | _  | _  | _ | _ | -     | _ | _ | _ | _ | -   |

## Table 4.2.20 Other Control Instructions (Byte/Word/Long-Word) (28 Instructions)

\*1: PCB, ADB, SSB, USB, and SPB: .....1 cycle DTB, DPR: ......2 cycles

\*2: 7 + 3\*(number of POP operations) + 2\*(register number of last register POPed) or 7 when RLST = 0 (no move register)

\*3: 29 + 3\*(number of PUSH operations) - 3\*(register number of last register PUSHed) or 8 when RLST = 0 (no move register)

\*4: (number of POP operations) \* (c) or (number of PUSH operations) \* (c)

| N                    | Inemonic                                       | #           | ~              | RG          | В                       | Operation                                                                                               | LH          | AH     | I           | S           | Т           | Ν     | Z           | V           | С           | RMW         |
|----------------------|------------------------------------------------|-------------|----------------|-------------|-------------------------|---------------------------------------------------------------------------------------------------------|-------------|--------|-------------|-------------|-------------|-------|-------------|-------------|-------------|-------------|
| MOVB<br>MOVB<br>MOVB | A ,dir: bp<br>A ,addr16: bp<br>A, io: bp       | 3<br>4<br>3 | 5<br>5<br>4    | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | byte (A) $\leftarrow$ (dir:bp)b<br>byte (A) $\leftarrow$ (addr16:bp)b<br>byte (A) $\leftarrow$ (io:bp)b | Z<br>Z<br>Z | * * *  |             |             |             | * * * | * * *       |             |             | -<br>-<br>- |
| MOVB<br>MOVB<br>MOVB | dir: bp, A<br>addr16: bp, A<br>io: bp, A       | 3<br>4<br>3 | 7<br>7<br>6    | 0<br>0<br>0 | 2×(b)<br>2×(b)<br>2×(b) | bit (dir:bp)b $\leftarrow$ (A)<br>bit (addr16:bp)b $\leftarrow$ (A)<br>bit (io:bp)b $\leftarrow$ (A)    | -<br>-<br>- | -<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | * * * | * * *       | -<br>-<br>- | -<br>-<br>- | *<br>*<br>* |
| SETB<br>SETB<br>SETB | dir: bp<br>addr16: bp<br>io: bp                | 3<br>4<br>3 | 7<br>7<br>7    | 0<br>0<br>0 | 2×(b)<br>2×(b)<br>2×(b) | bit (dir:bp)b $\leftarrow$ 1<br>bit (addr16:bp)b $\leftarrow$ 1<br>bit (io:bp)b $\leftarrow$ 1          | -<br>-<br>- | -<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- |       | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | *<br>*<br>* |
| CLRB<br>CLRB<br>CLRB | dir: bp<br>addr16: bp<br>io: bp                | 3<br>4<br>3 | 7<br>7<br>7    | 0<br>0<br>0 | 2×(b)<br>2×(b)<br>2×(b) | bit (dir:bp)b $\leftarrow$ 0<br>bit (addr16:bp)b $\leftarrow$ 0<br>bit (io:bp)b $\leftarrow$ 0          | -<br>-<br>- | -<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- |       | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | *<br>*<br>* |
| BBC<br>BBC<br>BBC    | dir: bp, rel<br>addr16: bp, rel<br>io: bp, rel | 4<br>5<br>4 | *1<br>*1<br>*2 | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | Branch if (dir:bp)b = 0<br>Branch if (addr16:bp)b = 0<br>Branch if (io:bp)b = 0                         | -<br>-<br>- | -<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- |       | -<br>-<br>- | * * *       | -<br>-<br>- | -<br>-<br>- |
| BBS<br>BBS<br>BBS    | dir:bp, rel<br>addr16:bp, rel<br>io:bp, rel    | 4<br>5<br>4 | *1<br>*1<br>*2 | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | Branch if (dir:bp)b = 1<br>Branch if (addr16:bp)b = 1<br>Branch if (io:bp)b = 1                         | -<br>-<br>- |        | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- |       | -<br>-<br>- | * * *       | -<br>-<br>- | -<br>-<br>- |
| SBBS                 | addr16:bp, rel                                 | 5           | *3             | 0           | 2×(b)                   | Branch if (addr16:bp)b = 1, bit = 1                                                                     | -           | -      | -           | -           | -           | -     | -           | *           | -           | *           |
| WBTS                 | io:bp                                          | 3           | *4             | 0           | *5                      | Wait until (io:bp)b = 1                                                                                 | -           | -      | -           | -           | -           | -     | -           | -           | -           | -           |
| WBTC                 | io:bp                                          | 3           | *4             | 0           | *5                      | Wait until (io:bp)b = 0                                                                                 | -           | -      | -           | -           | -           | -     | -           | -           | -           | -           |

Table 4.2.21 Bit Manipulation Instructions (21 Instructions)

- \*1: 8 when branching, 7 when not branching
- \*2: 7 when branching, 6 when not branching
- \*3: 10 when condition is satisfied, 9 when not satisfied
- \*4: Undefined count
- \*5: Until condition is satisfied

| Mnemonic    |     | # | ~ | RG | В | Operation                        | LH | AH | Ι | S | Т | Ν | Ζ | V | С | RMW |
|-------------|-----|---|---|----|---|----------------------------------|----|----|---|---|---|---|---|---|---|-----|
| SWAP        |     | 1 | 3 | 0  | 0 | byte (A)0 -7↔ (A)8-15            | -  | -  | - | - | - | - | - | - | - | -   |
| SWAP / XCHW | A,T | 1 | 2 | 0  | 0 | word (AH) $\leftrightarrow$ (AL) | -  | *  | - | - | - | - | - | - | - | -   |
| EXT         |     | 1 | 1 | 0  | 0 | Byte sign extension              | Х  | -  | - | - | * | * | - | - | - | -   |
| EXTW        |     | 1 | 2 | 0  | 0 | Word sign extension              | -  | Х  | - | - | * | * | - | - | - | -   |
| ZEXT        |     | 1 | 1 | 0  | 0 | Byte zero extension              | Z  | -  | - | - | R | * | - | - | - | -   |
| ZEXTW       |     | 1 | 1 | 0  | 0 | Word zero extention              | -  | Z  | - | - | R | * | - | - | - | -   |

## Table 4.2.22 Accumulator Manipulation Instructions (Byte/Word) (6 Instructions)

#### Table 4.2.23 String Instructions (10 Instructions)

| Mnemonic       | # | ~    | RG | В  | Operation                                        | LH | AH | Т | S | Т | Ν | Ζ | V | С | RMW |
|----------------|---|------|----|----|--------------------------------------------------|----|----|---|---|---|---|---|---|---|-----|
| MOVS / MOVSI   | 2 | *2   | +& | *3 | Byte move $@AH+ \leftarrow @AL+$ , counter = RW0 | -  | -  | - | I | - | - | - | - | - | -   |
| MOVSD          | 2 | *2   | +& | *3 | Byte move $@AH- \leftarrow @AL-$ , counter = RW0 | -  | -  | - | - | - | - | - | - | - | -   |
| SCEQ / SCEQ1   | 2 | *1   | +& | *4 | Byte search (@AH+) ~ AL, counter = RW0           | -  | -  | - | _ | - | * | * | * | * | -   |
| SCEQD          | 2 | *1   | +& | *4 | Byte search (@AH-) ~ AL, counter = RW0           | -  | -  | - | - | - | * | * | * | * | -   |
| FILS / FILS1   | 2 | 6m+6 | +& | *3 | Byte fill $@AH+ \leftarrow AL$ , counter = RW0   | -  | -  | - | - | - | * | * | - | - | -   |
| MOVSW / MOVSWI | 2 | *2   | +) | *6 | Word move $@AH+ \leftarrow @AL+$ , counter = RW0 | -  | -  | - | I | - | I | - | I | I | -   |
| MOVSWD         | 2 | *2   | +) | *6 | Word move @AH- $\leftarrow$ @AL-, counter = RW0  | -  | -  | - | - | - | - | - | - | - | -   |
| SCWEQ / SCWEQI | 2 | *1   | +) | *7 | Word search (@AH+) — AL, counter = RW0           | -  | -  | - | _ | _ | * | * | * | * | _   |
| SCWEQD         | 2 | *1   | +) | *7 | Word search (@AH-) — AL, counter = RW0           | -  | -  | - | - | - | * | * | * | * | -   |
| FILSW / FILSWI | 2 | 6m+6 | +) | *6 | Word fill @AH+ $\leftarrow$ AL, counter = RW0    | -  | _  | - | - | - | * | * | - | - | -   |

- \*1: 5 when RW0 is 0,  $4 + 7 \times (RW0)$  for count out, and 7n + 5 when match occurs
- \*2: 5 when RW0 is 0,  $4 + 8 \times$  (RW0) in any other case
- \*3: (b) × (RW0) + (b) × (RW0) When the source and destination access different areas, calculate the (b) value separately for each area.
- \*4:  $(b) \times n$
- \*5:  $2 \times (RW0)$
- \*6: (c) × (RW0) + (c) × (RW0) When the source and destination access different areas, calculate the (c) value separately for each area.
- \*7: (c)  $\times$  n
- \*8:  $2 \times (RW0)$
- m: RW0 value (counter value)
- n: Loop count

# 4.3 Instruction Map

Because the  $F^2MC-16L$  operation codes each consist of one or two bytes, the instruction map consists of numerous pages. The structure of the instruction map is shown below.



# Fig. 4.3.1 Structure of F<sup>2</sup>MC-16L Instruction Map

Instructions that consist of only one byte (such as NOP) are concluded on the basic page. Regarding instructions that require two bytes (such as MOVS), the existence of the map for the second byte is indicated when the first byte is referenced, so it is clear that it is necessary to use the following byte to reference the map for the second byte.



The correspondence between the actual instruction code and the instruction map is shown below.

**Note1:** Extended page maps are provided for bit manipulation instructions, character string manipulation instructions, two-byte instructions, and "ea" instructions; multiple-extended-page maps exist for each type of instruction.

#### Fig. 4.3.2 Correspondence between Actual Instructions and the Instruction Maps

| Мар   |
|-------|
| Page  |
| Basic |
| 4.3.1 |
| Table |

220

|     | #4                   | ı                     | 1                        |                             | 1                     | 1              |      | 1              |       |                |      | 1              |       | I              |         |                |        |         |         |                |        | 1         |                  |              |        | I                     |                     | ,                        |          | _            |
|-----|----------------------|-----------------------|--------------------------|-----------------------------|-----------------------|----------------|------|----------------|-------|----------------|------|----------------|-------|----------------|---------|----------------|--------|---------|---------|----------------|--------|-----------|------------------|--------------|--------|-----------------------|---------------------|--------------------------|----------|--------------|
| Е 0 | CALLV                | <br> <br> <br>        | 1<br>1<br>1<br>1         |                             | <br> <br> <br> <br>   | 1              |      | -              |       | -              |      |                |       | -              |         |                |        | 1       |         | -              |        | -         |                  | -            |        | ,<br>,<br>,<br>,<br>, |                     | <br> <br> <br>           |          |              |
|     | A, #4                | I<br>I                | I<br>I                   |                             | 1                     | 1              | 1    | 1              |       | 1              | 1    | 1              | 1     | 1              |         |                | I      |         | I       | 1              |        | 1         | 1                | 1            | I      | 1                     |                     | 1                        |          |              |
| 0 O | MOVN                 | <br> <br> <br>        | 1<br>1<br>1              |                             | <br> <br> <br>        |                |      | -              |       | 1              |      | 1              |       | 1              |         |                |        | 1       |         | 1              |        | -         |                  | -            |        | 1                     |                     | 1                        | -,       | -            |
| C 0 | MOVX<br>A,@RWi+d8    |                       |                          |                             |                       | 1              |      | 1              |       |                |      | 1              |       | •              | MOVW @R | Wi+dB, A       |        | 1       |         |                |        | 1         |                  |              |        |                       |                     |                          |          | *            |
| BO  | MOVX<br>A, Ri        | <br> <br> <br>        |                          |                             | 1<br>1<br>1<br>1      |                |      | -              |       |                |      | -              |       | 1              | 2       | @ RWi+dB       |        | -       |         |                |        | -         |                  |              |        |                       |                     |                          |          | 1            |
| A 0 |                      | 1<br>1<br>1<br>1      | 1<br>1<br>1<br>1         |                             | <br> <br> <br>        |                |      | <br> <br> <br> |       |                |      |                |       | •              | MOVW    | RWi, #16       |        |         |         | <br> <br> <br> |        |           |                  |              |        |                       |                     | <br> <br> <br> <br>      |          | +            |
| 06  | MOV<br>Ri, A         | ,<br>,<br>,<br>,<br>, | <br> <br> <br> <br> <br> |                             | -<br>-<br>-<br>-<br>- |                |      | 1              |       | 1              |      | 1              |       |                | MOVW    | RWi, A         |        |         |         |                |        | 1         |                  |              |        | -                     |                     | <br> <br> <br> <br> <br> |          | ٠            |
| 8 0 | MOV<br>A, Ri         | 1<br>1<br>1<br>1      | <br> <br> <br> <br>      |                             | <br> <br> <br>        |                |      | 1              |       |                |      | 1              |       |                | MOVW    | A, RWi         |        |         |         | <br> <br> <br> |        | 1         |                  | י<br>י<br>י  |        |                       |                     | <br> <br> <br> <br>      |          | +            |
| 7 0 | ea<br>instructions ) | ea                    | instructions (           | ea<br>addr16 instructions ) | еа                    | instructions ( | ea   | instructions ) | еа    | instructions < | ea   | instructions > | ea    | instructions 4 | ea      | instructions ) | MOVEA  | RWi, ea | NOM     | Ri, ea         | MOVW   | RWi, ea   | NOV              | ea, Ri       | MOVW   | ea, RWi               | XCH                 | Ri, ea                   | XCRW     | RWi, ea      |
| 6 0 | BRA<br>rel           | JMP                   | @A                       | JMP<br>addr16               | JMPP                  | addr24         | CALL | addr16         | CALLP | addr24         | RETP |                | RET   |                | INT     | #vct8          | INT    | addr16  | NTP     | addr24         | RETI   |           | Bit<br>operation | instructions |        |                       | String<br>operation | instructions             | Two-byte | instructions |
| 50  | MOV<br>A, io         | MOV                   | io, A                    | MOV<br>A, addr16            | MOV                   | addr 16, A     | NOM  | io, #8         | XVOM  | A, io          | MOVW | io, #16        | MOVX  | A, addr16      | MOVW    |                | MOVW   | io, A   | MOVW    | A, addr16      | MOVW   | addr16, A | POPW             | A            | MdOd   | AH                    | POPW                | PS                       | POPW     | rlst         |
| 4 0 | MOV<br>A, dir        | MOV                   | dir, A                   | MOV<br>A, #8                | MOVX                  | A, #8          | NOM  | dir, #8        | XVOM  | A, dir         | MOVW | A, SP          | MOVW  | SP, A          | MOVW    | A, dir         | MOVW   | dir, A  | MVOM    | A, #16         | MOVL   | A, #32    | PUSHW            | A            | MHSUA  | AH                    | PUSHW               | PS                       | PUSHW    | rlst         |
| 3 0 | ADD<br>A,#8          | SUB                   | A, #8                    | SUBC                        | CMP                   | A, #8          | AND  |                | OR    | A, #8          | XOR  | A, #8          | NOT   |                | ADDW    | A, #16         | SUBW   | A, #16  | CWBNE   | A, #16, re     | CMPW   | A, #16    | ANDW             | A, #16       | ORW    | A, #16                | XORW                | A, #16                   | NOTW     | A            |
| 20  | ADD<br>A, dir        | SUB                   | A, dir                   | ADDC                        | CMP                   | ٩              | AND  | CCR, #8        | OR    | CCR, #8        | DIVU | ٩              | MULU  | A              | ADDW    | ۷              | SUBW   | A       | CBNE A, | #8, rel        | CMPW   | A         | ANDW             | A            | ORW    | A                     | XORW                | A                        | MULUW    | A            |
| 1 0 | CMR                  | NCC                   |                          | SUBDC                       | JCTX                  | @A             | EXT  |                | ZEXT  |                | SWAP |                | ADDSP | #8             | ADDL    | A, #32         | SUBL   | A, #32  | MOV     | ILM, #         | CMPL   | ₹, #3     | EXTW             |              | ZEXTW  |                       | SWAPW               |                          | ADDSP    | #16          |
| 0 0 | NOP                  | INT9                  |                          |                             | NEG                   | A              | PCB  |                | DTB   |                | ADB  |                | SPB   |                | LINK    | imm#8          | UNLINK |         | NOV     | RP, #8         | NEGW   | A         | LSLW             | A            |        |                       | ASRW                | A                        | LSRW     | A            |
|     | 0+                   | +                     | ,                        | + 2                         | +                     |                | + 4  |                | +5    |                | 9+   |                | 7 + 7 |                | 8<br>+  |                | 6+     |         | 4 +     |                | 8<br>+ |           | 0<br>+           |              | 0<br>+ |                       | ш<br>+              |                          | Ц.<br>+  |              |

#### 4.3 Instruction Map

F 0 BZ/BEQ

rel BNZ/BNE rel BC /BLO rel BNC/BHS

ন দ দ

BP BN

e

ВТ

BNT BLT

e

e

BNV

B<

e e e e

BGE BLE BLE BLE Ð

BH

Chapter 4: Instructions

| = 6 CH)             |   |
|---------------------|---|
| t byte =            |   |
| Map (First I        |   |
| Ę                   |   |
| Instructic          |   |
| ulation             | _ |
| Manipı              |   |
| ble 4.3.2 Bit Manip |   |
| ole 4.              |   |

| Table 4.3.2 Bit Manipulation Instruction Map (First byte = 6 CH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | 0 B0 C0 D0 E0 F0 | Dp. rel 0:bp 0:bp 0:bp |  |  |  |          | p. rel 2 adf6:bp. rel 2 adf1:6:bp            |    |  |     |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|------------------------|--|--|--|----------|----------------------------------------------|----|--|-----|--|
| e 4.3.2 Bit Manipulation Instruction Map (First byte = 6 (<br><sup>00</sup> 10 20 30 40 50 60 7<br><sup>MOVB</sup> MOVB<br><sup>MOVB</sup> MOV | (H)                   | 80 90            | bp, rei                |  |  |  |          | BBC BBC<br>16:bp _ dir:bp,rel _ ad16:bp, rel |    |  |     |  |
| e 4.3.2 Bit Manipulation Instruction Nova       00       10       20       30       40         MOVB       MOVB       MOVB       MOVB       MOVB       A       A       A         MOVB       MOVB       MOVB       MOVB       MOVB       A       A       A       A       B       A       B       A       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B       B <t< td=""><td>1ap (First byte = 6 (</td><td>60</td><td>00</td><td></td><td></td><td></td><td></td><td>CLRB SETB<br/>addr16:bp dir:bp</td><td></td><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1ap (First byte = 6 ( | 60               | 00                     |  |  |  |          | CLRB SETB<br>addr16:bp dir:bp                |    |  |     |  |
| e 4.3.2 Bit Manipula                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | tion Instruction M    | 3.0              | p, A                   |  |  |  |          | P,A addr16: bp, A                            |    |  |     |  |
| <b>JG</b> 0 + + + + + + + + + + + + + + + + + +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | le 4.3.2 Bit Manipula | 1 0              | MOVB<br>A, io:bp       |  |  |  | <b>-</b> | MOVB MOVB<br>A, dir:bp A, addr16:bp          | ¥+ |  | Ш + |  |

| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Table 4 | 4.3.3 Cł          | haracte | r Strinç | Table 4.3.3 Character String Manipulation |     | Instruc | tion Ma | ap (Fir: | Instruction Map (First byte = 6EH) | = 6EH) |        |        |       |     |        |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------|---------|----------|-------------------------------------------|-----|---------|---------|----------|------------------------------------|--------|--------|--------|-------|-----|--------|-----|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         | 0 0               | 1 0     | 2 0      | 3.0                                       | 4 0 | 5 0     | 60      | 7 0      | 8 0                                | 06     | A 0    | B 0    | C 0   | D 0 | E 0    | F 0 |
| Pede 0108         Pede 0108 <t< th=""><th>0+</th><th>MOVSI<br/>PCB, PCB</th><th>MOVSD</th><th>MOVSWI</th><th>DWSVOM</th><th></th><th></th><th></th><th></th><th>SCEQI</th><th>SCEQD</th><th>scweol</th><th>SCWEQD</th><th>FILSI</th><th></th><th>FILSWI</th><th></th></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0+      | MOVSI<br>PCB, PCB | MOVSD   | MOVSWI   | DWSVOM                                    |     |         |         |          | SCEQI                              | SCEQD  | scweol | SCWEQD | FILSI |     | FILSWI |     |
| PCB. ADB         HOB         ADB         AD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | +       | PCB, DTB          |         |          |                                           |     |         |         |          | DTB                                | DTB    | DTB    | DTB    | DTB   |     |        |     |
| PCB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | +2      | PCB, ADB          |         |          |                                           |     |         |         |          | ADB                                | ADB    | ADB    | ADB    | ADB   |     | ADB    |     |
| DTB, PCB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | +3      | PCB, SPB          |         |          |                                           |     |         |         |          | SPB                                | SPB    | SPB    | V SPB  | SPB   |     | SPB    |     |
| DTB, DTB<br>DTB, DTB<br>DTB, SPB<br>DTB, SPB<br>ADB, PCB<br>ADB, PCB, PCB<br>ADB, PCB<br>ADB, PCB<br>ADB, PCB<br>ADB, PCB<br>ADB, PCB<br>ADB, PC | +4      | DTB, PCB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| DTB, ADB<br>DTB, SPB<br>ADB, PCB<br>ADB, PCB<br>ADB, DTB<br>ADB, SPB<br>ADB, SPB<br>ADB, SPB<br>SPB, PCB<br>SPB, PCB<br>SPB, PCB<br>SPB, PCB<br>SPB, PCB<br>SPB, PCB<br>SPB, PCB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | +<br>+  | DTB, DTB          |         |          |                                           |     | _       |         |          |                                    |        |        |        |       |     |        |     |
| ADB, PCB<br>ADB, DTB<br>ADB, DTB<br>ADB, DTB<br>ADB, SPB<br>ADB, SPB<br>SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ю<br>+  | DTB, ADB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| ADB, PCB<br>ADB, DTB<br>ADB, DTB<br>ADB, ADB<br>ADB, SPB<br>SPB, PCB<br>SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 7+      | DTB, SPB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| ADB, DTB<br>ADB, ADB<br>ADB, ADB<br>ADB, SPB<br>SPB, PCB<br>SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, DTB<br>SPB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 80<br>+ | ADB, PCB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| ADB, ADB<br>ADB, SPB<br>SPB, PCB<br>SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, ADB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 6<br>+  | ADB, DTB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| ADB, SPB<br>SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, ADB<br>SPB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ¥+      | ADB, ADB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| SPB, PCB<br>SPB, DTB<br>SPB, DTB<br>SPB, ADB<br>SPB, ADB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8<br>+  | ADB, SPB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| SPB, DTB<br>SPB, ADB<br>SPB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0<br>+  | SPB, PCB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| SPB, ADB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Q+      | SPB, DTB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
| SPB, SPB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Ш<br>+  | SPB, ADB          |         |          |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ч<br>+  | SPB, SPB          |         | · •      |                                           |     |         |         |          |                                    |        |        |        |       |     |        |     |

| e = 6          |
|----------------|
| First byte =   |
| (First         |
| Мар            |
| Instruction    |
| ipulation      |
| ) Man          |
| er String N    |
| .3.3 Character |
| Table 4.3.3    |

222

| First byte = 6FH) |
|-------------------|
| $\overline{}$     |
| Map               |
| C                 |
| Ictio             |
| 5                 |
| ž                 |
| č                 |
| -                 |
| Ð                 |
| ž                 |
| -<br>0            |
| Ò                 |
| 3                 |
| Two               |
| 4                 |
| ė                 |
| 4                 |
| ð                 |
| ble               |
| ä                 |
| Ĕ                 |
|                   |

| +0 MOV<br>+1 MOV<br>+2 MOV<br>+3 MOV<br>+4 MOV | A. DTB     |                |                                                             | 40                                         | 50 | 60 | 70 | 8 0 | 9.0 | A 0 | B 0 | C 0 | D 0 | E 0 | ΕO |
|------------------------------------------------|------------|----------------|-------------------------------------------------------------|--------------------------------------------|----|----|----|-----|-----|-----|-----|-----|-----|-----|----|
|                                                |            | MOVX           | MOV                                                         | MOV                                        |    |    |    |     |     |     |     |     |     |     |    |
|                                                | CW<br>2    |                | UID, A A, @ KLU +40 @ KLU+40, A A, @ KLU+40                 | A, @RL0140                                 |    |    |    |     |     |     |     |     |     |     |    |
| Ó M M                                          | , ADB      | ADB, A         |                                                             |                                            | _  |    |    |     |     | _   |     |     |     |     |    |
| NOM NOM                                        | MO         | MOVX           | MOVX _ MOV _ MOV _                                          | MOV                                        |    |    |    |     |     |     |     |     |     |     |    |
| OM OM                                          | A, SSB S   | SB, A A, @RL1- | SSB, A A, @RL1+d8 _@RL1+d8, A_ A, @RL1+d8                   | A, @RL1+d8                                 |    |    |    |     |     |     |     |     |     |     |    |
| MOM                                            | , USB      | V<br>USB, A    |                                                             |                                            |    |    |    |     |     |     |     |     |     |     |    |
|                                                | MO         | MOVX           | MOVX MOV MOV                                                | MOV                                        |    |    |    |     |     |     |     |     |     |     |    |
|                                                | A. DPR D   | PR. A A, @RL2  | DPR. A A, @RL2+d8 @RL2+d8, A A, @RL2+d8                     | A, @RL2+d8                                 |    |    |    |     |     |     |     |     |     | _   |    |
| +5 MOV                                         | , @A MO    | DV<br>@AL. AH  |                                                             |                                            |    |    |    |     |     |     |     |     |     |     |    |
| +6 MOV                                         | V. PCB     | @A A. @RL3-    | 0VX MOVX MOV MOV MOV<br>A @A A @RL3+d8 @RL3+d8 A A, @RL3+d8 | MOV<br>A, @RL3+d8                          | _  |    |    |     |     | _   |     |     |     |     |    |
| +7 ROLC A                                      | RO         |                | <br> <br> <br> <br> <br> <br>                               | <br> <br> <br> <br> <br> <br>              |    |    |    |     |     |     |     |     |     |     |    |
| 8+                                             |            |                | MOVW<br>@RL0+d8, A                                          | @RL0+d8, A A, @RL0+d8                      |    |    |    |     |     |     |     |     |     |     |    |
| 6+                                             |            |                |                                                             |                                            |    |    |    |     |     |     |     |     |     |     |    |
| +A                                             |            |                | @RL1+d8, A                                                  | MOVW MOVW MOVW MOVW @RL1+d8, A, @RL1+d8, A |    |    |    |     |     |     |     |     |     |     |    |
| ę                                              |            |                |                                                             |                                            |    |    |    |     |     |     |     |     |     |     |    |
| +C LSLW                                        | A, RO LSLL | A, R0          | A, R0 @RL2+d8, A A, @RL2+d8                                 | A, @RL2+d8                                 |    |    |    |     |     |     |     |     |     |     |    |
| +D MOVW<br>A,                                  | @ ¥        | , AH NRM       | A, R0                                                       |                                            |    |    |    |     |     |     |     |     |     |     |    |
| +E ASRW<br>A,                                  | ASRI<br>R0 | A, R0          | A, R0 @RL3+d8, A A, @RL3+d8                                 | MOVW<br>A, @RL3+d8                         |    |    |    |     |     |     |     |     |     |     |    |
| +F LSRW<br>A                                   | , R0 LSRL  | A, R0          | A, R0                                                       |                                            |    |    |    |     |     |     |     |     |     |     |    |

Table 4.3.5 "ea" Instructions ) (First byte = 70H)

| E0 F0 | CBNEO CBNEO |           |                       | #8,rel#8,rel<br>R2,;@RW2+d8, | #8rel#8rel<br>R3, @RW3+d8, | #8,_rel _ '#8, rel<br>R4,@RW4+d8, |                      | #8,rel _'#8,rel<br>R6,@RW6+d8, |                      | #8,_rel81_rel<br>@RŴ0,@RŴ0+d16, | #8rel#8rel<br>@RW1,@RW1+d16,         | #8,_rel _ i#8rel _<br>@RW2, _ i @RW2+d16,      | #8,_rel#8, rel<br>@RW3,@RW3+d16,    | #8rel _ ! #8rel _<br>! @RW0+RW7 | d#8. rel<br>@RW1+RW7               | hibit<br>pro #8. rel -<br>@PC+d16,     | U #8. rel              | () · · · · · · · |
|-------|-------------|-----------|-----------------------|------------------------------|----------------------------|-----------------------------------|----------------------|--------------------------------|----------------------|---------------------------------|--------------------------------------|------------------------------------------------|-------------------------------------|---------------------------------|------------------------------------|----------------------------------------|------------------------|------------------|
| DO    |             | XORL A,   | © RW0+d8<br>XORL Ă, Ē | ©RW1+d8<br>XORL Ă, F         | @RW2+d8<br>XORL Ă,         | @RW3+d8<br>XORL A, F              | @RW4+d8<br>XORL A,   | @RW5+d8<br>XORL A,             | @RW6+d8<br>XORL Ă,   | @RW7+d8<br>XORL A,              | @RW0+d16<br>XORL Ă,                  | @RW1+d16<br>XORL A,                            | @RW2+d16<br>XORL A,                 | @RW3+d16<br>XORL A,             | A, @RW0+ @RW0+RW7<br>(ORL iXORL A, | A, @RW1+ '@RW1+RW7<br>ÓŘL _ 'XOŘL Ă, _ | @PC+d16<br>XORL A.     |                  |
| с о   |             | XORL      | A, RL0<br>XORL        | A, RL0<br>XORL               | A, RL1<br>- XORL           | A, <u>r</u> L1<br>_X0RL           | A, RL2<br>XORL       | A, RL2<br>XORL                 | A, RL3<br>XORL       | A, RL3<br>XORL                  | A, @RW0<br>XORL                      | A, @RW1<br>_XORL                               | A, @RW2<br>XORL                     | _A, @RW3<br>XORL                | .~                                 |                                        | A, @RW2+               |                  |
| B 0   |             |           | @RW0+d8<br>ŌŘĹĂ,      | @RW1+d8<br>ŌŘĹĂ,             |                            | @_RW3+d8<br>                      |                      | @                              | @RW6+d8<br>ORL A,    | @RW7+d8<br>'ŌŘĹĂ,               | @RW0+d16<br>ORL A,                   | @RW1+d16<br>ORL A,                             | @RW2+d16<br>                        | @RW3+d16<br>ORL A,              | @RW0+!@RW0+RW7<br>- ORL A,         | @RW1+RW7<br>ORL A,                     | . @PC+d16<br>. @RC+d16 |                  |
| ΑO    |             | orl       | A, RLO<br>ŌRL         |                              |                            |                                   | A, <u>RL2</u><br>0RL | <u>A. RL2</u><br>ORL           | A, RL3 -<br>ŌRL      |                                 | _A, @RW0_<br>ORL                     |                                                | _A, @RW2<br>0RL                     | Ă, @RW3<br>ORL                  | ŌRI                                | A, @RW1+<br>ŌRL                        | A, @RW2+<br>ORL        |                  |
| 0.6   |             | ANDL A,   | @RW0+d8<br>ANDL A,    | @RW1+d8<br>ANDL_A,           | @RW2+d8<br>ANDL_A,         | @RW3+d8<br>ANDL A,                | @RW4+d8<br>          | @RW5+d8<br>ANDL A,             | @RW6+d8<br>ANDL A,   | @RW7+d8<br>ANDL A,              | @RW0+d16<br>ANDL_A,                  | @RW1+d16<br>ANDL A,                            | @RW2+d16<br>ANDL_A,                 | @ RW3+d16<br>ANDL A,            | A, @RW0+¦@RW0+RW7<br>ANDL ANDL A,  |                                        | @PC+d16                |                  |
| 8 0   |             | ANDL      | ANDL -                | ANDL -                       | A, RL1                     | ANDL                              | ANDL                 | A, RL2<br>ANDL                 | ANDL                 | ANDL - A, RL3                   | A, @RW0<br>ANDL                      | A, @RW1                                        | A, @RW2<br>ANDL                     | A, @RW3                         | A, @RW0+                           | A, @RW1+                               | A, @RW2+               |                  |
| 2.0   |             |           | @RW0+d8<br>ČMPL A,    | @RW1+d8<br>CMPL_A,           | @RW2+d8<br>ČMPL A,         | @RW3+d8<br>CMPL A,                | @RW4+d8<br>CMPL_A,   | @RW5+d8<br>CMPL_A,             | @RW6+d8<br>ČMPL_A,   | @RW7+d8<br>ČMPL A,              | @RW0+d16<br>CMPL A,                  | @RW1+d16<br>CMPL_A,                            | @RW2+d16<br>ČMPL A,                 | @RW3+d16<br>CMPL A,             | . @RW0+RW7<br>CMPL A,              | @RW1+RW7<br>SMPL_A,                    |                        |                  |
| 6 0   |             | CMPL      | A, RLO                | A, RLO                       | Ā, RL1<br>ČMPL             | A, RL1<br>CMPL                    | Ā, RL2               | A, RL2<br>CMPL                 | A, RL3               | Ā, RL3<br>ČMPL                  | A, @RW0 6<br>CMPL C                  | A, @RW1                                        | Ă, @RW2<br>CMPL                     | Ā, @RW3<br>CMPL                 | <u>A, @RW0+</u><br>CMPL 0          | A, @RW1+                               | A, @RW2+               |                  |
| 5 0   | CWBNEC      | @ RW0+d8, |                       |                              |                            |                                   |                      |                                |                      |                                 | <u>#16, rel_</u><br>@RW1, d16, _     | #16, rel<br>@RW2+d16,                          |                                     | <u>#</u> 16, rel<br>i@RW0+RW7,  | <u>#16, rel</u><br>@RW1+RW7,       | #16, rel<br>.@PC+d16,                  | - #16, rel             |                  |
| 4 0   | CWBNEC      | RW0,      | #16, rel -            | #16, rel                     | #16, rel<br>RW3,           |                                   | #16. rel             | # <u>1</u> 6, rel<br>RW6,      | #16, rel -           | #16, rel<br>@_RW0,              | #16, rel@ RW1,                       | #16, rel                                       | #16, rel<br>@_RW3,                  | #16. rel<br>@ RW0+,             | #16_ rel<br>@ RW1+,                | #16, rel<br>@ RW2+,                    | #16, rel -<br>@ RW3+   |                  |
| 30    |             | SUBL A,   | @RW0+d8<br>SUBL A,    | A, RLO @RW1+d8               | @RW2+d8<br>SUBL A,         |                                   | @RW4+d8<br>SUBL A,   |                                | ë @RW6+d8<br>SUBL A, | @RW7+d8<br>ŠŪBLĀ,               | A, @RW0 @RW0+d16<br>SUBL 'SUBL A,    | A, @RW1 - @RW1+d16<br>SUBL 'SUBL A,            | A, @RW2   @RW2+d16<br>SUBL iSUBL A, |                                 | @RW0+RW7<br>SUBL A,                | @RW1+RW7<br>ŠUBL A,                    | @PC+d16                |                  |
| 2 0   |             | SUBL      |                       |                              |                            | A,_RL1<br>SUBL                    | A, RL2               | A,_RL2<br>SUBL                 | <u>A,RL3</u><br>SUBL | A, RL3<br>SUBL                  | A, @RW0<br>SUBL                      |                                                |                                     |                                 | pə:                                | prohibit<br>,                          |                        |                  |
| 1 0   |             | ADDL A,   |                       | @RW1+d8<br>.DDL_A,           | @RW2+d8                    | A, RL1 - @RW3+d8                  | @RW4+d8<br>ADDL_A,   | @RW5+d8<br>ADDL_A,             | @RW6+d8<br>ADDL_A,   | @RW7+d8<br>ADDL_A,              | A, @RW0   @RW0+d16<br>ADDL _ ADDL A, | A, @RW1 <sup>†</sup> @RW1+d16<br>ĀDDL iADDL A, | A, @RW2 0 @RW2+d16<br>ADDL 4DDL 4   | A,@rw3@rw3+d16ADDLADDL          | A. @rwo+'@rwo+rw7<br>Addl iAddl A, | Ă, @RW1+'@RW1+RW7<br>ĀDDL _ ADDL Ă,    | A, @RW2+' @PC+d16<br>  |                  |
| 0 0   |             | ADDL      | ĂĎDL<br>- AĎDL        | ĂDDL - F                     | ĂDDL                       | - ADDL                            | <u> </u>             |                                | ADDL                 |                                 | ĂDDL                                 | A,_@R<br>ADDL                                  | A, @RW2<br>                         | A,_@RW3                         | <u>A, @Rwo</u> +<br>Addl           | A, @RW1+<br>                           | A, @RW2+               |                  |
|       |             |           | 0+                    | ÷                            | +2                         | +3                                | +4                   | +5                             |                      |                                 | +8                                   | D<br>+                                         | ¥¥                                  | φ (                             |                                    | Ū,                                     | ¥                      |                  |

Table 4.3.6 "ea" Instructions ( (First byte = 71H)

|            | 0 0            | 10                  | 2 0             | 3.0                           | 4 0           | 5 0              | 6 0           | 7 0               | 8 0              | 0.6                    | A 0              | B 0                  | C 0                           | D 0                      | ΕO                | ΕO                   |
|------------|----------------|---------------------|-----------------|-------------------------------|---------------|------------------|---------------|-------------------|------------------|------------------------|------------------|----------------------|-------------------------------|--------------------------|-------------------|----------------------|
| 0+         | JMPP<br>@RL0   | 1JMPP<br>@@RW0+d8   | CALLP<br>@RL0   | -CALLP<br>@@RW0+d8            | INCL<br>RLO   | INCL<br>@RW0+d8  | DECL<br>RL0   | · DECL<br>@RW0+d8 | MOVL<br>A, RL0   | MOVL A,<br>@RW0+d8     | MOVL<br>RL0, A   | MOVL @R<br>W0+d8, A  | MOV<br>R0, #8                 | + MOV @R<br>W0+d8, #8    | MOVEA<br>A, RW0   | MOVEA A,<br>@RW0+d8  |
| ÷          | JMPP<br>@RL0   | JMPP<br>@@RW1+d8    | CALLP<br>@RL0   | - CALLP<br>- @@RW1+d8         | INCL          | INCL<br>@RW1+d8  | I I           | DECL<br>@RW1+d8   |                  | @RW1+d8                | MOVL<br>RL0, A   | MOVL @R<br>W1+d8, A  | MOV<br>R1, #8                 | MOV @R<br>W1+d8,#8       | MOVEA<br>A, RW1   | @RW1+d8              |
| +2         | JMPP<br>@RL1   | JMPP<br>@ @ RW2+d8  | CALLP<br>@RL1   | 2+d8                          | INCL<br>RL1   | INCL<br>@RW2+d8  |               | DECL<br>@RW2+d8   | MOVL<br>A, RL1   | MOVL A,<br>@RW2+d8     | MOVL<br>RL1, A   | MOVL @R<br>W2+d8, A  | MOV<br>R2, #8                 | MOV @R<br>W2+d8,#8       | MOVEA<br>A, RW2   | MOVEA A,<br>@RW2+d8  |
| ۴<br>ب     | JMPP<br>@RL1   | JMPP<br>0.00 RW3+d8 | CALLP<br>©RL1   | CALLP<br>@@RW3+d8             | INCL<br>RL1   | INCL<br>@RW3+d8  | DECL          | DECL<br>@RW3+d8   | MOVL<br>A, RL1   | @RW3+d8                | MOVL<br>RL1, A   |                      | MOV<br>R3, #8                 | MOV @R<br>W3+d8, #8      | MOVEA<br>A, RW3   | @RW3+d8              |
| +4         | JMPP<br>@RL2   | JMPP<br>@@RW4+d8    | CALLP<br>@RL2   | CALLP<br>@@RW4+d8             | INCL<br>RL2   | INCL<br>@RW4+d8  | DECL<br>RL2   | DECL<br>@RW4+d8   | MOVL<br>A, RL2   | MOVL A,<br>@RW4+d8     | MOVL<br>RL2, A   | MOVL @R<br>W4+d8, A  | MOV<br>R4, #8                 | MOV @R<br>W4+d8,#8       | MOVEA<br>A, RW4   | MOVEA A,<br>@RW4+d8  |
| +5         | JMPP<br>@RL2   | JMPP<br>@@RW5+d8    | CALLP<br>@RL2   | CALLP<br>@@RW5+d8             | INCL<br>RL2   | INCL<br>@RW5+d8  |               | DECL<br>@RW5+d8   | MOVL<br>A, RL2   | MOVL A,<br>@RW5+d8     | MOVL<br>RL2, A   |                      | MOV<br>R5, #8                 | MOV @R<br>W5+d8,#8       | MOVEA<br>A, RW5   | MOVEA A,<br>@RW5+d8  |
| 9+         | JMPP<br>@RL3   | JMPP<br>@@RW6+d8    | CALLP<br>@RL3   | CALLP<br>@@RW6+d8             | INCL<br>RL3   | INCL<br>@RW6+d8  | DECL<br>RL3   | DECL<br>@RW6+d8   | MOVL<br>A, RL3   | MOVL A,<br>@RW6+d8     | MOVL<br>RL3, A   | MOVL @R<br>W6+d8, A  | MOV<br>R6, #8                 | MOV @R<br>W6+d8, #8      | MOVEA<br>A, RW6   | MOVEA A,<br>@RW6+d8  |
| 7+         | JMPP<br>@RL3   | JMPP<br>@@RW7+d8    | CALLP<br>@RL3   | CALLP<br>@@RW7+d8             | INCL<br>RL3   | INCL<br>@RW7+d8  | DECL<br>RL3   | DECL<br>@RW7+d8   | MOVL<br>A, RL3   | MOVL A,<br>@RW7+d8     | MOVL<br>RL3, A   |                      | MOV<br>R7, #8                 | MOV @R<br>W7+d8, #8      | MOVEA<br>A, RW7   | MOVEA A,<br>@RW7+d8  |
| +8         | JMPP<br>@@RW0  | JMPP<br>@RW0+d16    | CALLP<br>@RW0   | CALLP<br>@RW0+d16             | INCL<br>@RW0  | INCL<br>@RW0+d16 | DECL<br>@RW0  | DECL<br>@RW0+d16  | MOVL<br>A, @RWQ  | MOVL A,<br>@RW0+d16    | MOVL<br>@RW0, A  | MOVL @R<br>W0+d16, A | MOV<br>@RW0, #8               | MOV @R<br>W0+d16,#8      | MOVEA<br>A, @RW0  | @RW0+d16             |
| 6+         | ~              | JMPP<br>@RW1+d16    | CALLP<br>@@RW1  | CALLP<br>@RW1+d16             |               | 1+d16            | DECL<br>@RW1  | DECL<br>@RW1+d16  | MOVL<br>A, @RW1  | MOVL A,<br>@RW1+d16    | MOVL<br>@RW1, A  |                      | MOV<br>@RW1,#8                | MOV @R<br>W1+d16, #8     |                   | MOVEA A,<br>@RW1+d16 |
| ¥+         | JMPP<br>@@RW2  | JMPP<br>@RW2+d16    | CALLP<br>@@RW2  | CALLP<br>@RW2+d16             |               | INCL<br>@RW2+d16 |               | DECL<br>@RW2+d16  | MOVL<br>A, @RW2  | MOVL A,<br>@RW2+d16    | MOVL<br>@RW2, A  | MOVL @R<br>W2+d16, A | MOV<br>@RW2,#8                | MOV @R<br>W2+d16, #8     | MOVEA<br>A, @RW2  | MOVEA A,<br>@RW2+d16 |
| +B         | JMPP<br>@@RW3  | JMPP<br>@RW3+d16    | CALLP<br>@@RW3  | CALLP CALLP<br>@@RW3 @RW3+d16 |               |                  | DECL<br>@RW3  | DECL<br>@RW3+d16  | MOVL<br>A,@ RW3  | @RW3+d16               | MOVL<br>@RW3, A  | MOVL @R<br>W3+d16, A | MOV<br>@RW3,#8                | MOV @R<br>W3+d16, #8     | MOVEA<br>A, @RW3  | @RW3+d16             |
| Ŷ          | JMPP<br>@@RW0+ | JMPP<br>@RW0+RW7    | CALLP<br>@@RW0+ | CALLP<br>@RW0+RW7             |               | INCL<br>@RW0+RW7 | DECL<br>@RW0+ | DECL<br>@RW0+RW7  | MOVL<br>A, @RW0+ | MOVL A,<br>@RW0+RW7    | MOVL<br>@RW0+, A | MOVL @R<br>W0+RW7, A |                               | MOV @R<br>W0+RW7, #8     | MOVEA<br>A, @RW0+ | MOVEA A,<br>@RW0+RW7 |
| <u>О</u> + | JMPP<br>@@RW1+ | JMPP<br>@RW1+RW7    | CALLP<br>@@RW1+ | CALLP<br>@RW1+RW7             |               | INCL<br>@RW1+RW7 | DECL<br>@RW1+ | DECL<br>@RW1+RW7  | MOVL<br>A, @RW1+ | MOVL A,<br>@RW1+RW7    | MOVL<br>@RW1+, A | MOVL @R<br>W1+RW7, A | MOV - N<br>@RW1+, #8' V       | 1 MOV @R<br>8 W1+RW7, #8 | MOVEA<br>A, @RW1+ | MOVEA A,<br>@RW1+RW7 |
| Ψ          | JMPP<br>@@RW2+ | JMPP<br>@ @ PC+d16  | CALLP CALLP C   | + CALLP<br>+ @@PC+d16         |               | INCL<br>@PC+d16  | DECL<br>@RW2+ | DECL<br>@PC+d16   | MOVL<br>A, @RW2+ | MOVL A,<br>W2+ @PC+d16 | MOVL<br>@RW2+, A | MOVL @P<br>C+d16, A  | MOV<br>@RW2+, #8 <sup>1</sup> | MOV @P<br>C+d16, #8      | MOVEA<br>A, @RW2+ | MOVEA A,<br>@PC+d16  |
| ц<br>+     | JMPP<br>@@RW3+ |                     | CALLP<br>@@RW3+ | ALLP CALLP<br>@@RW3+ @addr16  | INCL<br>@RW3+ | INCL<br>addr16   | DECL<br>@RW3+ | DECL<br>addr16    | MOVL<br>A, @RW3# | MOVL A,<br>addr16      | MOVL<br>@RW3+, A | MOVL<br>addr16, A    | MOV MOV<br>@RW3+, #8' addr16, | MOV<br>addr16, #8        | MOVEA<br>A, @RW3+ | MOVEA A,<br>addr16   |

| (First byte = 72 |
|------------------|
| Instructions )   |
| 4.3.7 "ea" Ir    |
| Table 4          |

| : byte = 72H)                             | 5 0 | 50                | INC DEC DEC DEC MOV A MOV A MOV A MOV A W1+d8 A A R1 @RW1+d8 A, R1 @RW1+d8 A, R1 @RW1+d8 A, R1 A W1+d8, A A, R1 @RW1+d8 A, R1 | INC DEC I DEC MOV A MOV A MOV I MOV C MOV A MOV C MOVX A OV2+d8 R2 I @RW2+d8 A, R2 I @RW2+d8 R2. A W2+d8 A A, R2 I @RW2+d8 | INC DEC DEC MOV A MOV MOV MOV WOV A WOV CON A A MOV WA A A A A A A A A A A A A A A A A A A | INC DEC DEC DEC MOV MOV A MOV MOV WOV WOV WOVX A MOVX A ORW44d8 A, R4 i @RW44d8 A, R4 i @RW44d8 A, R4 i @RW44d8 | INC DEC DEC DEC MOV MOV A MOV MOV MOV MOV MOV A KE A KE A W5+d8 R5, A W5+d8, A R5 i @RW5+d8 A, R5 i W5+d8 A, R5 i | inc DEC DEC DEC MOV A MOV MOV MOV MOVX MOVX A XCH<br>@RW6+d8 R6 i @RW6+d8 A, R6 i @RW6+d8 R6, A i W6+d8, A A, R6 i @RW6+d8 A, R6 i | INC DEC DEC DEC MOV A MOV A MOV A MOV A WOV A WOV X A Y7A S WY448 A A R7 @RW7+48 A, R7 A W7+48 A R7 A X7+48 A R7 A R7 A R7+48 A R7+48 A R7 A R7+48 R7+48 R7+48 R7+48 R7+48 R7+48 A R7+48 R7+ | INC DEC DEC MOV MOV A, MOV A, MOV WOV GR MOVX A, XCH<br>0 @RW0-d16 @RW0 i @RW0-d16 A, @RW0-@RW0-d16 A, WO+d16 A, @RW0- | INC DEC DEC MOV MOV A MOV A MOV A WOV C MOV X MOVX A XCH<br>@RW1+d16 @RW1+d16 A, @RW1+d16 @RW1+d16 @RW1+A W1+d16, A A, @RW1 @RW1+d16 A, @RW1 | INC DEC DEC MOV MOV A MOV A MOV A MOV A MOV & MOV X MOVX A XCH<br>@RW2+d16 @RW2+d16 A.@RW2+d16 @RW2+d16 @RW2, A W2+d16, A A.@RW2 @RW2+d16 A @RW2 | LINC DEC DEC DEC MOV MOV A MOV A MOV & MOV & XCH OV WOX A XCH WOY & W3+d16 @RW3+d16 @RW3+d16 A @RW3+d16 A, @RW3+d16 A, @RW3+d16 A, @RW3+d16 A, @RW3+d16 A A A A A A A A A A A A A A A A A A A | INC DEC DEC DEC MOV MOV A MOV A MOV @R MOV & MOV W MOVX A XCH @RW0+RW7 @RW0+RW7 @RW0+RW7 A @RW0+RW7 A @RW0+RW7 A @RW0+RW7 A @RW0+RW7 A | LINC DEC DEC DEC MOV MOV A, MOV A, MOV BR MOVX A, NOVX A, XCH @RW1+RW7 @RW1+; @RW1+RW7 A, @RW1+; @RW1+FW7 A, @RW1+; #RW1+; @RW1+; #RW1+; @RW1+; #RW1+; RW1+; RW1+ | LINC DEC DEC DEC MOV MOV A, MOV A, MOV @P MOVX MOVX A, XCH @PC+d16 @RW2+; @PC+d16 A,@RW2+; @PC+d16 A,@RW2+; @PC+d16 A,@RW2+; |  |
|-------------------------------------------|-----|-------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|
|                                           | A 0 | _                 | MOV<br>R1, A                                                                                                                  |                                                                                                                            | MOV<br>R3, A                                                                               |                                                                                                                 | ļ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MOV<br>@RW0                                                                                                            | MOV<br>@RW1,                                                                                                                                 |                                                                                                                                                  |                                                                                                                                                                                               | I N I                                                                                                                                  | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                              |  |
|                                           | 0 6 | MOV A,<br>@RW0+d8 | MOV A,<br>@RW1+d8                                                                                                             | MOV A,<br>@RW2+d8                                                                                                          | MOV A,<br>@RW3+d8                                                                          | MOV A,<br>@RW4+d8                                                                                               | MOV A,<br>@RW5+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOV A,<br>@RW6+d8                                                                                                                  | MOV A,<br>@RW7+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOV A,<br>@RW0+d16                                                                                                     | MOV A,<br>@RW1+d16                                                                                                                           | MOV A,<br>@RW2+d16                                                                                                                               | MOV A,<br>@RW3+d16                                                                                                                                                                            | MOV A,<br>@RW0+RW7                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | , <b>Σ</b>                                                                                                                   |  |
|                                           | 8 0 | MOV<br>A, R0      |                                                                                                                               |                                                                                                                            | MOV<br>A, R3                                                                               | MOV<br>A, R4                                                                                                    | MOV<br>A, R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | MOV<br>A, R6                                                                                                                       | MOV<br>A, R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | A, @RW                                                                                                                 | MOV<br>A, @RW1                                                                                                                               | MOV<br>A, @RW2                                                                                                                                   | MOV<br>A, @RW3                                                                                                                                                                                | MOV<br>A, @RW0+                                                                                                                        | MOV<br>A, @RW1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MOV<br>A, @RW2+                                                                                                              |  |
|                                           | 7 0 | DEC<br>@RW0+d8    | DEC<br>@RW1+d8                                                                                                                | DEC<br>@RW2+d8                                                                                                             | DEC<br>@RW3+d8                                                                             | DEC<br>@RW4+d8                                                                                                  | DEC<br>@RW5+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DEC<br>@RW6+d8                                                                                                                     | DEC<br>@RW7+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DEC<br>@RW0+d16                                                                                                        | DEC<br>@RW1+d16                                                                                                                              | DEC<br>@RW2+d16                                                                                                                                  | DEC<br>@RW3+d16                                                                                                                                                                               | DEC<br>@RW0+RW7                                                                                                                        | DEC<br>@RW1+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DEC<br>@PC+d16                                                                                                               |  |
|                                           | 6 0 | DEC<br>R0         | DEC<br>R1                                                                                                                     | DEC<br>R2                                                                                                                  | DEC<br>R3                                                                                  |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                    | DEC<br>R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DEC<br>@RW0                                                                                                            | DEC<br>@RW1                                                                                                                                  | DEC<br>@RW2                                                                                                                                      | DEC<br>@RW3                                                                                                                                                                                   | DEC<br>@RW0+                                                                                                                           | DEC<br>@RW1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DEC<br>@RW2+                                                                                                                 |  |
| e = 72H                                   | 5 0 | INC<br>@RW0+d8    | INC<br>@RW1+d8                                                                                                                | INC<br>@RW2+d8                                                                                                             | INC<br>@RW3+d8                                                                             | INC<br>@RW4+d8                                                                                                  | INC<br>@RW5+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | INC<br>@RW6+d8                                                                                                                     | INC<br>@RW7+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | @RW0+d16                                                                                                               | @RW1+d16                                                                                                                                     | INC<br>@RW2+d16                                                                                                                                  | INC<br>@RW3+d16                                                                                                                                                                               | INC<br>@RW0+RW7                                                                                                                        | INC<br>@RW1+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | @PC+d16                                                                                                                      |  |
| rst byt                                   | 4 0 | INC<br>R0         | NC<br>R                                                                                                                       | INC<br>R2                                                                                                                  | INC<br>R3                                                                                  | INC<br>R4                                                                                                       | INC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | INC<br>R6                                                                                                                          | INC<br>R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | INC                                                                                                                    | INC<br>@RW1                                                                                                                                  | INC<br>@RW2                                                                                                                                      | INC<br>@RW3                                                                                                                                                                                   | INC<br>@RW0+                                                                                                                           | INC<br>@RW1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | INC<br>@RW2+                                                                                                                 |  |
| is) (Fii                                  | 3.0 | RORC<br>@RW0+d8   |                                                                                                                               |                                                                                                                            | RORC<br>@RW3+d8                                                                            |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                        | @RW1+d16                                                                                                                                     | RORC<br>@RW2+d16                                                                                                                                 | RORC<br>@RW3+d16                                                                                                                                                                              | RORC<br>@RW0+RW7                                                                                                                       | RORC<br>@RW1+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ©PC+d16                                                                                                                      |  |
| ructior                                   | 2 0 | RORC<br>R0        | RORC<br>R1                                                                                                                    | RORC<br>R2                                                                                                                 | RORC<br>R3                                                                                 | RORC<br>R4                                                                                                      | RORC R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RORC R6                                                                                                                            | RORC<br>R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RORC<br>@RW0                                                                                                           | RORC<br>@RW1                                                                                                                                 | RORC<br>@RW2                                                                                                                                     | RORC<br>@RW3                                                                                                                                                                                  | RORC<br>@RW0+                                                                                                                          | @RW1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RORC<br>@RW2+                                                                                                                |  |
| Table 4.3.7 "ea" Instructions ) (First by | 1 0 | ROLC<br>@RW0+d8   | ROLC<br>@RW1+d8                                                                                                               | ROLC<br>@RW2+d8                                                                                                            | ROLC<br>@RW3+d8                                                                            | ROLC<br>@RW4+d8                                                                                                 | ROLC<br>@RW5+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ROLC<br>@RW6+d8                                                                                                                    | ROLC<br>@RW7+d8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                        |                                                                                                                                              |                                                                                                                                                  |                                                                                                                                                                                               | ' N'                                                                                                                                   | ROLC<br>@RW1+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ROLC<br>@PC+d16                                                                                                              |  |
| 4.3.7 "                                   | 0 0 | ROLC<br>R0        | ROLC<br>R1                                                                                                                    | ROLC<br>R2                                                                                                                 | ROLC<br>R3                                                                                 | ROLC<br>R4                                                                                                      | ROLC<br>R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ROLC<br>R6                                                                                                                         | ROLC<br>R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ROLC                                                                                                                   | ROLC<br>@RW1                                                                                                                                 | ROLC<br>@RW2                                                                                                                                     | ROLC<br>@RW3                                                                                                                                                                                  | ROLC<br>@RW0+                                                                                                                          | ROLC<br>@RW1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ROLC<br>@RW2+                                                                                                                |  |
| e                                         |     | 0+                | +                                                                                                                             | +2                                                                                                                         | +3                                                                                         | +4                                                                                                              | +5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9+                                                                                                                                 | +7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8+                                                                                                                     | 6+                                                                                                                                           | +A                                                                                                                                               | 4B                                                                                                                                                                                            | о<br>+                                                                                                                                 | q                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Щ                                                                                                                            |  |

Table 4.3.8 "ea" Instructions ( (First byte = 73H)

|         | 0.0            | 1 0                         | 2 0                  | 3.0                             | 4 0           | 5 0              | 60            | 7 0               | 8 0                 | 06                  | A 0                          | B 0                                  | C 0               | D 0                                | E 0              | FΟ                  |
|---------|----------------|-----------------------------|----------------------|---------------------------------|---------------|------------------|---------------|-------------------|---------------------|---------------------|------------------------------|--------------------------------------|-------------------|------------------------------------|------------------|---------------------|
| г       | JMP            | © 1MP                       | CALL                 | LL - CALL                       | INCW          | INCW             | DECW          | - DECW            | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | 1 MOVW @RW                         | XCHW             | XCHW A,             |
| 0+      | @RW0           | @RW0 - @@RW0+d8             | @RW0                 | @RW0 - @@RW0+d8                 | RW0           | @RW0+d8          | RW0           | - @RW0+d8         | A, RW0              | @RW0+d8             | RW0, A                       | W0+d8, A                             | RW0, #16          | 0+d8, #16                          | A, RW0           | @RW0+d8             |
| +       | JMP<br>@RW1    | @RW1 - @@RW1+d8             | CALL<br>@RW1         | LL CALL<br>@RW1 @@RW1+d8        | INCW<br>RW1   | INCW<br>@RW1+d8  | DECW<br>RW1   | DECW<br>@RW1+d8   | MOVW A, RW1         | MOVW A,<br>@RW1+d8  | MOVW<br>RW1, A               | MOVW @R<br>W1+d8, A                  | MOVW<br>RW1, #16  | NW MOVW @RW<br>RW1, #16, 1+d8, #16 | XCHW<br>A, RW1   | XCHW A,<br>@RW1+d8  |
| +2      | JMP 08.W2      | <br>JMP<br>@@RW2+d8         | CALL<br>CALL<br>@RW2 |                                 | INCW<br>RW2   | INCW<br>@RW2+d8  | DECW<br>RW2   | DECW<br>0 @RW2+d8 | MOVW<br>A, RW2      | @RW2+d8             | MOVW<br>RW2, A               | MOVW @R<br>W2+d8, A                  | MOVW<br>RW2, #16  | MOVW @RW<br>2+d8, #16              | XCHW<br>A, RW2   | XCHW A,<br>@RW2+d8  |
| ۲       | JMP            | @RW3 @@RW3+d8               | CALL                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | MOVW @RW                           | XCHW             | XCHW A,             |
| ۴       | @RW3           |                             | @RW3                 | @@RW3+d8                        | RW3           | @RW3+d8          | RW3           | @RW3+d8           | A, RW3              | @RW3+d8             | RW3, A                       | W3+d8, A                             | RW3, #16          | 3+d8, #16                          | A, RW3           | @RW3+d8             |
| 4+      | JMP<br>@RW4    | @RW4 @@RW4+d8               | CALL<br>@RW4         | CALL<br>@@RW4+d8                | INCW<br>RW4   | INCW<br>@RW4+d8  | DECW<br>RW4   | DECW<br>@RW4+d8   | MOVW<br>A, RW4      | MOVW A,<br>@RW4+d8  | MOVW<br>RW4, A               | MOVW @R<br>W4+d8, A                  | MOVW<br>RW4, #16  | MOVW @RW<br>4+d8, #16              | XCHW<br>A, RW4   | XCHW A,<br>@RW4+d8  |
| -+5     | JMP            | ©                           | CALL                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | MOVW @RW                           | XCHW             | XCHW A,             |
| J       | @RW5           |                             | @RW5                 | @@RW5+d8                        | RW5           | @RW5+d8          | RW5           | @RW5+d8           | A, RW5              | @RW5+d8             | RW5, A                       | W5+d8, A                             | RW5, #16          | 5+d8, #16                          | A, RW5           | @RW5+d8             |
| 9+      | JMP            | P JMP                       | CALL                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | MOVW @RW                           | XCHW             | XCHW A,             |
|         | @RW6           | @RW6 @@RW6+d8               | @RW6                 | @@RW6+d8                        | RW6           | @RW6+d8          | RW6           | @RW6+d8           | A, RW6              | @RW6+d8             | RW6, A                       | W6+d8, A                             | RW6, #16          | 6+d8, #16                          | A, RW6           | @RW6+d8             |
| ۲       | JMP            | JMP                         | CALL                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | MOVW @RW                           | XCHW             | XCHW A,             |
| ۲       | @RW7           | @@RW7+d8                    | @RW7                 | @@RW7+d8                        | RW7           | @RW7+d8          | RW7           | @RW7+d8           | A, RW7              | @RW7+d8             | RW7, A                       | W7+d8, A                             | RW7, #16          | 7+d8, #16                          | A, RW7           | @RW7+d8             |
| -<br>8+ | JMP<br>@@RW0   | a@RW0 @@RW0+d16             |                      | CALL<br>@@RW0+d16               | INCW<br>@RW0  | INCW<br>@RW0+d16 | DECW<br>@RW0  | DECW<br>@RW0+d16  | 2                   | MOVW A,<br>@RW0+d16 | MOVW<br>@RW0, A              | MOVW @R<br>W0+d16, A                 | MOVW<br>@RW0, #16 | MOVW@RW0<br>+d16, #16              | XCHW<br>A, @RW0  | XCHW A,<br>@RW0+d16 |
| р       | JMP            | 4P JMP                      | CALL                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | @RW1+d16            | MOVW                         | MOVW @R                              | MOVW              | MOVW@RW1                           | XCHW             | XCHW A,             |
| 6+      | @@RW1          | @@RW1   @@RW1+d16           | @@RW1                | @@RW1+d16                       | @RW1          | @RW1+d16         | @RW1          | @RW1+d16          | A, @RW1             |                     | @RW1. A                      | W1+d16, A                            | @RW1, #16         | +d16, #16                          | A, @RW1          | @RW1+d16            |
| ۲       | JMP            | AP 'JMP                     | 0RW2                 | CALL                            | INCW          | INCW             | DECW          | DECW              | MOVW                | MOVW A,             | MOVW                         | MOVW @R                              | MOVW              | MOVW@ RW2 XCHW                     | 2 XCHW           | XCHW A,             |
| ۲       | @@RW2          | @@RW2 '@@RW2+d16            |                      | @@RW2+d16                       | @RW2          | @RW2+d16         | @RW2          | @RW2+d16          | A, @RW2             | @RW2+d16            | @RW2, A                      | W2+d16, A                            | @RW2, #16         | +d16, #16 A, @F                    | A, @RW2          | @RW2+d16            |
| -9      | JMP            | MP 'JMP                     | CALL                 | CALL CALL                       | INCW          | INCW             | DECW          | DECW              | MOVW                | @RW3+d16            | MOVW                         | MOVW @R                              | MOVW              | MOVW @RW3 XCHW                     | 3 XCHW           | XCHW A,             |
|         | @@RW3          | @@RW3 '@@RW3+d16            | @@RW3                | @@RW3 @@RW3+d16                 | @RW3          | @RW3+d16         | @RW3          | @RW3+d16          | A, @RW3             |                     | @RW3, A                      | W3+d16, A                            | @RW3, #16         | +d16, #16 A, @F                    | A, @RW3          | @RW3+d16            |
| ų       | JMP<br>@@RW0+' | MP JMP<br>@@RW0+'@@RW0+RW7  | CALL<br>@@RW0+       |                                 | INCW<br>@RW0+ | INCW<br>@RW0+RW7 | DECW<br>@RW0+ | DECW<br>@RW0+RW7  | MOVW<br>A, @RW0+'   | @RW0+RW7            | MOVW<br>@RW0+, A             | @RW0+, A W0+RW7, A                   | MOVW<br>RW0+,     | @   MOVW@RW0<br>#16' +RW7, #16     | XCHW<br>A, @RW0+ | XCHW A,<br>@RW0+RW7 |
| -<br>P  | JMP<br>@@RW1+  | MP 'JMP<br>@@RW1+'@@RW1+RW7 | CALL<br>@@RW1+       |                                 | INCW<br>@RW1+ | @RW1+RW7         | DECW<br>@RW1+ | DECW<br>@RW1+RW7  | MOVW<br>A, @RW1+    | MOVW A,<br>@RW1+RW7 | @RW1+, A                     | 00VW - MOVW @R<br>@RW1+, A W1+RW7, A | MOVW<br>RW1+,     | 2 + '                              | A, @RW1+         | XCHW A,<br>@RW1+RW7 |
| ų       | JMP<br>@@RW2+  | MP 'JMP<br>@@RW2+'@@PC+d16  | CALL<br>@@RW2+       | ALL · CALL<br>@@RW2+ · @@PC+d16 | INCW<br>@RW2+ | INCW<br>@PC+d16  | DECW<br>@RW2+ | DECW<br>@PC+d16   | MOVW -1<br>A, @RW2+ | MOVW A,             | MOVW MOVW<br>@RW2+, A C+d16, | MOVW @R<br>C+d16, A                  | MOVW<br>RW2+,     | @ MOVW @PC<br>#16' +d16, #16       | XCHW<br>A, @RW2+ | XCHW A,<br>@PC+d16  |
| ч       | JMP J          | JMP                         | CALL iC              | CALL                            | INCW          | INCW             | DECW          | DEC               | MOVW 1              | MOVW A,             | MOVW                         | MOVW                                 | MOVW @ 1          | MOVW ad                            | XCHW             | XCHW A,             |
| +       | @@RW3+'        | @addr16                     | @@RW3+               | @addr16                         | @RW3+         | addr16           | @RW3+         | addr16            | A, @RW3+            | addr16              | @RW3+, A                     | addr16, A                            | RW3+, #16         | dr16, #16                          | A, @RW3+         | addr16              |

|        | 0 0               | 1 0                               | 2 0             | 3.0                | 40               | 50                  | 60              | 7 0                | 8 0             | 06                   | A 0            | ВO                | C 0             | DO                 | E 0              | ΕO                   |
|--------|-------------------|-----------------------------------|-----------------|--------------------|------------------|---------------------|-----------------|--------------------|-----------------|----------------------|----------------|-------------------|-----------------|--------------------|------------------|----------------------|
| 0+     | ADD<br>A, R0      | +ADD A,<br>@RW0+d8                | SUB<br>A, R0    | +SUB A,<br>@RW0+d8 | ADDC<br>A, R0    | ADDC A,<br>@RW0+d8  | CMP<br>A, R0    | CMP A,<br>@RW0+d8  | RO              | AND A,<br>@RW0+d8    | 80             | OR A,<br>@RW0+d8  | XOR<br>A, R0    | XOR A,<br>@RW0+d8  | DBNZ<br>R0, r    | DBNZ @<br>RW0+d8, r  |
| ÷      | ADD<br>A, R1      | ADD A,<br>@RW1+d8                 | SUB<br>A, R1    |                    | ADDC<br>A, R1    | ADDC A,<br>@RW1+d8  | CMP<br>A, R1    | CMP A,<br>@RW1+d8  | AND<br>A, R1    | AND A,<br>@RW1+d8    | 2              | OR A,<br>@RW1+d8  | XOR<br>A, R1    |                    | DBNZ<br>R1, r    | DBNZ @<br>RW1+d8, r  |
| +2     | ADD<br>A, R2      | ADD A,<br>@RW2+d8                 | SUB<br>A, R2    |                    | ADDC<br>A, R2    | ADDC A,<br>@RW2+d8  | CMP<br>A, R2    | CMP A,<br>@RW2+d8  | AND<br>A, R2    | AND A,<br>@RW2+d8    | OR<br>A, R2    | OR A,<br>@RW2+d8  | XOR<br>A, R2    | ~                  | DBNZ             | DBNZ @<br>RW2+d8, r  |
| +<br>+ | ADD<br>A, R3      | ADD A,<br>@RW3+d8                 | SUB<br>A, R3    | SUB A,<br>@RW3+d8  | ADDC<br>A, R3    | ADDC A,<br>@RW3+d8  | CMP<br>A, R3    | CMP A,<br>@RW3+d8  | AND<br>A, R3    | ND A,<br>@RW3+d8     | OR<br>A, R3    | OR A,<br>@RW3+d8  | XOR<br>A, R3    | XOR<br>@RW         |                  | DBNZ @<br>RW3+d8, r  |
| +      |                   | ADD A,<br>@RW4+d8                 | SUB<br>A, R4    | SUB A,<br>@RW4+d8  | ADDC<br>A, R4    | ADDC A,<br>@RW4+d8  | CMP<br>A, R4    | CMP A,<br>@RW4+d8  | AND<br>A, R4    | ND A,<br>@RW4+d8     | OR<br>A, R4    | OR A,<br>@RW4+d8  | XOR<br>A, R4    | XOR<br>@RV         |                  | DBNZ @<br>RW4+d8, r  |
| +5     | ADD<br>A, R5      | ADD A,<br>@RW5+d8                 | SUB<br>A, R5    | SUB A,<br>@RW5+d8  | ADDC<br>A, R5    | ADDC A,<br>@RW5+d8  | CMP<br>A, R5    | CMP A,<br>@RW5+d8  | AND<br>A, R5    | ND A,<br>@RW5+d8     | OR<br>A, R5    | OR A,<br>@RW5+d8  | XOR<br>A, R5    |                    | DBNZ<br>R5, r    | DBNZ @<br>RW5+d8, r  |
| 9+     | ADD<br>A, R6      | ADD A,<br>@RW6+d8                 | SUB<br>A, R6    | SUB A,<br>@RW6+d8  | ADDC<br>A, R6    | ADDC A,<br>@RW6+d8  | CMP<br>A, R6    | CMP A,<br>@RW6+d8  | AND<br>A, R6    | ND A,<br>@RW6+d8     | OR<br>A, R6    | OR A,<br>@RW6+d8  | XOR<br>A, R6    | XOR A,<br>@RW6+d8  | DBNZ<br>R6, r    | DBNZ @<br>RW6+d8, r  |
| 7+     | ADD<br>A, R7      | ADD A,<br>@RW7+d8                 | SUB<br>A, R7    | SUB A,<br>@RW7+d8  | ADDC<br>A. R7    | ADDC A,<br>@RW7+d8  | CMP<br>A, R7    | CMP A,<br>@RW7+d8  | AND<br>A, R7    | ND A,<br>@RW7+d8     | OR<br>A, R7    | OR A,<br>@RW7+d8  | XOR<br>A, R7    | XOR A,<br>@RW7+d8  | DBNZ<br>R7, r    | DBNZ @<br>RW7+d8, r  |
| 8+     | ADD<br>A, @RW0    | ADD A,<br>@RW0+d16                | SUB<br>A, @RW0  | SUB A,<br>@RW0+d16 | ADDC<br>A, @RW0  | ADDC A,<br>@RW0+d16 | CMP<br>A, @RW0  | CMP A,<br>@RW0+d16 | AND<br>A, @RWO  | ND A,<br>@RW0+d16    | OR<br>A, @RW0  | OR A,<br>@RW0+d16 | XOR<br>A, @RW0  | XOR A,<br>@RW0+d16 | DBNZ<br>@RW0, r  | DBNZ @<br>RW0+d16, r |
| 6+     | ADD<br>A, @RW1    | ADD A,<br>@RW1+d16                | SUB<br>A, @RW1  | SUB A,<br>@RW1+d16 | ADDC<br>A, @RW1  | ADDC A,<br>@RW1+d16 | CMP<br>A, @RW1  | CMP A,<br>@RW1+d16 | AND<br>A, @RW1  | ND A,<br>@RW1+d16    | OR<br>A, @RW1  | OR A,<br>@RW1+d16 | XOR<br>A, @RW1  | XOR A,<br>@RW1+d16 | DBNZ<br>@RW1, r  | DBNZ @<br>RW1+d16, r |
| +A     | ADD<br>A, @RW2    | ADD A,<br>@RW2+d16                | SUB<br>A, @RW2  | SUB A,<br>@RW2+d16 | ADDC<br>A, @RW2  | ADDC A,<br>@RW2+d16 | CMP<br>A, @RW2  | CMP A,<br>@RW2+d16 | AND<br>A, @RW2  | ND A,<br>@RW2+d16    | OR<br>A, @RW2  | OR A,<br>@RW2+d16 | XOR<br>A, @RW2  | XOR A,<br>@RW2+d16 | DBNZ<br>@RW2, r  | DBNZ @<br>RW2+d16, r |
| +<br>B | ADD<br>A, @RW3    |                                   | SUB<br>A, @RW3  | SUB A,<br>@RW3+d16 |                  | ADDC A,<br>@RW3+d16 | CMP<br>A, @RW3  | CMP A,<br>@RW3+d16 | AND<br>A, @RW3  | AND A,<br>@RW3+d16   | JR<br>A, @RW3  | OR A,<br>@RW3+d16 | XOR<br>A, @RW3  |                    | DBNZ<br>@RW3, r  | DBNZ @<br>RW3+d16, r |
| ų      | ADD<br>A, @RW0+   | ADD A,<br>@RW0+RW7                | SUB<br>A, @RW0+ | SUB A,<br>@RW0+RW7 | ADDC<br>A, @RW0+ | ADDC A,<br>@RW0+RW7 | CMP<br>A, @RW0+ | @RW0+RW7           | AND<br>A, @RW0+ | ND A,<br>@RW0+RW7    | )R<br>A, @RW0+ | OR A,<br>@RW0+RW7 | XOR<br>A, @RW0+ |                    | DBNZ<br>@RW0+, r | DBNZ @<br>RW0+RW7, r |
| Ą      | ADD<br>A, @RW1+   | ADD 'ADD A,<br>A, @RW1+ '@RW1+RW7 | SUB<br>A, @RW1+ | SUB A,<br>@RW1+RW7 | ADDC<br>A, @RW1+ | @RW1+RW7            | CMP<br>A, @RW1+ | @RW1+RW7           | AND<br>A, @RW1+ | AND A,<br>@RW1+RW7   | OR<br>A, @RW1+ | 0R<br>® RW        | XOR<br>A, @RW1+ | XOR A,<br>@RW1+RW7 | DBNZ<br>@RW1+, r | DBNZ @<br>RW1+RW7, r |
| Ŧ      | ADD<br>A, @RW2+   | ADD A,<br>@PC+d16                 | SUB<br>A, @RW2+ |                    | ADDC<br>A, @RW2+ | ADDC A,<br>@PC+d16  | CMP<br>A, @RW2+ | CMP A,<br>@PC+d16  | AND<br>A, @RW2+ | AND A,<br>24 @PC+d16 | OR<br>A, @RW2+ | OR A,<br>@ PC+d16 | XOR<br>A, @RW2+ | XOR A,<br>@PC+d16  | DBNZ<br>@RW2+, r | @ PC+d16, r          |
| Ļ      | ADD<br>A, @RW3+ 1 | ADD A,<br>addr16                  | SUB<br>A, @RW3+ | SUB A,<br>addr16   | ADDC<br>A, @RW3+ | ADDC A,<br>addr16   | CMP<br>A, @RW3+ | CMP A,<br>addr16   | RW3             | AND A,<br>addr16     | OR<br>A, @RW3+ | OR<br>addr1       | XOR<br>A, @RW3+ | XOR A,<br>addr16   | DBNZ<br>@RW3+, r | DBNZ<br>addr16, r    |

Table 4.3.9 "ea" Instructions ) (First byte = 74H)

228

Table 4.3.10 "ea" Instructions < (First byte = 75H)

| F 0 | NOT<br>@RW0+d8        | NOT<br>@RW1+d8     | ©RW2+d8            | NOT<br>@RW3+d8     | NOT<br>@RW4+d8        | NOT<br>@RW5+d8     | NOT<br>@RW6+d8        | @RW7+d8            | NOT<br>@RW0+d16     | @RW1+d16            | NOT<br>@RW2+d16     | NOT<br>@RW3+d16                    | NOT<br>@RW0+RW7                     |                                      | NOT<br>@ PC+d16                    |                    |
|-----|-----------------------|--------------------|--------------------|--------------------|-----------------------|--------------------|-----------------------|--------------------|---------------------|---------------------|---------------------|------------------------------------|-------------------------------------|--------------------------------------|------------------------------------|--------------------|
| E 0 | NOT<br>R0             | NOT<br>R1          | NOT R2             | NOT<br>R3          | NOT<br>R4             | NOT<br>R5          | NOT<br>R6             | NOT R7             | NOT<br>@RW0         | ®RW1                | NOT<br>@RW2         | NOT<br>@RW3                        | 00T<br>@RW0+                        | 00T<br>@RW1+                         | NOT<br>@RW2+                       | NOT<br>@RW3+       |
| 0 Q | XOR @R<br>W0+d8, A    | XOR @R<br>W1+d8, A | XOR @R<br>W2+d8, A | XOR @R<br>W3+d8, A | XOR @R<br>W4+d8, A    | XOR @R<br>W5+d8, A | XOR @R<br>W6+d8, A    | XOR @R<br>W7+d8, A | XOR @R<br>W0+d16, A | XOR @R<br>W1+d16, A | XOR @R<br>W2+d16, A | XOR @R<br>W3+d16, A                | XOR @R<br>W0+RW7, A                 | XOR @R<br>W1+RW7, A                  | XOR @P NOT<br>C+d16, A @RW2+       | XOR<br>addr16, A   |
| C 0 | XOR<br>R0, A          | XOR<br>R1, A       | XOR<br>R2, A       | XOR<br>R3, A       | XOR<br>R4, A          | XOR<br>R5, A       | XOR<br>R6, A          | XOR<br>R7, A       | XOR<br>@RW0, A      | XOR<br>@RW1, A      | XOR<br>@RW2, A      | XOR<br>@RW3, A                     | XOR<br>@RW0+, A                     | XOR<br>@RW1+, A                      | XOR<br>@RW2+, A                    | XOR<br>@RW3+, A    |
| BO  | i OR<br>i @RW0+d8, A  | OR<br>@RW1+d8, A   | OR<br>@RW2+d8, A   |                    | OR<br>@RW4+d8, A      | OR<br>@RW5+d8, A   | OR<br>@RW6+d8, A      | OR<br>@RW7+d8, A   | OR<br>@RW0+d16, A   | RW1. A @RW1+d16, A  | OR<br>@RW2+d16, A   | ' OR<br>@RW3+d16, A                | OR @R<br>W0+RW7, A                  | OR @R<br>W1+RW7, A                   | -OR @P<br>\ @PC+d16, A             | ⁺OR<br>\ addr16, A |
| A 0 | OR<br>R0, A           | R<br>R1, A         | R                  | OR<br>R3, A        | R OR<br>R4, A         | OR<br>R5, A        | OR<br>R6, A           | OR<br>R7, A        | OR<br>@RW0, /       | OR<br>08<br>@RW1. A | OR<br>@RW2, A       | OR<br>@RW3, A                      | OR<br>@RW0+, /                      | OR<br>@RW1+, /                       | OR<br>@RW2+, /                     | OR<br>@RW3+, /     |
| 06  | AND @R<br>W0+d8, A    | AND @R<br>W1+d8, A | AND @R<br>W2+d8, A | AND @R<br>W3+d8, A | AND @F<br>W4+d8, A    | AND @F<br>W5+d8, A | AND @F<br>W6+d8, A    | AND @F<br>W7+d8, A | AND @F<br>W0+d16, A | AND @F<br>W1+d16, A | AND @F<br>W2+d16, A | AND @F<br>W3+d16, A                | AND @F<br>W0+RW7, A                 | AND @F<br>W1+RW7, A                  | AND @F<br>C+d16, A                 | AND<br>addr16, A   |
| 8 0 | AND<br>R0, A          | AND<br>R1, A       | AND<br>R2, A       | AND<br>R3, A       | AND<br>R4, A          | AND<br>R5, A       | AND<br>R6, A          | AND<br>R7, A       | AND<br>@RW0, A      | and<br>@RW1, A      | AND<br>@RW2, A      | AND<br>@RW3, A                     | and<br>@RW0+, A                     | AND<br>@RW1+, A                      | AND<br>@RW2+, A                    | AND<br>@RW3+, A    |
| 7 0 | NEG<br>@RW0+d8        | NEG<br>@RW1+d8     | NEG<br>@RW2+d8     | NEG<br>@RW3+d8     | NEG<br>@RW4+d8        | NEG<br>@RW5+d8     | NEG<br>@RW6+d8        | NEG<br>@RW7+d8     | NEG<br>@RW0+d16     |                     | NEG<br>@RW2+d16     | NEG<br>@RW3+d16                    | NEG<br>@RW0+RW7                     | NEG<br>@RW1+RW7                      | NEG<br>@PC+d16                     | NEG<br>addr16      |
| 6 0 | NEG<br>R0             | NEG<br>R1          | NEG R2             | NEG<br>R3          | NEG<br>R4             | NEG<br>R5          | NEG<br>R6             | NEG                | NEG<br>@RW0         |                     | NEG<br>@RW2         |                                    |                                     | NEG<br>@RW1+                         | NEG<br>@RW2+                       | NEG<br>@RW3+       |
| 5 0 | SUBC A,<br>@RW0+d8    | SUBC A,<br>@RW1+d8 | ©RW2+d8            | SUBC A,<br>@RW3+d8 | SUBC A,<br>@RW4+d8    | SUBC A,<br>@RW5+d8 | SUBC A,<br>@RW6+d8    | ©RW7+d8            | SUBC A,<br>@RW0+d16 | ©RW1+d16            | SUBC A,<br>@RW2+d16 | SUBC A,<br>@RW3+d16                | SUBC A,<br>@RW0+RW7                 | SUBC A,<br>@RW1+RW7                  | SUBC A,<br>@PC+d16                 | SUBC A,<br>addr16  |
| 4 0 | SUBC<br>A, R0         | SUBC<br>A, R1      | SUBC<br>A, R2      | SUBC<br>A, R3      |                       | SUBC<br>A, R5      | SUBC<br>A, R6         | SUBC<br>A, R7      |                     | SUBC<br>A, @RW1     | - <u> </u>          |                                    |                                     | SUBC<br>A, @RW1+                     |                                    | SUBC<br>A, @RW3+   |
| 3.0 | -SUB @R<br>- W0+d8, A | SUB @R<br>W1+d8, A | SUB @R<br>W2+d8, A | SUB @R<br>W3+d8, A | SUB @R<br>W4+d8, A    | SUB @R<br>W5+d8, A | SUB @R<br>W6+d8, A    | SUB @R<br>W7+d8, A |                     | SUB<br>W1+d1        | SUB<br>W2+d1        | SUB 'SUB @R<br>@RW3, A ' W3+d16, A | ©RW0+, A'W0+RW7, A                  | UB 'SUB @R<br>@RW1+, A' W1+RW7, A    | UB 'SUB @P<br>@RW2+, A' C+d16, A   | SUB<br>N addr16, A |
| 2 0 | SUB<br>R0, A          | SUB<br>R1, A       | SUB<br>R2, A       | SUB<br>R3, A       | @R SUB<br>A R4, A     | t SUB<br>R5, A     | sub<br>R6, A          | SUB<br>R7, A       | SUB<br>@RW0, A      |                     | SUB<br>@RW2, /      | SUB<br>@RW3, A                     | SUB<br>@RW0+, A                     | SUB<br>@RW1+, A                      | SUB<br>@RW2+, A                    | SUB<br>@RW3+, A    |
| 1 0 | ADD @R<br>W0+d8, A    | ADD @R<br>W1+d8, A | ADD @R<br>W2+d8, A | ADD @R<br>W3+d8, A | ADD @R SU<br>W4+d8, A | ADD @R<br>W5+d8, A | ADD @R SU<br>W6+d8, A | ADD @R<br>W7+d8, A | ADD @R<br>W0+d16, A | ADD @R<br>W1+d16, A | ~                   |                                    | (DD 'ADD @R<br>@RW0+, A ' W0+RW7, A | (DD + ADD @R<br>@RW1+, A + W1+RW7, A | ADD @P<br>C+d16, A                 | ADD<br>addr16, A   |
| 0.0 | ADD<br>R0, A          | ADD<br>R1, A       | ADD<br>R2, A       | ADD<br>R3, A       | ADD<br>R4, A          | ADD<br>R5, A       | , A ,                 | ADD<br>R7, A       | DD<br>@RW0, A       | <br>DD<br>@RW1, A   | DD<br>@RW2, A       | DD<br>@RW3, A                      | ADD<br>@RW0+, A                     | ADD<br>@RW1+, A                      | ADD + ADD (<br>@RW2+, A + C+d16, A | ADD<br>@RW3+, A    |
|     | 0+                    | +۱                 | +2                 | +3                 | +4                    | +5                 | 9+                    | 7+                 | 8+                  | 6+                  | +A                  | 8+                                 | 4C                                  | Q+                                   | ų                                  | ¥+<br>+            |

Table 4.3.11 "ea" Instructions > (First byte = 76H)

230

|        | 00               | 10                  | 00                  | 3.0                               | 40                   | 50                   | 60                           | 7.0                          | 08               | 0.0                 | A 0                        | C R                 | 00               |                     | 0<br>E            | C<br>L                |
|--------|------------------|---------------------|---------------------|-----------------------------------|----------------------|----------------------|------------------------------|------------------------------|------------------|---------------------|----------------------------|---------------------|------------------|---------------------|-------------------|-----------------------|
| ç      | ADDW             | ADDW A,             | MBUS                |                                   | N                    | ADDCW A,             | CMPW                         | CMPW A,                      | ANDW             | ANDW A,             | ORW                        | ORW A               | XORW             | XORW A,             | DWB               | DWBNZ @               |
| 0+     | A, RW0           | - @RW0+d8           | A, RWO              | @ RW0+d8                          | A, RW0-              | @RW0+d8              | A, RW0                       | @RW0+d8                      | A, RW0-          | @ RW0+d8            | A, RW0                     | @RW0+d8             | A, RWO           | @ RW0+d8            | RW0, r            | RW0+d8, r             |
| +      | ADDW<br>A, RW1   | ADDW A,<br>@RW1+d8  | SUBW SUBW SUBW      | SUBW A,<br>@RW1+d8                | ADDCW<br>A, RW1      | ADDCW A,<br>@RW1+d8  | CMPW<br>A, RW1               | CMPW A,<br>@RW1+d8           | ANDW<br>A, RW1   | ANDW A,<br>@RW1+d8  | ORW<br>A, RW1              | ORW A.<br>@RW1+d8   | XORW<br>A, RW1   | XORW A,<br>@RW1+d8  | DWBNZ<br>RW1, r   | DWBNZ @<br>RW1+d8, r  |
| +2     | ADDW<br>A, RW2   | ADDW A, @RW2+d8     |                     | ·                                 | ADDCW<br>A, RW2      | ADDCW A,<br>@RW2+d8  | CMPW A, RW2                  | CMPW A,<br>@RW2+d8           | ANDW<br>A, RW2   | @RW2+d8             | ORW<br>A, RW2              | ORW A<br>@RW2+d8    | XORW<br>A, RW2   | XORW A,<br>@RW2+d8  | DWBNZ<br>RW2, r   | DWBNZ @<br>RW2+d8, r  |
| +      | ADDW<br>A, RW3   | ADDW A,<br>@RW3+d8  | SUBW SUBW SI A, KW3 | SUBW A,<br>@RW3+d8                | ADDCW<br>A, RW3      | ADDCW A,<br>@RW3+d8  | CMPW A, RW3                  | CMPW A,<br>@RW3+d8           | ANDW<br>A, RW3   | @RW3+d8             | ORW<br>A, RW3              | A<br>ORW<br>@RW3+d8 | XORW<br>A, RW3   | XORW A,<br>@RW3+d8  | DWBNZ<br>RW3, r   | DWBNZ @<br>RW3+d8, r  |
| +4     | ADDW<br>A, RW4   | ADDW A,<br>@RW4+d8  | SUBW<br>A, RW4      | SUBW A,<br>@RW4+d8                | ADDCW<br>A, RW4      | ADDCW A,<br>@RW4+d8  | CMPW<br>A, RW4               | CMPW A,<br>@RW4+d8           | ANDW<br>A, RW4   | ANDW A,<br>@RW4+d8  | ORW<br>A, RW4              | ORW A<br>@RW4+d8    | XORW<br>A, RW4   | XORW A,<br>@RW4+d8  | DWBNZ<br>RW4, r   | DWBNZ @<br>RW4+d8, r  |
| +5     | ADDW<br>A, RW5   | ADDW A,<br>@RW5+d8  | SUBW<br>A, RW5      | SUBW A,<br>@RW5+d8                | ADDCW<br>A, RW5      | ADDCW A,<br>@RW5+d8  | CMPW<br>A, RW5               | CMPW A,<br>@RW5+d8           | ANDW<br>A, RW5   | aNDW A,<br>@RW5+d8  | ORW<br>A, RW5              | ORW A<br>@RW5+d8    | XORW<br>A, RW5   | XORW A,<br>@RW5+d8  | DWBNZ<br>RW5, r   | DWBNZ @<br>RW5+d8, r  |
| 9+     | ADDW<br>A, RW6   | ADDW A,<br>@RW6+d8  | SUBW<br>A, RW6      | SUBW A,<br>@RW6+d8                | ADDCW<br>A, RW6      | ADDCW A,<br>@RW6+d8  | CMPW<br>A, RW6               | CMPW A,<br>@RW6+d8           | ANDW<br>A, RW6   | @RW6+d8             | ORW<br>A, RW6              | ORW A.<br>@RW6+d8   | XORW<br>A, RW6   | XORW A,<br>@RW6+d8  | DWBNZ<br>RW6, r   | DWBNZ @<br>RW6+d8, r  |
| 2+     | ADDW<br>A, RW7   | ADDW A,<br>@RW7+d8  | SUBW<br>A, RW7      |                                   | ADDCW<br>A, RW7      | ADDCW A,<br>@RW7+d8  | CMPW<br>A, RW7               | CMPW A,<br>@RW7+d8           | ANDW<br>A, RW7   | @RW7+d8             | ORW<br>A, RW7              | ORW A.<br>@RW7+d8   | XORW<br>A, RW7   | XORW A,<br>@RW7+d8  | DWBNZ<br>RW7, r   | DWBNZ @<br>RW7+d8, r  |
| 8+     | ADDW<br>A, @RW0  | ADDW A,<br>@RW0+d16 | SUBW<br>A, @RW0     |                                   | ADDCW<br>A, @RWq     | ADDCW A,<br>@RW0+d16 | CMPW<br>A, @RW¢              | CMPW A,<br>@RW0+d16          | ANDW<br>A, @RWd  | ANDW A,<br>@RW0+d16 | ORW<br>A, @RW0             | ORW A.<br>@RW0+d16  | ×                | XORW A,<br>@RW0+d16 | DWBNZ<br>@RW0, r  | DWBNZ @R<br>W0+d16, r |
| 6+     | ADDW<br>A, @RW1  | _ <                 | SUBW<br>A, @RW1     | SUBW A,<br>@RW1+d16               | ¦-`-,                | ADDCW A,<br>@RW1+d16 | CMPW<br>A, @RW1              | CMPW A,<br>@RW1+d16          | ANDW<br>A, @RW1  | ANDW A,<br>@RW1+d16 | ORW<br>A, @RW1             | ORW A<br>@RW1+d16   | XORW<br>A, @RW1  | XORW A,<br>@RW1+d16 | DWBNZ<br>@RW1, r  | DWBNZ @R<br>W1+d16, r |
| +      | ADDW<br>A, @RW2  | · <u>~</u>          | SUBW<br>A, @RW2     | ©RW2+0                            | ADDCW<br>A, @RW2     | ADDCW A,<br>@RW2+d16 | CMPW<br>A, @RW2              | CMPW A,<br>@RW2+d16          | ANDW<br>A, @RW2  | ANDW A,<br>@RW2+d16 | ORW<br>A, @RW2             | ORW A.<br>@RW2+d16  | XORW<br>A, @RW2  | XORW A,<br>@RW2+d16 | DWBNZ<br>@RW2, r  | DWBNZ @R<br>W2+d16, r |
| +<br>B | ADDW<br>A, @RW3  | ADDW A,<br>@RW3+d16 | SUBW<br>A, @RW3     | SUBW<br>@RW3+0                    | ADDCW ',<br>A, @RW3  | ADDCW A,<br>@RW3+d16 | W<br>@RW3                    | CMPW A,<br>@RW3+d16          | ANDW<br>A, @RW3  | ANDW A,<br>@RW3+d16 | ORW<br>A, @RW3             | ORW A.<br>@RW3+d16  |                  | XORW A,<br>@RW3+d16 | DWBNZ<br>@RW3, r  | DWBNZ @R<br>W3+d16, r |
| 0<br>+ | ADDW<br>A, @RW0+ |                     | SUBW<br>A, @RW0+    |                                   | ADDCW<br>A, @RW0+    | ADDCW A,<br>@RW0+RW7 | CMPW<br>A, @RW04             | PW CMPW A,<br>@RW04 @RW0+RW7 | ANDW<br>A, @RW0+ | ANDW A,<br>@RW0+RW7 | ORW<br>A, @RW0+            | ORW A<br>@RW0+RW7   | · ~ .            | XORW A,<br>@RW0+RW7 | DWBNZ<br>@RW0+, r | DWBNZ @R<br>W0+RW7, r |
| Q<br>+ | ADDW<br>A, @RW1+ | A) @RW1+ \@RW1+RW7  | SUBW<br>A, @RW1+    | +RW7                              | ADDCW<br>A, @RW1+    | ADDCW A,<br>@RW1+RW7 | CMPW<br>A, @RW1+             | @RW1+ @RW1+RW7               | ANDW<br>A, @RW1+ | ANDW A,<br>@RW1+RW7 | ORW<br>A, @RW1+            | ORW A.<br>@RW1+RW7  | XORW<br>A, @RW1+ | XORW A,<br>@RW1+RW7 | DWBNZ<br>@RW1+, r | DWBNZ @R<br>W1+RW7, r |
| Щ<br>+ | ADDW<br>A, @RW2+ | ADDW A,<br>@PC+d16  | SUBW<br>A, @RW2+    | SUBW SUBW A,<br>A, @RW2+' @PC+d16 | ADDCW -,<br>A, @RW2+ | ADDCW A,<br>@PC+d16  | CMPW - 0<br>A, @RW2+         | - CMPW A,<br>+ @PC+d16       | ANDW<br>A, @RW2+ | ANDW A,<br>@PC+d16  | ORW<br>A, @RW2+            | ORW A<br>@ PC+d16   | XORW<br>A, @RW2+ | XORW A,<br>@PC+d16  | DWBNZ<br>@RW2+, r | DWBNZ @<br>PC+d16, r  |
| ц<br>+ | ADDW<br>A, @RW3+ | ADDW<br>addr        | SUBW<br>A, @RW3+    | SUBW A,<br>addr16                 | ADDCW 4,<br>A, @RW3+ | ADDCW A,<br>addr16   | CMPW CMPW<br>A, @RW3+ addr16 | CMPW A,<br>addr16            | ANDW<br>A, @RW3+ | ANDW A,<br>addr16   | ORW ORW<br>A, @RW3+ addr16 | ORW A.<br>addr16    | XORW<br>A, @RW3+ | XORW A,<br>addr16   | DWBNZ<br>@RW3+, r | DWBNZ<br>addr16, r    |

4.3 Instruction Map

Chapter 4: Instructions

Table 4.3.12 "ea" Instructions ( [First byte = 77H)

|     | +d8                 | +d8                           | +d8                           | +d8                           | +d8                 | +d8                 | +d8                 | + d8                | <br>                 | d16                  | d16                  | d16                  | RW7                  | RW7                  | 16                  | 9                             |
|-----|---------------------|-------------------------------|-------------------------------|-------------------------------|---------------------|---------------------|---------------------|---------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|-------------------------------|
| ΕO  | NOTW<br>@RW0+d8     | NOTW<br>@RW1+d8               | NOTW<br>@RW2+d8               | 0 RW3+d8                      | NOTW<br>@RW4+d8     | NOTW<br>@RW5+d8     | NOTW<br>@RW6+d8     | NOTW<br>@RW7+d8     | NOTW<br>@RW0+d16     | NOTW<br>@RW1+d16     | @RW2+d16             | NOTW<br>@RW3+d16     | NOTW<br>@RW0+RW7     | NOTW<br>@RW1+RW7     | © PC+d16            | NOTW<br>addr16                |
| ЕO  | NOTW<br>RW0         | NOTW<br>RW1                   | NOTW<br>RW2                   | NOTW<br>RW3                   | NOTW<br>RW4         | NOTW<br>RW5         | NOTW<br>RW6         | NOTW<br>RW7         | NOTW<br>@RW0         | NOTW<br>@RW1         | NOTW<br>@RW2         | NOTW<br>@RW3         | NOTW<br>@RW0+        | NOTW<br>@RW1+        | NOTW<br>@RW2+       | NOTW<br>@RW3+                 |
| D 0 | XORW @R<br>W0+d8, A | XORW @R<br>W1+d8, A           | XORW @R<br>W2+d8, A           | XORW @R<br>W3+d8, A           | XORW @R<br>W4+d8, A | XORW @R<br>W5+d8, A | XORW @R<br>W6+d8, A | XORW @R<br>W7+d8, A | XORW @R<br>W0+d16, A | XORW @R<br>W1+d16, A | XORW @R<br>W2+d16, A | XORW @R<br>W3+d16, A | XORW @R<br>W0+RW7, A | XORW @R<br>W1+RW7, A | XORW @P<br>C+d16, A | XORW<br>addr16, A             |
| C 0 | XORW<br>RW0, A      | XORW<br>RW1, A                | XORW<br>RW2, A                | XORW<br>RW3, A                | XORW<br>RW4, A      | XORW<br>RW5, A      | XORW<br>RW6, A      | XORW<br>RW7, A      | XORW A               | XORW<br>@RW1, A      | XORW<br>@RW2, A      | XORW<br>@RW3, A      | XORW<br>@RW0+, A     | XORW<br>@RW1+, A     | XORW<br>@RW2+, A    | XORW<br>@RW3+, A              |
| BO  | ORW @R<br>W0+d8, A  | ORW @R<br>W1+d8, A            | ORW @R<br>W2+d8, A            | ORW @R<br>W3+d8, A            | ORW @R<br>W4+d8, A  | ORW @R<br>W5+d8, A  | ORW @R<br>W6+d8, A  | ORW @R<br>W7+d8, A  | ORW @R<br>W0+d16, A  | ORW @R<br>W1+d16, A  | ORW @R<br>W2+d16, A  | ORW @R<br>W3+d16, A  | ORW @R<br>W0+RW7, A  | ORW @R<br>W1+RW7, A  | ORW @P<br>C+d16, A  | ORW<br>addr16, A              |
| A 0 | ORW<br>RW0, A       | ORW<br>RW1, A                 | OWR<br>RW2, A                 | ORW<br>RW3, A                 | ORW<br>RW4, A       | ORW<br>RW5, A       | ORW<br>RW6, A       | ORW<br>RW7, A       | ORW<br>@RW0, A       | ORW<br>@RW1, A       | ORW<br>@RW2, A       | ORW<br>@RW3, A       | ORW<br>@RW0+, A      | ORW<br>@RW1+, A      | ORW<br>@RW2+, A     | ORW<br>@RW3+, A               |
| 0 6 | ANDW @R<br>W0+d8, A | ANDW @R<br>W1+d8, A           | ANDW @R<br>W2+d8, A           | DW ANDW @R<br>RW3, A W3+d8, A | ANDW @R<br>W4+d8, A | ANDW @R<br>W5+d8, A | ANDW @R<br>W6+d8, A | ANDW @R<br>W7+d8, A | @RW0, A W0+d16, A    | ANDW @R<br>W1+d16, A | ANDW @R<br>W2+d16, A | ANDW @R<br>W3+d16, A | ANDW @R<br>W0+RW7, A | ANDW @R<br>W1+RW7, A | ANDW @P<br>C+d16, A | ANDW<br>addr16, A             |
| 8 0 | ANDW<br>RW0, A      | ANDW<br>RW1, A                | ANDW<br>RW2, A                | ANDW<br>RW3, A                | ANDW<br>RW4, A      | ANDW<br>RW5, A      | ANDW<br>RW6, A      | ANDW<br>RW7, A      | ANDW<br>@RW0, A      | ANDW<br>@RW1, A      | ANDW<br>@RW2, A      | ANDW<br>@RW3, A      | ANDW<br>@RW0+, A     | ANDW<br>@RW1+, A     | ANDW<br>@RW2+, A    | ANDW<br>@RW3+, A <sup>1</sup> |
| 7 0 | NEGW<br>@RW0+d8     | NEGW<br>@RW1+d8               | NEGW<br>@RW2+d8               | NEGW<br>@RW3+d8               | NEGW<br>@RW4+d8     | NEGW<br>@RW5+d8     | NEGW<br>@RW6+d8     | NEGW<br>@RW7+d8     | NEGW<br>@RW0+d16     | NEGW<br>@RW1+d16     | NEGW<br>@RW2+d16     | NEGW<br>@RW3+d16     | NEGW<br>@RW0+RW7     | NEGW<br>@RW1+RW7     | NEGW<br>@PC+d16     | NEGW<br>addr16                |
| 6 0 | NEGW<br>RW0         | NEGW<br>RW1                   | NEGW<br>RW2                   | NEGW                          | NEGW<br>RW4         | NEGW                | NEGW<br>RW6         | NEGW<br>RW7         | NEGW                 | NEGW<br>@RW1_0       | NEGW                 | NEGW<br>@RW3         | NEGW<br>@RW0+        | NEGW<br>@RW1+        | NEGW<br>@RW2+       | NEGW 1<br>@RW3+               |
| 5 0 | SUBCW A,<br>@RW0+d8 | SUBCW A,<br>@RW1+d8           | SUBCW A,<br>@RW2+d8           | SUBCW A,<br>@RW3+d8           | SUBCW A,<br>@RW4+d8 | SUBCW A,<br>@RW5+d8 | SUBCW A,<br>@RW6+d8 | SUBCW A,<br>@RW7+d8 | SUBCW A,<br>@RW0+d16 | SUBCW A,<br>@RW1+d16 | SUBCW A,<br>@RW2+d16 | SUBCW A,<br>@RW3+d16 | SUBCW A,<br>@RW0+RW7 | SUBCW A,<br>@RW1+RW7 | SUBCW A,<br>@PC+d16 | SUBCW A,<br>addr16            |
| 4 0 | SUBCW<br>A, RWO     | SUBCW<br>A, RW1               | SUBCW<br>A, RW2               | SUBCW<br>A, RW3               | SUBCW<br>A, RW4     | SUBCW<br>A, RW5     | SUBCW<br>A, RW6     | SUBCW<br>A,RW7      | SUBCW<br>A, @RW0     |                      |                      | SUBCW<br>A, @RW3     | SUBCW<br>A, @RW0+    | SUBCW<br>A, @RW1+    | 0                   | SUBCW A<br>A, @RW3+           |
| 30  | SUBW @R<br>W0+d8, A | BW SUBW @R<br>RW1, A W1+d8, A | BW SUBW @R<br>RW2, A W2+d8, A | SUBW @R<br>W3+d8, A           | SUBW @R<br>W4+d8, A | SUBW @R<br>W5+d8, A | SUBW @R<br>W6+d8, A | SUBW @R<br>W7+d8, A | SUBW @R<br>W0+d16, A | SUBW @R<br>W1+d16, A | SUBW @R<br>W2+d16, A | SUBW @R<br>W3+d16, A | SUBW @R<br>W0+RW7, A | SUBW @R<br>W1+RW7, A | SUBW @P<br>C+d16, A | SUBW<br>addr16, A             |
| 20  | SUBW<br>RW0, A      | SUBW<br>RW1, A                | SUBW<br>RW2, A                | SUBW<br>RW3, A                | ۲<br>۲              | SUBW<br>RW5, A      | < <                 | SUBW<br>RW7, A      | @RW0, A W0+d16, A    | <                    | SUBW<br>@RW2, A      | _ <                  | SUBW<br>@RW0+, A     | SUBW<br>@RW1+, A     | SUBW<br>@RW2+, A    | SUBW 13<br>@RW3+, A           |
| 1 0 | ADDW @R<br>W0+d8, A | ADDW @R<br>W1+d8, A           | ADDW @R<br>W2+d8, A           | ADDW @R<br>W3+d8, A           | ADDW @R<br>W4+d8, A | ADDW @R<br>W5+d8, A | ADDW @R<br>W6+d8, A |                     |                      |                      | ADDW @R<br>W2+d16, A |                      | ADDW @R<br>W0+RW7    | ADDW @R<br>W1+RW7    | ADDW @R<br>C+d16, A | ADDW @R<br>addr16, A          |
| 0 0 | ADDW<br>RW0, A      | ADDW<br>RW1, A                | ADDW<br>RW2, A                | ADDW<br>RW3, A                | ADDW<br>RW4, A      | ADDW<br>RW5, A      | ADDW<br>RW6, A      | ADDW<br>RW7, A      | ADDW<br>@RW0, A      | ADDW<br>@RW1, A      | ADDW<br>@RW2, A      | ADDW<br>@RW3, A      | ADDW<br>@RW0+, A     | ADDW<br>@RW1+, A     | ADDW<br>@RW2+, A    | ADDW<br>@RW3+, A              |
|     | 0+                  | +                             | +2                            | +3                            | +4                  | +5                  | 9+                  | +7                  | +8                   | 6+                   | +A                   | +B                   | ç                    | Q-                   | ŧΕ                  | Ц<br>+                        |
|     | I                   | ]                             |                               |                               |                     |                     | l                   |                     | I                    |                      | I                    |                      | I                    |                      |                     |                               |

|    | 0 0              | 1 0                     | 2 0                             | 3.0                                 | 4 0 | 50 | 6 0 | 7 0 | 8 0                           | 0 6                                  | A 0                            | B 0                                 | C 0 | D 0 | ΕO | ΕO |
|----|------------------|-------------------------|---------------------------------|-------------------------------------|-----|----|-----|-----|-------------------------------|--------------------------------------|--------------------------------|-------------------------------------|-----|-----|----|----|
| +0 | MULU<br>A, Ro    | MULU A,<br>@RW0+d8      | 0                               | MULUW A,<br>@RW0+d8                 |     |    |     |     | DIVU<br>A, RO                 | DIVU A,<br>@RW0+d8                   | DIVUW<br>A, RWO                | DIVUW A,<br>@RW0+d8                 |     |     |    |    |
| +  | MULU<br>A, R1    | MULU A,<br>@RW1+d8      | MULUW<br>A, RW1                 | MULUW A,<br>@RW1+d8                 |     |    |     |     | DIVU<br>A, R1                 | DIVU A,<br>@RW1+d8                   | DIVUW<br>A, RW1                | DIVUW A,<br>@RW1+d8                 |     |     |    |    |
| +2 | MULU<br>A, R2    | MULU A,<br>@RW2+d8      | MULUW<br>A, RW2                 | MULUW A,<br>@RW2+d8                 |     |    |     |     | DIVU<br>A, R2                 | DIVU A,<br>@RW2+d8                   | DIVUW<br>A, RW2                | DIVUW A,<br>@RW2+d8                 |     |     |    |    |
| +3 | MULU<br>A, R3    | MULU A,<br>@RW3+d8      | MULUW<br>A, RW3                 | MULUW A,<br>@RW3+d8                 |     |    |     |     | DIVU<br>A, R3                 | DIVU A,<br>@RW3+d8                   | DIVUW<br>A, RW3                | DIVUW A,<br>@RW3+d8                 |     |     |    |    |
| +4 | MULU<br>A, R4    | ,48<br>−                | MULUW<br>A, RW4                 | MULUW A,<br>@RW4+d8                 |     | 1  |     |     | DIVU<br>A, R4                 | DIVU A,<br>@RW4+d8                   | DIVUW<br>A, RW4                | DIVUW A,<br>@RW4+d8                 |     |     |    |    |
| +5 | MULU<br>A, R5    | MULU A,<br>@RW5+d8      | MULUW<br>A, RW5                 | MULUW A,<br>@RW5+d8                 |     |    |     |     | DIVU<br>A, R5                 | DIVU A,<br>@RW5+d8                   | DIVUW<br>A, RW5                | DIVUW A,<br>@RW5+d8                 |     |     |    |    |
| 9+ | MULU<br>A, R6    | MULU A,<br>@RW6+d8      | A, RW6                          | MULUW A,<br>@RW6+d8                 |     |    |     |     | DIVU<br>A, R6                 | DIVU A,<br>@RW6+d8                   | DIVUW<br>A, RW6                | DIVUW A,<br>@RW6+d8                 |     |     |    |    |
| +7 | MULU<br>A, R7    | MULU A, MUI<br>@RW7+d8  | -UW<br>A, RW7                   | MULUW A,<br>@RW7+d8                 |     | -  |     |     | DIVU<br>A, R7                 | DIVU A,<br>@RW7+d8                   | DIVUW<br>A, RW7                | DIVUW A,<br>@RW7+d8                 |     |     |    |    |
| +8 | MULU<br>A, @RW0  | MULU A,<br>@RW0+d16     | UW<br>@RW0                      | MULUW A,<br>@RW0+d16                |     |    |     |     | DIVU<br>A, @RWQ               | DIVU A,<br>@RW0+d16                  | DIVUW<br>A, @RW0               | DIVUW A,<br>@RW0+d16                |     |     |    |    |
| 6+ | MULU<br>A, @RW1  | MULU A,<br>@RW1+d16     | MULUW<br>A, @RW1                | MULUW A,<br>@RW1+d16                |     |    |     |     | DIVU<br>A, @RW1               | DIVU A,<br>@RW1+d16                  | DIVUW<br>A, @RW1               | DIVUW A,<br>@RW1+d16                |     |     |    |    |
| +A | MULU<br>A, @RW2  | @RW2+d16                | MULUW<br>A, @RW2                | MULUW A,<br>@RW2+d16                |     |    |     |     | DIVU<br>A, @RW2               | DIVU DIVU A, D<br>A, @RW2   @RW2+d16 | DIVUW<br>A, @RW2               | A DIVUW DIVUW A,<br>A @RW2 @RW2+d16 |     |     |    |    |
| ₽  | RW3              | MULU A,<br>@RW3+d16     | MULUW<br>A, @RW3                | MULUW A,<br>@RW3+d16                |     |    |     |     | DIVU<br>A, @RW3               | DIVU A,<br>@RW3+d16                  | DIVUW<br>A, @RW3               | DIVUW A,<br>@RW3+d16                |     |     |    |    |
| ç  | MULU<br>A, @RW0+ | MULU A,<br>@RW0+RW7     | MULUW<br>A, @RW0+               | AULUW MULUW A,<br>A, @RW0+ @RW0+RW7 |     |    |     |     | DIVU<br>A, @RW0+              | DIVU A,<br>@RW0+RW7                  | DIVUW<br>A, @RW0+              | DIVUW A,<br>@RW0+RW7                |     |     |    |    |
| Ą  |                  | AULU A, @RW1+ '@RW1+RW7 | A, @RW1+                        | MULUW MULUW A,<br>A, @RW1+ @RW1+RW7 |     |    |     |     | A, @RW1+                      | DIVU A,<br>@RW1+RW7                  | A, @RW1+                       | DIVUW A,<br>@RW1+RW7                |     |     |    |    |
| ų  | W2+              | MULU A,<br>@PC+d16      | MULUW MULUW<br>A, @RW2+ @PC+d16 | MULUW A,<br>@PC+d16                 |     |    |     |     | DIVU<br>A, @RW2+              | DIVU A,<br>@PC+d16                   | DIVUW<br>A, @RW2+              | DIVUW A,<br>@ PC+d16                |     |     |    |    |
| Ц+ | MULU<br>A, @RW3+ |                         | MULUW<br>A, @RW3+               | MULUW A,                            |     |    |     |     | DIVU DIVU<br>A, @RW3+' addr16 | DIVU A,<br>addr16                    | DIVUW DIVUW<br>A, @RW3+ addr16 | DIVUW A,<br>addr16                  |     |     |    |    |

Table 4.3.13 "ea" Instructions ) (First byte = 78H)

232

## Chapter 4: Instructions

Table 4.3.14 MOVEA RWi, ea (First byte = 79H)

| F 0 | MOVEA RW7,<br>@RW0+d8                              | MOVEA RW7,<br>@RW1+d8                              | @RW2+d8                                                                | MOVEA RW7,<br>@RW3+d8                             | @RW4+d8               | MOVEA RW7,<br>@RW5+d8              | @RW6+d8                                            | @RW7+d8                                            | AOVEA RW7,<br>@RW0+d16                    | @RW1+d16                                                                 | 00VEA RW7,<br>@RW2+d16                                 | MOVEA RW7,<br>@RW3+d16                                                         | MOVEA RW7,<br>@RW0+RW7                                                                                  | EA RW7,<br>V1+RW7                                                                                          | AOVEA RW7,<br>@PC+d16                                                                          | DVEA RW7,<br>addr16                      |
|-----|----------------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------|-----------------------|------------------------------------|----------------------------------------------------|----------------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------|
| ш   | MOVE<br>0 @R                                       | MOVE<br>0. R                                       |                                                                        | MOVE<br>3 @R                                      |                       |                                    | · · · · ·                                          |                                                    | 2                                         |                                                                          | ~                                                      | /3 @RW                                                                         |                                                                                                         | R MOVEA RW7<br>/1+ @RW1+RW                                                                                 | ~                                                                                              | ž                                        |
| E 0 | MOVEA<br>RW7, RW0                                  | MOVEA<br>RW7, RW1                                  | MOVEA<br>RW7, RW2                                                      | MOVEA<br>RW7, RW3                                 | MOVEA<br>RW7, RW4     | MOVEA<br>RW7, RW5                  | MOVEA<br>RW7, RW6                                  | MOVEA<br>RW7, RW7                                  | MOVEA<br>RW7, @RW0                        | MOVEA<br>RW7, @RW1                                                       | MOVEA<br>RW7, @RW2                                     | MOVEA<br>RW7, @RW3                                                             | MOVEA<br>W7, @RW                                                                                        | MOVEA<br>W7, @RW                                                                                           | MOVEA<br>W7, @RW                                                                               | 5                                        |
| D 0 | MOVEA RW6.<br>@RW0+d8                              | MOVEA RW6<br>@RW1+d8                               | MOVEA RW6<br>@RW2+d8                                                   | MOVEA RW6<br>@RW3+d8                              | MOVEA RW6<br>@RW4+d8  | MOVEA RW6<br>@RW5+d8               | MOVEA RW6<br>@RW6+d8                               | MOVEA RW6<br>@RW7+d8                               | MOVEA RW6<br>@RW0+d16                     | @RW1+d16                                                                 | @RW2+d16                                               | MOVEA RW6<br>@RW3+d16                                                          | R   MOVEA RW6<br>0+ @RW0+RW7                                                                            | R MOVEA RW6                                                                                                | R - MOVEA RW6<br>/2+1 @PC+d16                                                                  | MOVEA RW6 MOVEA<br>addr16 W7, @R         |
| C 0 | MOVEA<br>RW6, RW0                                  | MOVEA<br>RW6, RW1                                  | MOVEA<br>RW6, RW2                                                      | MOVEA<br>RW6, RW3                                 | MOVEA<br>RW6, RW4     | MOVEA<br>RW6, RW5                  | MOVEA<br>RW6, RW6                                  | MOVEA<br>RW6, RW7                                  | MOVEA<br>RW6, @RW0                        | MOVEA<br>RW6, @RW1                                                       | MOVEA<br>RW6, @RW2                                     | MOVEA<br>RW6, @RW3                                                             | MOVEA R<br>W6, @RW0+                                                                                    | MOVEA R<br>W6, @RW1+                                                                                       | MOVEA<br>W6, @RW                                                                               | W3+                                      |
| B 0 | MOVEA RW5,<br>@RW0+d8                              | MOVEA RW5,<br>@RW1+d8                              | MOVEA RW5,<br>@RW2+d8                                                  | MOVEA RW5,<br>@RW3+d8                             | @RW4+d8               | MOVEA RW5,<br>@RW5+d8              | MOVEA RW5,<br>@RW6+d8                              | @RW7+d8                                            | MOVEA RW5,<br>@RW0+d16                    | MOVEA RW5,<br>@RW1+d16                                                   | MOVEA RW5,<br>@RW2+d16                                 | MOVEA RW5,<br>@RW3+d16                                                         | R   MOVEA RW5,<br>/0+ @RW0+RW7                                                                          | R MOVEA RW5,<br>V1+ @RW1+RW7                                                                               | R MOVEA RW5,<br>/2+ @PC+d16                                                                    | R MOVEA RW5, MOVEA<br>/3+' addr16 W6, @R |
| A 0 | MOVEA<br>RW5, RW0                                  | MOVEA<br>RW5, RW1                                  | MOVEA<br>RW5, RW2                                                      | MOVEA<br>RW5, RW3                                 | MOVEA<br>RW5, RW4     | MOVEA<br>RW5, RW5                  | MOVEA<br>RW5, RW6                                  | MOVEA<br>RW5, RW7                                  | MOVEA<br>RW5, @RW0                        | MOVEA<br>RW5, @RW1                                                       | MOVEA<br>RW5, @RW2                                     | RW3                                                                            | MOVEA R<br>W5, @RW0+                                                                                    | MOVEA RW4, MOVEA R ' MOVEA RW6<br>@RW1+RW7 W5, @RW1+' @RW1+RW7                                             |                                                                                                |                                          |
| 0 6 | MOVEA RW4,<br>@RW0+d8                              | MOVEA RW4,<br>@RW1+d8                              | MOVEA RW4,<br>@RW2+d8                                                  | MOVEA RW4,<br>@RW3+d8                             | MOVEA RW4,<br>@RW4+d8 | MOVEA RW4,<br>@RW5+d8              | MOVEA RW4,<br>@RW6+d8                              | MOVEA RW4,<br>@RW7+d8                              | MOVEA RW4,<br>@RW0+d16                    | MOVEA RW4, MOVEA<br>@RW1+d16 RW5, @                                      | MOVEA RW4,<br>@RW2+d16                                 | MOVEA RW4,<br>@RW3+d16                                                         | MOVEA RW3, MOVEA R ' MOVEA RW4, MOVEA R ' MOVEA RW5<br>@RW0+RW7 W4, @RW0+! @RW0+RW7 W5, @RW0+! @RW0+RW7 |                                                                                                            | R MOVEA RW4, MOVEA<br>V2+ @PC+d16 W5, @RV                                                      | R MOVEA RW4, MOVEA<br>/3+ addr16 W5, @RV |
| 8 0 | MOVEA<br>RW4, RW0                                  | MOVEA<br>RW4, RW1                                  | MOVEA<br>RW4, RW2                                                      | MOVEA<br>RW4, RW3                                 | MOVEA<br>RW4, RW4     | MOVEA<br>RW4, RW5                  | MOVEA<br>RW4, RW6                                  | MOVEA<br>RW4, RW7                                  | OVEA RW3, MOVEA<br>@RW0+d16 RW4, @RW0     | MOVEA<br>RW4, @RW1                                                       | MOVEA<br>RW4, @RW2                                     | MOVEA<br>RW4, @RW3                                                             | MOVEA R<br>W4, @RW0+                                                                                    | ~                                                                                                          |                                                                                                |                                          |
| 7 0 | MOVEA RW3, MOVEA<br>@RW0+d8 RW4,                   | @RW1+d8 RW4, F                                     | @RW2+d8 RW4, F                                                         | MOVEA RW3, MOVEA<br>@RW3+d8 RW4, F                | @RW4+d8 RW4, F        | MOVEA RW3, MOVEA<br>@RW5+d8 RW4, I | @RW6+d8 RW4, I                                     | @RW7+d8 RW4, RW4,                                  | MOVEA RW3, MOVEA<br>@RW0+d16 RW4, @       | MOVEA RW3, MOVEA<br>@RW1+d16 RW4, @                                      | MOVEA RW3, MOVEA<br>@RW2+d16 RW4, @                    | MOVEA RW3, MOVEA<br>@RW3+d16 RW4, @                                            | MOVEA RW3, MOVEA<br>@RW0+RW7 W4, @R                                                                     |                                                                                                            | MOVEA RW3, MOVEA<br>@PC+d16 W4, @R\                                                            | R MOVEA RW3, MOVEA<br>/3+ addr16 W4, @Rv |
| 6 0 | MOVEA<br>RW3, RW0                                  | MOVEA<br>RW3, RW1                                  | MOVEA<br>RW3, RW2                                                      | MOVEA<br>RW3, RW3                                 | MOVEA<br>RW3, RW4     | MOVEA<br>RW3, RW5                  | MOVEA<br>RW3, RW6                                  | MOVEA<br>RW3, RW7                                  | MOVEA<br>RW3, @RW0                        | MOVEA<br>RW3, @RW1                                                       | MOVEA<br>RW3, @RW2                                     | MOVEA<br>RW3, @RW3                                                             | MOVEA R<br>W3, @RW0+                                                                                    | MOVEA R<br>W3, @RW1+                                                                                       | MOVEA R<br>W3, @RW2+                                                                           | <                                        |
| 50  | MOVEA RW2<br>@RW0+d8                               | MOVEA RW2<br>@RW1+d8                               | MOVEA RW2<br>@RW2+d8                                                   | MOVEA RW2<br>@RW3+d8                              | MOVEA RW2<br>@RW4+d8  | MOVEA RW2<br>@RW5+d8               | MOVEA RW2<br>@RW6+d8                               | MOVEA RW2<br>@RW7+d8                               | MOVEA RW2<br>@RW0+d16                     | @RW1+d16                                                                 | MOVEA RW2<br>@RW2+d16                                  | MOVEA RW2<br>@RW3+d16                                                          | MOVEA RW2<br>@RW0+RW7                                                                                   | MOVEA RW2<br>@RW1+RW7                                                                                      | MOVEA RW2<br>@ PC+d16                                                                          | MOVEA RW2 MOVEA<br>addr16 W3, @R/        |
| 4 0 | MOVEA<br>RW2, RW0                                  | MOVEA<br>RW2, RW1                                  | MOVEA<br>RW2, RW2                                                      | MOVEA<br>RW2, RW3                                 | MOVEA<br>RW2, RW4     | MOVEA<br>RW2, RW5                  | MOVEA<br>RW2, RW6                                  | MOVEA<br>RW2, RW7                                  | MOVEA<br>RW2, @RW0                        | MOVEA<br>RW2, @RW1                                                       | MOVEA<br>RW2, @RW2                                     | MOVEA<br>RW2, @RW3                                                             | MOVEA R<br>W2, @RW0+                                                                                    | MOVEA R<br>W2, @RW1+                                                                                       | MOVEA R W2, @RW2+                                                                              | MOVEA R<br>W2, @RW3+                     |
| 3 0 | MOVEA RW1, MOVEA<br>@RW0+d8 RW2, F                 | AOVEA MOVEA RW1, MOVEA<br>RW1, RW1, @RW1+d8 RW2, R | MOVEA RW1,<br>@RW2+d8                                                  | OVEA MOVEA RW1, MOVEA<br>RW1, RW3, @RW3+d8 RW2, R | MOVEA RW1, MOVEA      | MOVEA RW1, MOVEA<br>@RW5+d8 RW2, R | AOVEA MOVEA RW1, MOVEA<br>RW1, RW6, @RW6+d8 RW2, R | MOVEA MOVEA RW1, MOVEA<br>RW1, RW7, @RW7+d8 RW2, R | MOVEA RW1, MOVEA<br>0, @RW0+d16, RW2, @RW | MOVEA RW1, MOVEA                                                         |                                                        | MOVEA RW1, MOVEA<br>W3 @RW3+d16 RW2, @I                                        | MOVEA RW1,<br>@RW0+RW7                                                                                  | MOVEA RW1,<br>@RW1+RW7                                                                                     | MOVEA RW1,<br>@ PC+d16                                                                         | MOVEA RW1,<br>addr16                     |
| 2 0 | 3W0                                                | Ś                                                  | MOVEA N                                                                |                                                   | 2                     | Š                                  | Š                                                  | MOVEA<br>RW1, RW7                                  | Š                                         | MOVEA<br>RW1, @RW1                                                       | MOVEA 'MOVEA RW1,<br>RW1, @RW2' @RW2+d16               | MOVEA<br>RW1, @R                                                               | MOVEA R<br>W1, @RW0+                                                                                    | MOVEA R<br>W1, @RW1+                                                                                       | MOVEA R MOVEA RW1<br>W1, @RW2+ @PC+d16                                                         | MOVEA R N<br>W1, @RW3+                   |
| 10  | AOVEA MOVEA RW0, MOVEA<br>RW0, RW0 - @RW0+d8 RW1,1 | MOVEA RW0, MOVEA<br>@RW1+d8 RW1, R                 | MOVEA RW0, MOVEA MOVEA RW1, MOVEA<br>2 @RW2+d8 RW1, RW2 @RW2+d8 RW2, R | MOVEA RW0, MOVEA<br>@RW3+d8 RW1, RW               | OVEA RW0,<br>@RW4+d8  | AOVEA RW0,<br>@RW5+d8              | MOVEA RW0, MOVEA<br>@RW6+d8 RW1, R                 | @RW7+d8 RW1,RW1,R                                  | MOVEA RW0, MOVEA                          | MOVEA 'MOVEA RW0, MOVEA 'MOVEA RW1,<br>RW0, @RW1' @RW1+d16 RW1, @RW1+d16 | MOVEA 'MOVEA RW0, MOVEA<br>RW0, @RW2' @RW2+d16 RW1, @R | MOVEA 'MOVEA RW0, MOVEA 'MOVEA RW1,<br>RW0, @RW3' @RW3+d16 RW1, @RW3' @RW3+d16 | MOVEA R'MOVEA RWO] MOVEA R'MOVEA RW1, MOVEA R<br>W0, @RW0+'@RW0+RW7 W1, @RW0+'@RW0+RW7 W2, @RW0-        | MOVEA R.MOVEA RWO, MOVEA R MOVEA R MOVEA RW1, MOVEA R<br>W0, @RW1+; @RW1+RW7 W1, @RW1+; @RW1+RW7 W2, @RW1+ | MOVEA R.MOVEA R.WO, MOVEA R. MOVEA RW1, MOVEA<br>W0, @RW2+! @PC+d16 W1, @RW2+! @PC+d16 W2, @RW | RWO,                                     |
| 0 0 | MOVEA I<br>RW0, RW0                                | MOVEA N<br>RW0, RW1                                | MOVEA N<br>RW0, RW2                                                    | MOVEA N<br>RW0, RW3                               | MOVEA RW0, RW4        | MOVEA<br>RW0, RW5                  | MOVEA N<br>RW0, RW6                                | MOVEA MOVEA<br>RW0, RW7 @RW                        | MOVEA MOVEA RW0<br>RW0, @RW0, @RW0+d16    | MOVEA 'I<br>RW0, @RW1                                                    | MOVEA 'I<br>RW0, @RW2                                  | MOVEA 1<br>RW0, @RW3                                                           | MOVEA R<br>W0, @RW0+                                                                                    | MOVEA R'I<br>W0, @RW1+                                                                                     | MOVEA R'MOVEA RWI<br>W0, @RW2+ @PC+d16                                                         | MOVEA R'MOVEA F<br>W0, @RW3+ ' addr16    |
|     | 0+                                                 | +1                                                 | +2                                                                     | +3                                                | +4                    | +5                                 | 9+                                                 | +7                                                 | +8                                        | 6+                                                                       | A+                                                     | +B                                                                             | °+C                                                                                                     | Q+                                                                                                         | Щ+                                                                                             | 4<br>+                                   |

MOV R7, @RW4+d8 @RW5+d8 MOV R7, MOV R7, @RW1+d16 MOV R7, @RW0+d8 MOV R7, @RW3+d16 @RW0+RW @RW1+RW MOV R7, @PC+d16 @RW3+d8 @RW7+d8 @RW1+d8 @RW2+d8 @RW6+d8 @RW0+d1 @RW2+d16 OV R7, addr16 R7. R7. R7. R7. R7. R7. R7, Р Г VOV MOV MOV - NOM NOV NOV NOV Q MOV R7, @RW0 MOV R7, @RW1 MOV R7, @RW2 MOV R7, @RW3 MOV R7, R6 MOV R7, @RW1+ R7. MOV R7, @RW2+ MOV R7 @RW0+ R7. R7. R7. MOV R7, R2 MOV R7, R3 MOV R7, R4 MOV R @RW3+ R7 MOV R7, R1 R5 R MOV R7 F о Ш MOV R7, F MOV R7, MOV R6, @RW0+d16 MOV R6, @RW0+RW7 MOV R6, @RW1+RW7 MOV R6, @RW5+d8 MOV R6, @RW7+d8 MOV R6, @RW3+d16 MOV R6, @RW1+d8 MOV R6, @RW2+d8 MOV R6, @RW4+d8 MOV R6, @RW6+d8 MOV R6, @RW0+d8 @RW2+d16 @RW1+d16 R6, R6, R6, @PC+d16 - R6, g 0 0 MOV addr1 MOV MOV MOV MOV MOV R6, @RW0 MOV R6, @RW3 MOV R6, @RW1 R6, R6, @RW2 R6, R6. R6, MOV R6 @RW1+ MOV R6, R3 MOV R6, R6 MOV R6, R7 R6, R7 MOV R6, R2 MOV R6, R4 @RW2+ MOV R6 @RW3+ R5 - -@RW0+ R0 ۳. 000 MOV R6, MOV R6, MOV MOV R6, MOV VOV MOV R5, @RW0+RW7 MOV R5, @RW1+d16 MOV R5, @RW3+d16 MOV R5, addr16 MOV R5, @RW1+d8 MOV R5, @RW2+d8 MOV R5, @RW3+d8 @RW4+d8 @RW4+d8 @RW7+d8 @RW0+d16 MOV R5, @PC+d16 MOV R5, @RW0+d8 MOV R5, @RW5+d8 MOV R5, @RW6+d8 @ RW2+d16 R5, R5. B 0 MOV MOV MOV MOV R5, @RW1+ ' @RW3+ MOV R5, @RW3 R5, @RW0+ R5, @RW2+ MOV R5, @RW1 R5, @RW0 R5, @RW2 MOV R5, R3 MOV R5, R2 ß Ř R4 R5 R6 R7 MOV R5, R MOV R5, F MOV R5, F MOV R5, F MOV R5, F MOV R5, I MOV MOV NOM MOV R5, @ MOV MOV R4, 1 @RW0+d16 MOV R4, @RW3+d16 v R4, | addr16 MOV R4, @RW7+d8 MOV R4, @RW1+d16 MOV R4, @RW2+d16 MOV R4, @RW0+RW7 MOV R4, @RW1+RW7 AOV R4, @PC+d16 0V R4, @RW2+d8 MOV R4, @RW4+d8 MOV R4, @RW5+d8 0V R4, @RW6+d8 MOV R4, @RW0+d8 AOV R4, @RW1+d8 @ RW3+d8 R4, 06 MOV MOV MOV MOV NOM MOV MOV MOV MOV IN R4, @RW2+ \_\_\_\_\_\_ MOV \_\_\_\_\_ R4, @RW3+' MOV - N R4, @RW1+ 1 MOV R4, @RW0+ MOV R4, @RW2 MOV R4, @RW3 MOV R4, @RW0 MOV R4, @RW1 MOV R4, R6 MOV R4, R7 MOV R4, R5 MOV R4, R1 MOV R4, R2 MOV R4, R3 MOV R4, R4 RO 80 MOV R4, @RW0+d16 MOV R3, @RW3+d8 MOV R3, @RW7+d8 MOV R3, @RW0+RW7 MOV R3, @RW0+d8 AOV R3, @RW1+d8 MOV R3, @RW2+d8 MOV R3, @RW4+d8 MOV R3, @RW5+d8 MOV R3, @RW6+d8 MOV R3, @RW1+d16 MOV R3, @RW2+d16 MOV R3, @RW3+d16 - MOV R3, P @PC+d16 MOV <sup>-</sup> MOV R3, R3, @RW1+<sup>-</sup> @RW1+RW7 R3, - MOV R - addr16 7 0 MOV MOV MOV · M R3, @RW2+' ( @ RW3+ R3, @RW0+' R3, @RW0 MOV R3, @RW1 R3, @RW2 @ RW3 MOV R3, R6 MOV R3, R5 MOV R3, R7 MOV R3, R2 MOV R3, R3 MOV R3, R4 Ł RO 60 MOV R3, I MOV R3, F MOV R3, MOV MOV MOV R3, MOV @RW0+RW7 MOV R2, @RW1+RW7 00V R2, @RW1+d8 MOV R2, @RW2+d8 MOV R2, @RW3+d8 MOV R2, @RW4+d8 MOV R2, @RW5+d8 MOV R2, @RW6+d8 \_\_\_\_\_RW7+d8 MOV R2, @RW1+d16 MOV R2, @RW3+d16 @RW0+d16 MOV R2, @RW0+d8 @ RW2+d16 MOV R2, @PC+d16 R2. Ľ Ľ Ľ MOV F addr16 50 MOV NOW MOV MOV MOV R2, @RW2 MOV R2, @RW3 MOV R2, @RW3 MOV MOV R2, @RW1+ R2, @RW1+ MOV R2, @RW1 R2, @RW0 MOV R2, R7 MOV R2, R2 MOV R2, R3 MOV R2, R4 MOV R2, R5 MOV R2, R6 R MOV R2, R1 4 0 MOV MOV MOV R1, @RW1+RW7 MOV R1, @RW0+d16 MOV R1, @RW0+RW7 MOV R1, @RW1+d16 MOV R1, @RW3+d16 @RW7+d8 MOV R1, @RW2+d16 MOV R1, @RW2+d8 MOV R1, @RW4+d8 MOV R1, @RW5+d8 @RW6+d8 MOV R1, @RW0+d8 MOV R1, @RW1+d8 MOV R1, @RW3+d8 V R1, addr16 Ъ. @PC+d16 30 MOV R1, MOV @RW2+ ' @PC+ MOV MOV R1, @RW3 MOV R1, @RW0 MOV R1, @RW2 MOV R1, @RW1 - E Ł R. MOV R1, R2 MOV R1, R4 MOV R1, R6 MOV R1, R7 R5 @RW1+ RO MOV R1, R1 R1, R3 @RW0+ MOV @RW3+ 20 MOV R1. MOV R1, VOM R0, ... 0V R0, @RW7+d8 0V R0, MOV R0, @RW1+d16 MOV R0, @RW3+d16 MOV R0, @RW1+d8 MOV R0, @RW2+d8 MOV R0, @RW3+d8 MOV R0, @RW4+d8 MOV R0, @RW5+d8 MOV R0, @RW0+RW7 @RW0+d16 MOV R0, @RW0+d8 @RW6+d8 @RW2+d16 / 'MOV R0, @RW1+'@RW1+RW7 AOV R0, @PC+d16 RO. RO, 0 MOV VOV VOV MOV MOV MOV MOV R0, @RW0+ '( MOV R0, R0 MOV R0, R1 R0, R2 MOV R0, R3 MOV R0, R3 MOV R0, R3 MOV R0, R5 MOV R0, R4 MOV R0, R5 MOV MOV R0, @RW2 @RW2+ 1 @RW3 @RW3+ @RW1 00 R0, 80, Åð, ROV ROV ROV , NOV , NOV , NOV , NOV , NOV ₹ 4 ပ္ щ ¥ **9** Ŧ 42 ę 4 45 9+ 4 φ 6+

.

Table 4.3.15 MOV Ri, ea (First byte = 7AH)

234

Table 4.3.16 MOVW RWi, ea (First byte = 7BH)

| 90 A0 B0 C0 D0 E0 | MOVW RW4, MOVW i MOVW RW5, MOVW i MOVW RW6, MOVW i MOVW RW7<br>@RW0+d8 RW5, RW0 i @RW0+d8 RW6, RW0 i @RW0+d8 RW7, RW0 i @RW0+d8 | JOUW RW4, MOVW I MOVW RW5, MOVW RW6 MOVW RW6 MOVW W7<br>@RW1+d8 RW5, RW1 - @RW1+d8 RW6, RW1 - @RW1+d8 RW7, RW1 - @RW1+d8 | WOWN RW4, MOWW , MOWW RW5, MOWW RW6, MOWW RW6, MOWW RW7<br>@RW2+d8, RW5, RW2 , @RW2+d8, RW6, RW2 , @RW2+d8, RW7, RW2 , @RW2+d8 | JOWN RW4, MOWW , MOWW RW5, MOWW RW6, MOWW RW7, MOWW RW7<br>@RW3+d8 RW5, RW3 , @RW3+d8 RW6, RW3 , @RW3+d8 RW7, RW3 , @RW3+d8 | aow rw4, Movw , Movw rw5, Movw rw6, Movw rw6, Movw rw7<br>@rw4+d8 | IOVW RW4, MOVW - MOVW RW5, MOVW RW5, MOVW RW6, MOVW RW7<br>@RW5+d8 RW5, RW5, @RW5+d8 RW6, RW5, @RW5+d8 | 1.1.2                | JOWN RW4, MOWW - MOWW RW5, MOWW RW6, MOWW RW7<br>@RW7+48, RW5, RW7, @RW7+48, RW6, RW7, @RW7+48, RW7, RW7, @RW7+48 | NOW RW4, MOW MOW RW5, MOW MOW WW6, MOW RW6, MOW RW7, @RW04d16 RW7, @RW0, @RW04d16 RW7, @RW0, @RW04d16 | NOW RW4, MOVW 'MOVW RW5, MOVW RW6, MOVW RW6, MOVW RW7<br>@RW1+d16 RW5, @RW1+@RW1+d16 RW6, @RW1+d16 RW7, @RW1+@RW1+d16 | NOWN RW4, MOVW 'MOVW RW5, MOVW RW6, MOVW RW7 'MOVW RW7<br>@RW2+d16 RW5, @RW2+@RW2+d16 RW6, @RW2+d16 RW7, @RW2; @RW2+d16 | MOVW RW4, MOVW - MOVW RW5, MOVW RW6, MOVW RW6, MOVW - MOVW RW7<br>@RW3+d16 RW5, @RW3+@RW3+d16 RW6, @RW3+ @RW3+d16 RW7, @RW3 @RW3+d16 | MOVW RW4, MOVW R MOVW RW5, MOVW RW5, MOVW RW6, MOVW RW7<br>@RW0+RW7 W5, @RW0+!@RW0+RW7 W6, @RW0+RW7 W7, @RW0+! @RW0+RW7 |                                                             | 7 W5, @RW1+' @RW1+RW7 W6, @RW1+' @RW1+RW7 W7, @RW | 7 W5. @RW1+. @RW1+RW7 W6. @RW1+. @RW1+RW7 W7. @RW<br>MOVW R MOVW RW5. MOVW R MOVW RW6. MOVW<br>MOVW R @PC+d16 W6. @RW2+! @PC+d16 W7. @RW |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 80                | MOVW<br>RW4, RW0                                                                                                                | MOVW<br>RW4, RW1                                                                                                         | MOVW INV2                                                                                                                      | MOVW<br>RW4, RW3                                                                                                            | MOVW NOVW RW4, RW4, RW4, RW4                                      | MOVW<br>RW4, RW5                                                                                       | MOVW<br>RW4, RW6     | MOVW<br>RW4, RW7                                                                                                  | MOVW NOVW NOVW                                                                                        | MOVW<br>RW4, @RW1                                                                                                     | MOVW<br>RW4, @RW2                                                                                                       | MOVW<br>RW4, @RW3                                                                                                                    | MOVW R<br>W4, @RW0+                                                                                                     |                                                             | V7 W4, @RW1+                                      | W4, @RW1+' @<br>MOVW R M<br>W4, @RW2+'                                                                                                   |
| 2 0               | - MOVW RW3,<br>@RW0+d8                                                                                                          | MOVW RW3,<br>@RW1+d8                                                                                                     | MOVW RW3,<br>@RW2+d8                                                                                                           | MOVW RW3,<br>@RW3+d8                                                                                                        | MOVW RW3,<br>@RW4+d8                                              | MOVW RW3,<br>@RW5+d8                                                                                   | MOVW RW3,<br>@RW6+d8 | MOVW RW3,<br>@RW7+d8                                                                                              | MOVW RW3,<br>@RW0+d16                                                                                 | 0 RW1+d16                                                                                                             |                                                                                                                         | MOVW RW3,<br>@RW3+d16                                                                                                                | R   MOVW RW3,<br>0+   @RW0+RW7                                                                                          | R MOW RW3,                                                  | W3, @RW1+                                         | @ RW1+RW7<br>- MOVW RW3,<br>- @ PC+d16                                                                                                   |
| 60                | MOVW<br>RW3, RW0                                                                                                                | MOVW<br>RW3, RW1                                                                                                         | MOVW<br>RW3, RW2                                                                                                               | <br>MOVW<br>RW3, RW3                                                                                                        | MOVW<br>RW3, RW4                                                  | MOVW<br>RW3, RW5                                                                                       | MOVW<br>RW3, RW6     | MOVW<br>RW3, RW7                                                                                                  | MOVW<br>RW3, @RW0                                                                                     | <br>MOVW<br>RW3, @RW1                                                                                                 | MOVW<br>RW3, @RW2                                                                                                       | MOVW<br>RW3, @RW3                                                                                                                    | <br>MOVW<br>W3, @RW                                                                                                     |                                                             |                                                   |                                                                                                                                          |
| 50                | MOVW RW2,<br>@RW0+d8                                                                                                            | MOVW RW2,<br>@RW1+d8                                                                                                     | @RW2+d8                                                                                                                        | @RW3+d8                                                                                                                     | @RW4+d8                                                           | MOVW RW2,<br>@RW5+d8                                                                                   | @RW6+d8              | @RW7+d8                                                                                                           | @RW0+d16                                                                                              | @ RW1+d16                                                                                                             | @RW2+d16                                                                                                                | @RW3+d16                                                                                                                             | R MOVW RW2,<br>0+ @RW0+RW7                                                                                              | MOVW RW2,                                                   | (@ KWI+KW/                                        | ~ ~                                                                                                                                      |
| 4 0               | MOVW<br>RW2, RW0                                                                                                                | MOVW<br>RW2, RW1                                                                                                         | MOVW<br>RW2, RW2                                                                                                               |                                                                                                                             | MOVW<br>RW2, RW4                                                  | MOVW<br>RW2, RW5                                                                                       | MOVW<br>RW2, RW6     | MOVW<br>RW2, RW7                                                                                                  | MOVW<br>RW2, @RW0                                                                                     | MOVW<br>RW2, @RW1                                                                                                     | MOVW<br>RW2, @RW2                                                                                                       | MOVW<br>RW2, @RW3                                                                                                                    | MOVW R<br>W2, @RW0+                                                                                                     |                                                             | WZ, @RWI+                                         | W2, @RW<br>MOVW<br>W2, @RW                                                                                                               |
| 30                | MOVW RW1,<br>@RW0+d8                                                                                                            | IOVW MOVW RW1,<br>RW1, RW1, @RW1+d8                                                                                      | IOVW MOVW RW1,<br>RW1, RW2, @RW2+d8                                                                                            | IOUWMOUW RW1,<br>RW1, RW3, @RW3+d8                                                                                          |                                                                   |                                                                                                        | @RW6+d8              | <br>AOVW RW1,<br>@RW7+d8                                                                                          | @RW0+d16                                                                                              | MOVW MOVW RW1,<br>RW1, @RW1, @RW1+d16                                                                                 |                                                                                                                         |                                                                                                                                      |                                                                                                                         |                                                             |                                                   | WI, @KWI+ @KWI+KW/<br><br>MOVW R ' MOVW RW1,<br>W1, @RW2+' @PC+d16                                                                       |
| 2 0               | MOVW<br>RW1, RW0                                                                                                                | MOVW<br>RW1, RW1                                                                                                         | MOVW<br>RW1, RW2                                                                                                               | MOVW<br>RW1, RW3                                                                                                            | MOVW RW4                                                          | MOVW MOVW RW1,<br>RW1, RW5, @RW5+d8                                                                    | 10VW<br>RW1, RW6     | 10VW<br>RW1, RW7                                                                                                  | 10VW<br>10VW<br>101, @RWC                                                                             | MOVW<br>RW1, @RW1                                                                                                     | MOVW<br>RW1, @RW2                                                                                                       | MOVW<br>RW1, @RW3                                                                                                                    | MOVW R<br>W1, @RW0+                                                                                                     | MOVW R MOVW RW1, MOVW 1000000000000000000000000000000000000 |                                                   | MOVW R<br>W1, @RW2+                                                                                                                      |
| 10                | AOVW MOVW RW0,<br>RW0, RW0 - @RW0+d8                                                                                            | 10VW MOVW RW0,<br>RW0, RW1 - @RW1+d8                                                                                     | AOVW MOVW RW0,<br>RW0, RW2 - @RW2+d8                                                                                           | ©WW RW0,<br>@RW3+d8                                                                                                         | @RW4+d8                                                           | MOVW RW0,<br>@RW5+d8                                                                                   | MOWN RW0,<br>@RW6+d8 | MOVW RW0, MOVW RW0, M                                                                                             | MOVW RW0,<br>@RW0+d16                                                                                 | @RW1+d16                                                                                                              | MOVW MOVW RW0,<br>RW0, @RW2¦ @RW2+d16                                                                                   |                                                                                                                                      | OWN RWO,<br>RWO+RW7                                                                                                     |                                                             |                                                   |                                                                                                                                          |
| 0 0               | MOVW<br>RW0, RW0                                                                                                                | MOVW<br>RW0, RW1                                                                                                         | MOVW<br>RW0, RW2                                                                                                               | MOVW MOVW                                                                                                                   | MOVW NV4                                                          | MOVW<br>RW0, RW5                                                                                       | MOVW NOVW            | MOVW<br>RW0, RW7                                                                                                  | MOVW<br>RW0, @RW0                                                                                     | MOVW NOVW                                                                                                             | MOVW<br>RW0, @RW2                                                                                                       | MOVW MOVW                                                                                                                            | MOVW R MOVW RWO<br>W0, @RW0+ @RW0+RW7                                                                                   |                                                             |                                                   | MOVW R MOVW RWC<br>W0, @RW2+                                                                                                             |
|                   | 0+                                                                                                                              | +                                                                                                                        | +2                                                                                                                             | +3                                                                                                                          | +4                                                                | +5                                                                                                     | 9+                   | +7                                                                                                                | +8                                                                                                    | 6+                                                                                                                    | +A                                                                                                                      | ₽<br>₽                                                                                                                               | Q<br>+                                                                                                                  | ę                                                           |                                                   | Ψ                                                                                                                                        |

| DO EO FO | - MOV @R MOV - MOV @R<br>- W0+d8, R6 R0, R7 - W0+d8, R7 | MOV @R MOV MOV @R<br>W1+d8, R6 R1, R7 W1+d8, R7 | MOV @R MOV MOV @R<br>W2+d8, R6 R2, R7 W2+d8, R7 | MOV @R MOV @R W3+d8, R7 w W3+d8, R7 | MOV @R MOV MOV @R<br>W4+d8, R6 R4, R7 W4+d8, R7 | MOV @R MOV WOV @R<br>W5+d8, R6 R5, R7 W5+d8, R7 | MOV @R MOV MOV @R<br>W6+d8, R6 R6, R7 W6+d8, R7 | MOV @R MOV MOV @R<br>W7+d8, R6 R7, R7 W7+d8, R7 | MOV @RW MOV @RW<br>0+d16, R6 @RW0, R7 0+d16, R7 | MOV @RW MOV @RW<br>3 1+d16, R6 @RW1, R7 1+d16, R7 |                      |                                 | MOV @RW MOV MOV @RW<br>R6 0+RW7, R6 @RW0+, R7 0+RW7, R7 | MOV @RW MOV I MOV @RW<br>R6' 1+RW7,R6 @RW1+,R7' 1+RW7, R7 |             |                                     |
|----------|---------------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|---------------------------------------------------|----------------------|---------------------------------|---------------------------------------------------------|-----------------------------------------------------------|-------------|-------------------------------------|
| C 0      | MOV<br>R0, R6                                           |                                                 | MOV<br>R2, R6                                   |                                     | . —                                             |                                                 | MOV<br>R6, R6                                   | MOV<br>R7, R6                                   | 0 MOV<br>@RW0, R6                               | W MOV<br>@RW1, R6                                 | @RW2, R6             | V MOV<br>@RW3, R6               | @RW0+,                                                  | @RW1+,                                                    |             | @RW2+, F                            |
| B 0      | MOV @R<br>W0+d8, R5                                     | MOV @R<br>W1+d8, R5                             | MOV @R<br>W2+d8, R5                             | MOV @R<br>W3+d8, R5                 | MOV @R<br>W4+d8, R5                             | MOV @R<br>W5+d8, R5                             | MOV @R<br>W6+d8, R5                             | MOV @R<br>W7+d8, R5                             | MOV @RW<br>0+d16, R5                            | MOV @RW<br>1+d16, R5                              | MOV @RW<br>2+d16, R5 | MOV @RW<br>3+d16, R5            | MOV @RW<br>0+RW7, R5                                    | MOV @RW<br>1+RW7, R5                                      |             | - MOV<br>PC+d16, R5                 |
| A 0      | MOV<br>R0, R5                                           | MOV<br>R1, R5                                   | MOV<br>R2, R5                                   | <br>MOV<br>R3, R5                   | MOV<br>R4, R5                                   | <br>MOV<br>R5, R5                               | MOV<br>R6, R5                                   | MOV<br>R7, R5                                   | MOV<br>@RW0, R5                                 | MOV<br>@RW1, R5                                   | MOV<br>@RW2, R5      | MOV<br>@RW3, R5                 | MOV<br>@RW0+, R5                                        | @RW1+, R5                                                 |             | MOV<br>@RW2+, R5 <sup></sup>        |
| 06       | - MOV @R<br>W0+d8, R4                                   | MOV @R<br>W1+d8, R4                             | MOV @R,<br>W2+d8, R4                            | MOV @R,<br>W3+d8, R4                | MOV @R<br>W4+d8, R4                             | MOV @R<br>W5+d8, R4                             | MOV @R<br>W6+d8, R4                             | MOV @R<br>W7+d8, R4                             | MOV @RW<br>0+d16, R4                            | MOV @RW<br>1+d16, R4                              | MOV @RW<br>2+d16, R4 | MOV @RW<br>3+d16, R4            | MOV @RW<br>0+RW7, R4                                    | MOV @RW<br>1+RW7, R4                                      | 1<br>1<br>1 |                                     |
| 8 0      | MOV<br>R0, R4                                           | MOV<br>R1, R4                                   | MOV<br>R2, R4                                   | MOV<br>R3, R4                       | MOV<br>R4, R4                                   | <br>MOV<br>R5, R4                               | MOV<br>R6, R4                                   | MOV<br>R7, R4                                   | @RW0, R4                                        | @RW1, R4                                          | MOV<br>@RW2, R4      | MOV<br>@RW3, R4                 | @RW0+, R4                                               | @RW1+, R4                                                 |             | @RW2+, R4                           |
| 7 0      | - MOV @R<br>W0+d8, R3                                   | MOV @R<br>W1+d8, R3                             | MOV @R<br>W2+d8, R3                             | MOV @R<br>W3+d8, R3                 | MOV @R<br>W4+d8, R3                             | MOV @R<br>W5+d8, R3                             | MOV @R<br>W6+d8, R3                             | MOV @R<br>W7+d8, R3                             | MOV @RW<br>0+d16, R3                            | , <u>≥</u> `_                                     | 2                    | MOV @RW<br>3+d16, R3            | MOV @RW<br>0+RW7, R3                                    | MOV @RW<br>1+RW7, R3                                      |             | - MOV<br>R3' PC+d16, R3             |
| 6 0      | MOV<br>R0, R3                                           | MOV<br>R1, R3                                   | MOV<br>R2, R3                                   | MOV                                 |                                                 | MOV<br>R5, R3                                   | MOV<br>R6, R3                                   | 2                                               | MOV<br>@RW0, R3                                 | MOV<br>@RW1, R3                                   | @RWMOV<br>R2@RW2, R3 | MOV<br>@RW3, R3                 | MOV<br>@RW0+, R3                                        | @RW1+, R3                                                 |             | <br>MOV<br>@RW2+, R3                |
| 50       | MOV @R,<br>W0+d8, R2                                    | MOV @R<br>W1+d8, R2                             | MOV @R<br>W2+d8, R2                             | MOV @R<br>W3+d8, R2                 | MOV @R<br>W4+d8, R2                             | MOV @R<br>W5+d8, R2                             | MOV @R<br>W6+d8, R2                             | MOV @R<br>W7+d8, R2                             | MOV @RW 0<br>0+d16, R2                          | MOV @RW N<br>1+d16, R2                            | MOV @RW<br>2+d16, R2 | MOV @RW<br>3+d16, R2            | MOV @RW<br>0+RW7, R2                                    | MOV @RW<br>1+RW7, R2                                      |             | MOV<br>PC+d16, R2                   |
| 4 0      | MOV<br>R0, R2                                           | MOV<br>R1, R2                                   | MOV<br>R2, R2                                   | MOV                                 | MOV<br>R4, R2                                   | MOV<br>R5, R2                                   | MOV<br>R6, R2                                   | MOV<br>R7, R2                                   | MOV<br>@RW0, R2                                 | @RW1, R2                                          | MOV<br>@RW2, R2      | MOV<br>@RW3, R2                 | @RW0+, R2                                               | @RW1+, R2                                                 |             | @RW2+, R2                           |
| 3.0      | MOV @R<br>W0+d8, R1                                     | MOV @R<br>W1+d8, R1                             | MOV @R<br>W2+d8, R1                             | MOV @R<br>W3+d8, R1                 | MOV @R<br>W4+d8, R1                             | MOV @R<br>W5+d8, R1                             | MOV @R<br>W6+d8, R1                             | MOV @R<br>W7+d8, R1                             | MOV @RW<br>0+d16, R1                            | MOV @RW<br>1+d16, R1                              | MOV @RW<br>2+d16, R1 | MOV @RW<br>3+d16, R1            | MOV @RW<br>0+RW7, R1                                    | MOV MOV @RW<br>@RW1+, R1 1+RW7, R1                        |             | MOV 1 MOV<br>@RW2+, R1 1 PC+d16, R1 |
| 2 0      | MOV<br>R0, R1                                           | MOV<br>R1, R1                                   | MOV<br>R2, R1                                   | <br>MOV<br>R3, R1                   | MOV<br>R4, R1                                   | <br>MOV<br>R5, R1                               | MOV<br>R6, R1                                   | MOV<br>R7, R1                                   | <br>@RW0, R1                                    | MOV<br>@RW1, R1                                   | MOV<br>@RW2, R1      | MOV<br>@RW3, R1                 | MOV<br>@RW0+, R1                                        | <br>MOV<br>@RW1+, R1                                      |             | MOV<br>@RW2+, R1                    |
| 1 0      | -MOV @R<br>- W0+d8, R0                                  | MOV @R<br>W1+d8, R0                             | MOV @R<br>W2+d8, R0                             | MOV @R<br>W3+d8, R0                 | MOV @R<br>W4+d8, R0                             | MOV @R<br>W5+d8, R0                             | MOV @R<br>W6+d8, R0                             | MOV @R<br>W7+d8, R0                             | MOV @RW 1<br>0+d16, R0                          |                                                   | MOV @RW<br>2+d16, R0 | MOV @RW 1<br>@RW3, R0 3+d16, R0 | AOV MOV @RW<br>@RW0+, R0 0+RW7, R0                      | MOVMOV@RW                                                 |             | AOV · MOV<br>@ RW2+, R0' PC+d16, R0 |
| 0 0      | MOV<br>R0, R0                                           | MOV<br>R1, R0                                   | MOV<br>R2, R0                                   | <br>MOV<br>R3, R0                   | MOV<br>R4, R0                                   | MOV<br>R5, R0                                   | MOV<br>R6, R0                                   | MOV<br>R7, R0                                   | MOV<br>@RW0, R0                                 | MOV<br>@RW1, R0                                   | MOV<br>@RW2, R0      | MOV<br>@RW3, R0                 | @RW0+, R(                                               | @RW1+, R(                                                 |             | MOV<br>@RW2+, R                     |
|          | 0+                                                      | ÷                                               | +2                                              | +                                   | +4                                              | 4°                                              | 9<br>+                                          | 7+                                              | 8+                                              | 6+                                                | +A                   | +<br>H                          | О<br>+                                                  | Q<br>+                                                    |             | щ<br>+                              |

Table 4.3.17 MOV ea, Ri (First byte = 7CH)

236

Table 4.3.18 MOVW ea, RWi (First byte = 7DH)

| WUT         MOVW         @RW         MOVW         @RW         WOVW         @RW           WUT         0+48, RW1         RW0, RW         MOVW         MOVW         @RW         WO           WUT         1-46, RW1         RW0, RW         MOVW         @RW         WO         WO           WUT         1-46, RW1         RW1, RW1, RW2, RW2         1-46, RW2         @RW         @RW           WUT         2-46, RW1         RW1, RW3, RW2         2-46, RW2         @RW2           WUT         3-46, RW1         RW4, RW2         1-46, RW2         @RW2           WUT         4-46, RW1         RW4, RW2         1-46, RW2         @RW2           WUT         5-46, RW1         RW4, RW2         @RW2         @RW2           WUT         6-46, RW1         RW4, RW2         @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              | 0 0                    | 1 0                   | 2 0               | 3.0                            | 4 0                 | 5 0                   | 09                                  | 0 2                             | 8 0                 | 0.6                              | A 0                                   | B 0                              | C 0                                  | 0 0                                | E 0                                  | ΕO                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------|-----------------------|-------------------|--------------------------------|---------------------|-----------------------|-------------------------------------|---------------------------------|---------------------|----------------------------------|---------------------------------------|----------------------------------|--------------------------------------|------------------------------------|--------------------------------------|-----------------------|
| MOUW         MOUW         BRWI, RWI         MOUW         BRWI, RWI         MOUW         BRWI         RWI         RWI         RWI         RWI         MOUW         BRWI         MOUW         BRWI         RWI         MOUW         BRWI         RWI         MOUW         BRWI         RWI         RWI <th< th=""><th>0+</th><th>MOVW<br/>RW0, RW0</th><th>MOVW @RW<br/>0+d8, RW0</th><th>RW1</th><th>&gt;</th><th>MOVW<br/>RW0, RW2</th><th></th><th>MOVW<br/>RW0, RW3</th><th>MOVW @RW MOVW<br/>0+d8, RW3 RW0,</th><th>MOVW<br/>RW0, RW4</th><th>MOVW @RW<br/>0+d8, RW4</th><th>MOVW II<br/>RW0, RW5</th><th>MOVW @RW MOVW<br/>0+d8, RW5 RW0,</th><th>RW6</th><th>MOVW @RW MOVW<br/>0+d8, RW6 RW0,</th><th>MOVW<br/>RW0, RW7</th><th>MOVW @RW<br/>0+d8, RW7</th></th<>                                                                                                                               | 0+           | MOVW<br>RW0, RW0       | MOVW @RW<br>0+d8, RW0 | RW1               | >                              | MOVW<br>RW0, RW2    |                       | MOVW<br>RW0, RW3                    | MOVW @RW MOVW<br>0+d8, RW3 RW0, | MOVW<br>RW0, RW4    | MOVW @RW<br>0+d8, RW4            | MOVW II<br>RW0, RW5                   | MOVW @RW MOVW<br>0+d8, RW5 RW0,  | RW6                                  | MOVW @RW MOVW<br>0+d8, RW6 RW0,    | MOVW<br>RW0, RW7                     | MOVW @RW<br>0+d8, RW7 |
| MOVW         RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <del>,</del> | MOVW<br>RW1, RW0       | MOVW @RW<br>1+d8, RW0 | 5                 | •MOVW @RW<br>1+d8, RW1         |                     | MOVW @R<br>1+d8, RW2  | MOVW<br>RW1, RW3                    | MOVW @RW<br>1+d8, RW3           | MOWW<br>RW1, RW4    | •MOVW @RW<br>1+d8, RW4           | MOVW I                                | MOVW @RW<br>1+d8, RW5            | MOVW<br>RW1, RW6                     | MOVW @RW<br>1+d8, RW6              | MOVW<br>RW1, RW7                     | MOVW @RW<br>1+d8, RW7 |
| MOUVU         MOUVU         BRW1         MOUVU         BRW1         MOUVU         BRW1         RW3. RW1         MOUVU         BRW1         RW3. RW2         MOUVU         BRW1         RW3. RW2         MOUVU         BRW1         RW4. RW1         MOUVU         BRW1         RW4. RW2         AHB. RW1         BRW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | +2           | MOVW<br>RW2, RW0       | MOVW @RW<br>2+d8, RW0 | sw1               | •MOVW @RW<br>2+d8, RW1         | ~                   | MOVW @RW<br>2+d8, RW2 | MOVW<br>RW2, RW3                    | MOVW @RW<br>2+d8, RW3           | MOVW<br>RW2, RW4    | •MOVW @RW<br>2+d8, RW4           | MOVW<br>RW2, RW5                      | MOVW @RW<br>2+d8, RW5            | MOVW<br>RW2, RW6                     | MOVW @RW MOVW<br>2+d8, RW6 RW2,    | MOVW<br>RW2, RW7                     | MOVW @RW<br>2+d8, RW7 |
| MOUW         MOUW         BRW         BRW <t< th=""><td>+3</td><td>MOVW<br/>RW3, RW0</td><td>MOVW @RW<br/>3+d8, RW0</td><td>MOVW<br/>RW3, RW1</td><td>MOVW @RW<br/>3+d8, RW1</td><td>-</td><td>MOVW @RW<br/>3+d8, RW2</td><td>MOVW<br/>RW3, RW3</td><td>MOVW @RW<br/>3+d8, RW3</td><td>MOWW<br/>RW3, RW4</td><td>MOVW @RW<br/>3+d8, RW4</td><td>MOVW<br/>RW3, RW5</td><td>MOVW @RW<br/>3+d8, RW5</td><td>MOVW<br/>RW3, RW6</td><td>MOVW @RW<br/>3+d8, RW6</td><td>MOVW<br/>RW3, RW7</td><td>MOVW @RW<br/>3+d8, RW7</td></t<>                                                                                                                               | +3           | MOVW<br>RW3, RW0       | MOVW @RW<br>3+d8, RW0 | MOVW<br>RW3, RW1  | MOVW @RW<br>3+d8, RW1          | -                   | MOVW @RW<br>3+d8, RW2 | MOVW<br>RW3, RW3                    | MOVW @RW<br>3+d8, RW3           | MOWW<br>RW3, RW4    | MOVW @RW<br>3+d8, RW4            | MOVW<br>RW3, RW5                      | MOVW @RW<br>3+d8, RW5            | MOVW<br>RW3, RW6                     | MOVW @RW<br>3+d8, RW6              | MOVW<br>RW3, RW7                     | MOVW @RW<br>3+d8, RW7 |
| MOVW         MOVW         BRW         BRW <t< th=""><td>+4</td><td>MOVW<br/>RW4, RW0</td><td>MOVW @RW<br/>4+d8, RW0</td><td>MOVW<br/>RW4, RW1</td><td>MOVW @RW<br/>4+d8, RW1</td><td>~</td><td>MOVW @RW<br/>4+d8, RW2</td><td>MOVW<br/>RW4, RW3</td><td>MOVW @RW<br/>4+d8, RW3</td><td>MOWW<br/>RW4, RW4</td><td>MOVW @RW<br/>4+d8, RW4</td><td>MOVW<br/>RW4, RW5</td><td>MOVW @RW<br/>4+d8, RW5</td><td>MOVW<br/>RW4, RW6</td><td>@RW<br/>RW6</td><td>MOVW<br/>RW4, RW7</td><td>MOVW @RW<br/>4+d8, RW7</td></t<>                                                                                                                                          | +4           | MOVW<br>RW4, RW0       | MOVW @RW<br>4+d8, RW0 | MOVW<br>RW4, RW1  | MOVW @RW<br>4+d8, RW1          | ~                   | MOVW @RW<br>4+d8, RW2 | MOVW<br>RW4, RW3                    | MOVW @RW<br>4+d8, RW3           | MOWW<br>RW4, RW4    | MOVW @RW<br>4+d8, RW4            | MOVW<br>RW4, RW5                      | MOVW @RW<br>4+d8, RW5            | MOVW<br>RW4, RW6                     | @RW<br>RW6                         | MOVW<br>RW4, RW7                     | MOVW @RW<br>4+d8, RW7 |
| MOVW         MOVW         @RW         MOVW         MOVW         MOVW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | +            |                        | MOVW @RW<br>5+d8, RW0 | SW1               | MOVW @RW<br>5+d8, RW1          | ~                   | MOVW @RW<br>5+d8, RW2 | MOVW<br>RW5, RW3                    | MOVW @RW<br>5+d8, RW3           | MOWV<br>RW5, RW4    | MOVW @RW<br>5+d8, RW4            | MOVW II<br>RW5, RW5                   | MOVW @RW<br>5+d8, RW5            | MOVW<br>RW5, RW6                     | / @RW<br>RW6                       | MOVW<br>RW5, RW7                     | MOVW @RW<br>5+d8, RW7 |
| MOVW         MOVW         BRW7, RW1         MOVW         BRW1, RW1         MOVW         BRW1         RW1, RW2         T-46, RW1         MOVW         BRW1         MOVW         BRW1         MOVW         BRW1         BW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 9+           |                        | MOVW @RW<br>6+d8, RW0 | W1                | MOVW @RW<br>6+d8, RW1          | MOVW<br>RW6, RW2    | MOVW @RW<br>6+d8, RW2 | MOVW<br>RW6, RW3                    |                                 | MOWW<br>RW6, RW4    | MOVW @RW<br>6+d8, RW4            | MOVW<br>RW6, RW5                      | MOVW @RW<br>6+d8, RW5            | v<br>; RW6                           | RW6                                | MOVW<br>RW6, RW7                     | MOVW @RW<br>6+d8, RW7 |
| MOVW         MOVW@RW0         MOVW@RW0         MOVW@RW0         MOVW@RW0         MOVW@RW0         MOVW@RW1         MOVW@RW1 <th< th=""><td>7+</td><td>MOVW<br/>RW7, RW0</td><td>MOVW @RW<br/>7+d8, RW0</td><td>W1</td><td>MOVW @RW<br/>7+d8, RW1</td><td>MOVW<br/>RW7, RW2</td><td>MOVW @RW<br/>7+d8, RW2</td><td>MOVW<br/>RW7, RW3</td><td>MOVW @RW<br/>7+d8, RW3</td><td>MOWV<br/>RW7, RW4</td><td>MOVW @RW<br/>7+d8, RW4</td><td>MOVW<br/>RW7, RW5</td><td>~</td><td>v<br/>, RW6</td><td>@RW<br/>RW6</td><td>MOVW<br/>RW7, RW7</td><td>MOVW @RW<br/>7+d8, RW7</td></th<> | 7+           | MOVW<br>RW7, RW0       | MOVW @RW<br>7+d8, RW0 | W1                | MOVW @RW<br>7+d8, RW1          | MOVW<br>RW7, RW2    | MOVW @RW<br>7+d8, RW2 | MOVW<br>RW7, RW3                    | MOVW @RW<br>7+d8, RW3           | MOWV<br>RW7, RW4    | MOVW @RW<br>7+d8, RW4            | MOVW<br>RW7, RW5                      | ~                                | v<br>, RW6                           | @RW<br>RW6                         | MOVW<br>RW7, RW7                     | MOVW @RW<br>7+d8, RW7 |
| MOVW         MOVW@RW1         MOVW@RW2         MOVW@RW2         MOVW@RW2         MOVW@RW2         MOVW@RW2         MOVW@RW2         MOVW@RW3         MOV         MOVW@RW3         MOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | +8           | MOVW<br>@RW0, RW0      | MOVW@RW0<br>+d16, RW0 | , RW1             | MOVW@RW0<br>+d16, RW1          | MOVW<br>@ RW0, RW2  | MOVW@RW0<br>+d16, RW2 | MOVW<br>@RW0, RW3                   | 2                               | MOWV<br>@RW0,RW4    |                                  | MOVW MOVW@RW0<br>@RW0, RW5, +d16, RW5 | <u> </u>                         | MOVW MOVW@RWC<br>@RW0, RW6 +d16, RW6 | <u> </u>                           | MOVW MOVW@RW<br>@RW0, RW7, +d16, RW7 | MOVW@RW0<br>+d16, RW7 |
| MOVW         MOVW@RW2         MOV         MOVW@RW2         MOVW@RW3         MOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6+           | MOVW<br>@RW1, RW0      | MOVW@RW1<br>+d16, RW0 | MOVW<br>@RW1, RW1 | MOVW@RW1<br>+d16, RW1          | MOVW<br>@ RW1, RW2  | MOVW@RW1<br>+d16, RW2 | MOVW MOVW@RW<br>@RW1, RW3 +d16, RW3 | MOVW@RW1<br>+d16, RW3           | MOWW<br>@RW1,RW4    | MOV W@ RW1<br>+d16, RW4          | @RW1, RW5 +d16, RW5                   | ' _ '                            | MOVW MOVW@RW<br>@RW1, RW6 +d16, RW6  | - ·                                | MOVW<br>@RW1, RW7                    | MOVW@RW1<br>+d16, RW7 |
| MOVW         MOVW@RW3         MOVW         MOVW@RW3         MOV         MOVW@RW3         MOV         MOVW@RW3         MOV         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ¥+           | MOVW<br>@RW2, RW0      | MOVW@RW2<br>+d16, RW0 | MOVW<br>@RW2, RW1 | MOVW@RW2<br>+d16, RW1          | ~                   | MOVW@RW2<br>+d16, RW2 | MOVW MOVW@RW<br>@RW2, RW3 +d16, RW3 | MOVW@RW2<br>+d16, RW3           | MOWW<br>@RW2,RW4    | MOVW@RW2<br>+d16, RW4            | MOVW<br>@RW2, RW5                     | MOVW@RW2<br>+d16, RW5            | MOVW MOVW@RW<br>@RW2, RW6 +d16, RW6  | 2                                  | MOVW<br>@RW2, RW7                    | MOVW@RW2<br>+d16, RW7 |
| MOVW MOVW@RW0 MOVW @ MOVW@RW0 MOVW @ MOVW@RW0<br>@RW0+, RW0 + RW7, RW0 RW0+, RW1 + RW7, RW1 RW0+, RW2 + RW2 RW2<br>MOVW mOVW@RW1 MOVW @ MOVW@ MOVW@ RW1+, RW1 + RW1+, RW2 + RW2 RW1<br>@RW1+, RW0 + RW1, RW0 RW1+, RW1+, RW1+, RW2 + RW2 RW2<br>MOVW @PC+ MOVW @ PC+ MOVW @ MOVW @PC+ MOVW @ PC+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | B+           | MOVW<br>@RW3, RW0      | MOVW@RW3<br>+d16, RW0 | RW1               | MOVW@RW3<br>+d16, RW1          | ~ .                 | MOVW@RW3<br>+d16, RW2 | MOVW<br>@RW3, RW3                   | MOVW@RW3<br>+d16, RW3           | MOWW<br>@RW3,RW4    | MOV W@RW3<br>+d16, RW4           | @RW3, RW5                             | MOVW@RW3<br>+d16, RW5            | MOVW<br>@RW3, RW6                    | MOVW@RW3<br>+d16, RW6              | MOVW<br>@RW3, RW7                    | MOVW@RW3<br>+d16, RW7 |
| MOVW 'MOVW@RW1 MOVW @ 'MOVW@RW1 MOVW @ 'MOVW@RW1<br>@RW1+, RW0' +RW7, RW1 '+RW7, RW1 '+RW7, RW2<br>MOVW 'MOVW @P-HMOVW @ 'MOVW @P-HMOVW @ MOVW @PC-<br>@RW2+, RW0' M16, RW0 RW2+, RW1 ' d16, RW1 RW2+, RW2 ' d16, RW2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0+<br>+      | MOVW<br>@RW0+, RW0     | MOVW@RW0<br>+RW7, RW0 | MOVW<br>RW0+, R   | MOVW@RW0<br>+RW7, RW1          |                     | MOVW@RW0<br>+RW7, RW2 | MOVW @<br>RW0+, RW3                 | MOVW@RW0<br>+RW7, RW3           | MOVW @<br>RW0+, RW4 | MOVW@RW0<br>+RW7, RW4            | MOVW @ 1<br>RW0+, RW5                 | MOVW@RW0<br>+RW7, RW5            | RW6                                  | MOVW@RW0<br>+RW7, RW6              | MOVW @<br>RW0+, RW7                  | MOVW@RW0<br>+RW7, RW7 |
| MOVW MOVW @PC+IMOVW @ MOVW @PC+ MOVW @PC+<br>@RW2+, RW0' d16, RW0 RW2+, RW1 ' d16, RW1 RW2+, RW2 ' d16, RW2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Q+           | MOVW<br>@RW1+, RW0     | MOVW@RW1<br>+RW7, RW0 | MOVW<br>RW1+, RI  | MOVW@RW1<br>+RW7, RW1          |                     | MOVW@RW1<br>+RW7, RW2 | MOVW @<br>RW1+, RW3                 | MOVW@RW1<br>+RW7, RW3           | MOWV @<br>RW1+, RW4 | MOVW@RW1<br>+RW7, RW4            | MOVW @ 'I<br>RW1+, RW5 '-             | @ 'MOVW@RW1<br>5 '+RW7, RW5      | RW6                                  | @RW1<br>RW6                        | MOVW @ MOVW<br>RW1+, RW7 +RW7        | MOVW@RW1<br>+RW7, RW7 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ¥            | MOVW<br>@RW2+, RW0<br> | MOVW @PC+             | MOVW<br>RW2+, RI  | @ 'MOVW @PC+<br>RW1 ' d16, RW1 |                     | MOVW @PC+             | MOVW @<br>RW2+, RW3                 | MOVW @PC+                       | MOVW @<br>RW2+, RW4 | MOVW @PC+ MOVW<br>d16, RW4 RW2+, | RW5                                   | MOVW @PC+ MOVW<br>d16, RW5 RW2+, | RW6 @                                | MOVW @PC+ MOVW<br>d16, RW6 RW2+, F | No.                                  | @ 'MOVW @PC+          |
| @ IMOVW addr MOVW @ IMOVW addr<br>RW1 1 16, RW1 RW3+, RW2 16, RW2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ц<br>+       | , RWC                  | MOVW addr<br>16, RW0  | MOVW<br>RW3+      | OVW addr<br>16, RW1            | MOVW @<br>RW3+, RW2 | MOVW addr<br>16, RW2  | MOVW @<br>RW3+, RW3                 | MOVW addr<br>16, RW3            | MOVW @<br>RW3+, RW4 | MOVW addr<br>16, RW4             | MOVW @ 1<br>RW3+, RW5                 | MOVW addr<br>16, RW5             | v addr MOVW @ 1<br>16, RW5 RW3+, RW6 | MOVW addr<br>16, RW6               | MOVW @<br>RW3+, RW7                  | MOVW addr<br>16, RW7  |

| 7EH)         |
|--------------|
| First byte = |
| Ri, ea (     |
| 4.3.19 CH    |
| Table 4.     |

238

| Chapter 4: Instructions |
|-------------------------|
|-------------------------|

|          | 0.0              | 1 0                                   | 2 0              | 3.0                                                         | 40               | 5 0                                 | 6 0                            | 7 0                     | 8 0              | 06                                                          | A 0                           | BO                  | C 0                              | D 0                                  | E 0              | ΕO                     |
|----------|------------------|---------------------------------------|------------------|-------------------------------------------------------------|------------------|-------------------------------------|--------------------------------|-------------------------|------------------|-------------------------------------------------------------|-------------------------------|---------------------|----------------------------------|--------------------------------------|------------------|------------------------|
| 0+       | XCH<br>R0, R0    | · XCH R0,<br>) @RW0+d8                | XCH<br>R1, R0    | -XCH R1,<br>@RW0+d8                                         | XCH<br>R2, R0    | · XCH R2,<br>0 <sup>-</sup> @RW0+d8 | XCH<br>R3, R0                  | - XCH R3,<br>0' @RW0+d8 | XCH<br>R4, R0    | XCH R4,<br>@RW0+d8                                          | XCH R5, R0                    | ХСH<br>@RW          | XCH<br>R6, R0                    | - XCH R6,<br>0 @RW0+d8               | XCH<br>R7, R0    | XCH R7,<br>@RW0+d8     |
| +        | XCH<br>R0, R1    | XCH R0,<br>@RW1+d8                    | XCH              | iXCH R1,<br>R1, R1 i @RW1+d8                                | XCH<br>R2, R1    | XCH R2,<br>@RW1+d8                  | XCH<br>R3, R1                  | - XCH R3,<br>1- @RW1+d8 | XCH<br>R4, R1    | XCH R4,<br>@RW1+d8                                          | XCH<br>R5, R1                 | XCH R5,<br>@RW1+d8  | XCH<br>R6, R1                    | XCH R6,<br>@RW1+d8                   | XCH<br>R7, R1    | NOTW R7,<br>@RW1+d8    |
| +2       | XCH R0, R2       | CH R0,<br>@RW2+d8                     | XCH              | ,XCH R1,<br>XCH R1,<br>R1, R2 + @RW2+d8                     | XCH<br>R2, R2    | XCH R2,<br>CW2+d8                   | XCH R3, R2                     | XCH R3,<br>2 @RW2+d8    | XCH<br>R4, R2    | XCH R4,<br>@RW2+d8                                          | R5, R2                        | XCH R5,<br>@RW2+d8  |                                  | XCH R6,<br>@RW2+d8                   | XCH<br>R7, R2    | XCH R7,<br>@RW2+d8     |
| +3       | XCH R0, R3       | CH R0,<br>@RW3+d8                     | XCH              | R1, R3 i @RW3+d8                                            | XCH<br>R2, R3    | XCH R2,<br>0 @RW3+d8                | XCH<br>R3, R3                  |                         | CH<br>R4, R3     | XCH R4,<br>@RW3+d8                                          | R5, R3                        | © RW3+d8            | XCH                              | XCH<br>@RV                           | <u> </u>         | NOTW R7,<br>@RW3+d8    |
| +4       | XCH XCH X        | CH R0,<br>@RW4+d8                     | XCH              | XCH R1,<br>XCH R1,<br>R1, R4, @RW4+d8                       | XCH<br>R2, R4    | ×                                   | XCH<br>R3, R4                  | XCH R3, X<br>2 @RW4+d8  | CH<br>R4, R4     | ©H<br>@RW                                                   | ZCH<br>XCH<br>R5, R4          | CH R5,<br>@RW4+d8   |                                  | XCH R6,<br>0 @RW4+d8                 | XCH<br>R7, R4    | NOTW R7,<br>@RW4+d8    |
| +5       | XCH R0, R5       | CH R0,<br>@RW5+d8                     | XCH              | XCH R1,<br>R1, R5 , @RW5+d8                                 | XCH<br>R2, R5    | ×                                   | XCH<br>R3, R5                  | XCH R3,<br>@RW5+d8      | CH<br>R4, R5     | XCH R4,<br>@RW5+d8                                          | XCH<br>R5, R5,                | XCH R5,<br>@RW5+d8  | XCH<br>R6, R5,                   | XCH R6, >                            | XCH<br>R7, R5    | XCH R7,<br>@RW5+d8     |
| 9+       | XCH<br>R0, R6    | CH R0,<br>@RW6+d8                     | К<br>К<br>С<br>Н | XCH R1,<br>R1, R6, @RW6+d8                                  | XCH<br>R2, R6    | XCH R2,<br>@RW6+d8                  | XCH<br>R3, R6                  | XCH R3,<br>@RW6+d8      | XCH<br>R4, R6    | XCH R4,<br>@RW6+d8                                          | XCH<br>R5, R6                 | XCH R5,<br>@RW6+d8  | XCH<br>R6, F                     | XCH R6,<br>86, @RW6+d8               | XCH<br>R7, R6,   | XCH R7,<br>@RW6+d8     |
| 7+       | XCH<br>R0, R7    | XCH R0,<br>@RW7+d8                    | XCH<br>R1, R7    | XCH R1,<br>@RW7+d8                                          | XCH<br>R2, R7    | ×                                   | XCH<br>R3, R7                  | $\sim$                  | XCH<br>R4, R7    | XCH R4,<br>@RW7+d8                                          | XCH<br>R5,                    | XCH R5,<br>@RW7+d8  | R6, F                            | XCH R6,<br>@RW7+d8                   | $\sim$           | XCH R7,<br>@RW7+d8     |
| +        | XCH<br>R0, @RW0  | XCH R0,<br>@RW0+d16                   | XCH<br>R1, @RW0  | XCH R1,<br>@RW0+d16                                         | XCH<br>R2, @RW0  | XCH<br>@RW(                         | XCH<br>R3, @RW0                | XCH<br>@RW0+            | XCH<br>R4, @RW0  | XCH R4,<br>@RW0+d16                                         | XCH<br>R5, @RV                | V0 @RW0+d16 R6      | XCH<br>R6, @RW0                  | × .                                  | XCH<br>R7, @RW0  | XCH R7,<br>@RW0+d16    |
| 6+       | XCH<br>R0, @RW1  | XCH R0,<br>@RW1+d16                   | XCH<br>R1, @RW1  | XCH R1,<br>@RW1+d16                                         | XCH<br>R2, @RW1  |                                     | XCH<br>R3, @RW1                | XCH R3,<br>@RW1+d16     | XCH<br>R4        | R4,<br>V1+d16                                               | XCH<br>R5, @RW1               | XCH R5,<br>@RW1+d16 | H<br>@RW1                        |                                      | XCH<br>R7, @RW1  | XCH R7,<br>@RW1+d16    |
| ¥+       | XCH<br>R0, @RW2  | R0,<br>d16, A                         |                  | XCH R1, @RW2 @RW2+d16, A                                    | ×                | XCH R2,<br>@RW2+d16, A              | XCH<br>R3, @RW2                | XCH R3,<br>@RW2+d16, A  | ÅČH<br>R4,       | @RW2 @RW2+d16, A                                            | @RW2                          | 0                   | XCH<br>R6, @RW2                  | XCH R6,<br>@RW2+d16, A               | XCH<br>R7, @RW2  | XCH R7,<br>@RW2+d16, A |
| +B       |                  | XCH R0,<br>@RW3+d16                   | XCH<br>R1, @RW3  | XCH 'XCH R1,<br>R1, @RW3 <sup>+</sup> @RW3+d16              | , × ,            | XCH R2,<br>@RW3+d16                 | XCH<br>R3, @RW3                | XCH R3,<br>@RW3+d16     | XCH<br>R4,       | XCH R4,<br>@RW3 @RW3+d16                                    | @RW3                          | XCH R5,<br>@RW3+d16 |                                  | XCH XCH KG,<br>R6, @RW3 @RW3+d16     | XCH<br>R         | XCH R7,<br>@RW3+d16    |
| Ŷ        | XCH<br>R0, @RW0+ | CH RO,<br>@RW0+RW7                    |                  | XCH 'XCH R1,<br>R1, @RW0+'@RW0+RW7                          | $\sim$           | XCH R2,<br>@RW0+RW7                 | ~ -                            |                         | R4, ®            | XCH CH R4,<br>R4, @RW0+ @RW0+RW7                            | RW0+                          |                     |                                  | XCH R6,<br>@RW0+RW7                  | XCH<br>R7, @RW0+ | XCH R7,<br>@RW0+RW7    |
| <b>P</b> | XCH<br>R0, @RW1+ | XCH + XCH R0,<br>R0, @RW1+ 1 @RW1+RW7 |                  | XCH <sup>·</sup> XCH R1,<br>R1, @RW1+ <sup>'</sup> @RW1+RW7 | XCH<br>R2, @RW1+ | XCH R2,<br>@RW1+RW7                 | XCH<br>R3, @RW1+               | - XCH R3,<br>+ @RW1+RW7 | XCH<br>R4, @RW1+ | XCH <sup>-</sup> XCH R4,<br>R4, @RW1+ <sup>-</sup> @RW1+RW7 | XCH<br>R5, @RW1+              | XCH R5,<br>@RW1+RW7 | ~                                | KCH · XCH R6,<br>R6, @RW1+' @RW1+RW7 | XCH<br>R7, @RW1+ | XCH R7,<br>@RW1+RW7    |
| ų        | XCH<br>R0, @RW2+ | XCH R0,<br>@PC+d16                    | XCH<br>R1, @RW2+ | XCH · XCH R1,<br>R1, @RW2+ <sup>†</sup> @PC+d16             | XCH<br>R2, @RW2+ | - XCH R2,<br>@PC+d16                | XCH<br>R3, @RW2+               | - XCH R3,<br>+ @PC+d16  | XCH<br>R4, @RW2+ | XCH R4,<br>@PC+d16                                          | XCH<br>R5, @RW2+              | XCH R5,<br>@PC+d16  | XCH<br>R6, @RW2+                 | - XCH R6,<br>@PC+d16                 | XCH<br>R7, @RW2+ | XCH R7,<br>@PC+d16     |
| 4<br>+   | XCH<br>R0, @RW3+ | XCH R0,<br>addr16                     | XCH<br>R1, @RW3+ | XCH R1,<br>+ addr16                                         | XCH<br>R2, @RW3+ | XCH R2,<br>addr16                   | XCH · XCH<br>R3, @RW3+' addr16 | · XCH R3,<br>+' addr16  | XCH<br>R4, @RW3+ | XCH R4,<br>addr16                                           | XCH · XCH<br>R5, @RW3+ addr16 | XCH R5,<br>+ addr16 | XCH XCH XCH<br>R6, @RW3+' addr16 | XCH R6,<br>addr16                    | XCH<br>R7, @RW3+ | XCH R7,<br>addr16      |

Table 4.3.20 XCHW RWi, ea (First byte = 7FH)

|    | 0 0                                             | 1 0                                                                                         |                                      | 3.0                                                            | 4 0                 | 50                                   | 6 0                                                        | 7.0                                   |                     | 0.6                                   | A 0                 | _                               |                                                      | BO                                                 | B0 C0                                                                    | B0 C0 D0                                                                                  |
|----|-------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------|---------------------|--------------------------------------|------------------------------------------------------------|---------------------------------------|---------------------|---------------------------------------|---------------------|---------------------------------|------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 0+ | XCHW '>                                         | XCHW RW0, XCHW<br>@RW0+d8 RW1                                                               | , RWO                                | XCHW RW1,<br>@RW0+d8                                           | XCHW<br>RW2, RW0    | XCHW RW2, XCHW<br>@RW0+d8 RW3,       | XCHW<br>RW3, RW0                                           | XCHW RW3<br>@RW0+d8                   | XCHW<br>RW4, RW0    | × ·                                   | XCHW RW4<br>@RW0+d8 | HW RW4 XCHW<br>@RW0+d8 RW5, RW0 | <u> </u>                                             | XCHW XCHW RW5, X<br>RW5, RW0 - @RW0+d8             | XCHW XCHW RW5, XCHW XCHW XCHW XCHW XCHW XCHW                             | XCHW XCHW RW5, X<br>RW5, RW0 - @RW0+d8                                                    |
| +  | XCHW XCH<br>RW0, RW1 @                          | XCHW RW0, XCHW<br>@RW1+d8 RW1,                                                              | RV                                   | CHW XCHW RW1,<br>RW1, RW1 @RW1+d8                              | XCHW<br>RW2, RW1    | XCHW RW2,<br>@RW1+d8                 | XCHW<br>RW3, RW1                                           | XCHW RW3<br>@RW1+d8                   | XCHW<br>RW4, RW1    | XCHW<br>@RW                           | CHW RW4<br>@RW1+d8  | <u> </u>                        | XCHW XCHW RW5,<br>RW5, RW1 @RW1+d8                   | <u> </u>                                           | XCHW XCHW RW5, XCHW V                                                    | XCHW XCHW RW5, X<br>RW5, RW1 @RW1+d8                                                      |
| +2 | XCHW XCHW XC                                    | XCHW RW0, XCHW<br>@RW2+d8 RW1,                                                              | RW.                                  | XCHW RW1,<br>@RW2+d8                                           | XCHW<br>RW2, RW2    | XCHW RW2,<br>@RW2+d8                 | XCHW<br>RW3, RW2                                           | XCHW RW3<br>@RW2+d8                   | XCHW<br>RW4, RW2    | XCHW RW4<br>@RW2+d8                   | 48<br>d8            | XCHW<br>RW5, RW2                | XCHW<br>RW5, RW2                                     | $\sim$                                             | XCHW XCHW RW5, XCHW<br>RW5, RW2 @RW2+d8 RW6, RW2                         | XCHW XCHW RW5, X<br>RW5, RW2 @RW2+d8                                                      |
| +3 | XCHW<br>RW0, RW3                                | CHW XCHW RW0, XCHW<br>RW0, RW3 @RW3+d8 RW1                                                  | XCHW<br>RW1, RW:                     | CHW XCHW RW1,<br>RW1, RW3 @RW3+d8                              | XCHW<br>RW2, RW3    | XCHW RW2,<br>@RW3+d8                 | XCHW<br>RW3, RW3                                           | XCHW RW3, XCHW<br>@RW3+d8 RW4,        | XCHW<br>RW4, RW3    | XCHW RW4<br>@RW3+d8                   | 4                   | XCHW<br>RW5, RW3                | XCHW<br>RW5, RW3                                     |                                                    | XCHW XCHW RW5, XCHW<br>RW5, RW3 @RW3+d8 RW6, RW3                         | XCHW XCHW RW5, X<br>RW5, RW3 @RW3+d8                                                      |
| +4 | XCHW XCHW<br>RW0, RW4 @RV                       | ZW4 - @RW4+d8 RW1,                                                                          | Ϋ́Υ                                  | XCHW RW1, XCHW<br>4 @RW4+d8 RW2,                               | XCHW<br>RW2, RW4    | XCHW RW2,<br>@RW4+d8                 | XCHW<br>RW3, RW4                                           | XCHW RW3<br>@RW4+d8                   | XCHW<br>RW4, RW4    | XCHW RW4<br>@RW4+d8                   |                     | XCHW<br>RW5, RW4                | XCHW RW5,<br>RW4 @RW4+d8                             | XCHW XCHW RW5, XCHW<br>RW5, RW4 - @RW4+d8 RW6, RW4 | RW4 @RW4+d8 RW6, RW4                                                     | RW4 @RW4+d8                                                                               |
| +5 | XCHW<br>RW0, RW5                                | KCHW XCHW RW0, XCHW<br>RW0, RW5 @RW5+d8 RW1,                                                | XCHW<br>RW1, RW5                     | XCHW RW1, XCHW<br>@RW5+d8 RW2, I                               | XCHW<br>RW2, RW5    | XCHW RW2, XCHW<br>@RW5+d8 RW3,       | XCHW<br>RW3, RW5                                           | XCHW RW3 XCHW<br>@RW5+d8 RW4,         | XCHW<br>RW4, RW5    | XCHW RW4<br>@RW5+d8                   | ~                   | XCHW<br>RW5, RW5                | XCHW RW5,<br>RW5 @RW5+d8                             | XCHW<br>RW5 @RW                                    | XCHW RW5, XCHW<br>RW5 @RW5+d8 RW6, RW5                                   | XCHW RW5,<br>@RW5+d8                                                                      |
| 9+ | XCHW XC<br>RW0, RW6                             | XCHW RW0, XCHW<br>@RW6+d8 RW1,                                                              | RW6                                  | CHW RW1,<br>@RW6+d8                                            | XCHW<br>RW2, RW6    | XCHW RW2,<br>@RW6+d8                 | XCHW<br>RW3, RW6                                           | XCHW RW3 XCHW<br>@RW6+d8 RW4,         | XCHW<br>RW4, RW6    | XCHW RW4<br>@RW6+d8                   | XCHW<br>RW5,        | RW6                             | XCHW RW5,<br>@RW6+d8                                 | XCHW<br>RW6 @RW                                    | KCHW RW5, XCHW<br>RW6 @RW6+d8 RW6, RW6                                   | XCHW RW5,<br>@RW6+d8                                                                      |
| 7+ | XCHW<br>RW0, RW7                                | XCHW RW0, XCHW<br>@RW7+d8 RW1,                                                              | RW7                                  | XCHW RW1,<br>@RW7+d8                                           | XCHW<br>RW2, RW7    | XCHW RW2, XCHW<br>@RW7+d8 RW3,       | XCHW<br>RW3, RW7                                           | XCHW RW3 XCHW<br>@RW7+d8 RW4,         | XCHW<br>RW4, RW7    | XCHW RW4<br>@RW7+d8                   | XCHW<br>RW5,        | KCHW<br>RW5, RW7                | RW7                                                  | RW7                                                | KW7 @RW7+d8 RW6, RW7                                                     | XCHW RW5,<br>@RW7+d8                                                                      |
| 8+ | XCHW<br>RW0, @RWC                               | XCHW XCHW RW0, XCHW RW0, @RW0+d16 RW1, @                                                    | CHW RW0, XCHW CHW CHW CHW            | XCHW RW1,<br>@RW0+d16                                          | XCHW<br>RW2, @RW0   | XCHW RW2, XCHW<br>@RW0+d16 RW3, (    | CHW RW2, XCHW<br>@RW0+d16 RW3, @RW0,                       | XCHW RW3<br>@RW0+d16                  | XCHW<br>RW4, @RW0   | XCHW RW4<br>@RW0+d16                  | XCHW<br>RW5,        | XCHW<br>RW5, @RWQ               | @RW0                                                 | @RWQ @RW0+d16                                      | @RWQ @RW0+d16 RW6, @RW0                                                  | @RWQ @RW0+d16                                                                             |
| 6+ | XCHW<br>RW0, @RW1                               | XCHW XCHW RW0, XCHW XCHW RW1, XCHW RW1, XCHW RW0, @RW1, @RW1-416 RW1, @RW1, @RW1-416 RW2, @ | XCHW<br>RW1, @RW1                    | %CHW RW1,<br>@RW1+d16                                          | XCHW<br>RW2, @RW1   | XCHW RW2, XCHW<br>@RW1+d16 RW3, @    | XCHW<br>RW3, @RW1                                          | CHW RW3 XCHW<br>@RW1+d16 RW4, @       | XCHW<br>RW4, @RW1   | XCHW RW4<br>@RW1+d16                  | XCHW<br>RW5, @      | XCHW<br>RW5, @RW1               | ®RW1                                                 | ©RW1 @RW1+d16                                      | ©RW1 @RW1+d16 RW6, @RW1                                                  | ©RW1 @RW1+d16                                                                             |
| ¥+ | XCHW<br>RW0, @RW2                               | XCHW XCHW KWO, XCHW XCHW RW1, XCHW<br>RW0, @RW2, @RW2+d16 RW1, @RW2, @RW2+d16 RW2, @RW      | XCHW<br>RW1, @RW2                    | XCHW RW1,<br>@RW2+d16                                          | XCHW<br>RW2, @RW2   | XCHW RW2, XCHW<br>@RW2+d16 RW3, @    | @RW2+d16 RW3, @RW2                                         | XCHW RW3<br>@RW2+d16                  | XCHW<br>RW4, @RW2   | XCHW RW4 XCHW<br>@RW2+d16 RW5, @      | XCH<br>RW5          | w<br>@RW2                       | XCHW XCHW RW5,<br>RW5, @RW2 @RW2+d16                 | XCHW RW5,<br>@RW2+d16                              | TCHW RW5, TCHW           RW2         @RW2+d16           RW2         @RW2 | XCHW RW5,<br>@RW2+d16                                                                     |
| щ  | XCHW<br>RW0, @RW3                               | XCHW 'XCHW RW0, XCHW XCHW RW1,<br>RW0, @RW3 @RW3+d16 RW1, @RW3 @RW3+d16                     | XCHW<br>RW1, @RW3                    | XCHW RW1,<br>2 @RW3+d16                                        | XCHW<br>RW2, @RW3   | XCHW RW2, XCHW<br>@RW3+d16 RW3, @    | @RW3                                                       | XCHW RW3<br>@RW3+d16                  | XCHW<br>RW4, @RW3   | XCHW RW4<br>@RW3+d16                  | XCHW<br>RW5, @      | 0<br>@RW3                       | @RW3                                                 | RW3 @RW3+d16 RW6, @RW3                             | RW3 @RW3+d16 RW6, @RW3                                                   | TCHW RW5,<br>@RW3+d16                                                                     |
| ပ္ | XCHW R<br>W0, @RW0+                             | XCHW R'XCHW RWO, XCHW R'XCHW RW1,<br>W0, @RW0+ '@RW0+RW7 W1, @RW0+'@RW0+RW7                 | XCHW R<br>W1, @RW0+                  | R' XCHW RW1,<br>)+ @RW0+RW7                                    | XCHW R<br>W2, @RW0+ | XCHW RW2, XCHW<br>@RW0+RW7 W3, @     | - M                                                        | R XCHW RW3 XCHW<br>)+ @RW0+RW7 W4, @F | XCHW R<br>W4, @RW0+ | R XCHW RW4 XCHW<br>)+ @RW0+RW7 W5, @P | XCH'<br>W5,         | @RW0+                           | W R XCHW RW5,<br>@RW0+ @RW0+RW7                      | R' XCHW RW5, XCHW<br>RW0+! @RW0+RW7 W6, @RW0       | XCHW<br>W6, @RW(                                                         | W R'XCHW RW5, XCHW R'XCHW RW6, XCHW RW<br>@RW0+ @RW0+RW7 W6, @RW0+" @RW0+RW7 W7, @RW0+RW7 |
| q  | XCHW R<br>W0, @RW1-                             | XCHW R'XCHW RW0, XCHW R'XCHW RW1, XCHW W0, @RW1+ @RW1+RW7 W1, @RW1+RW7 W2, @RW1             | XCHW R<br>W1, @RW1+                  | R' XCHW RW1,<br>1+ @RW1+RW7                                    | XCHW R<br>W2, @RW1+ | XCHW RW2,<br>@RW1+RW7                | ©RW1+RW2, XCHW R' XCHW RW3<br>@RW1+RW7 W3, @RW1+' @RW1+RW7 |                                       | ۲۷                  |                                       | XCHW<br>W5, @       | ۲W                              | R' XCHW RW5,<br>3W1+ @RW1+RW7                        | R' XCHW RW5, XCHW<br>RW1+RW7 W6, @RW'              | R' XCHW RW5, XCHW<br>RW1+RW7 W6, @RW'                                    | R' XCHW RW5,<br>3W1+ @RW1+RW7                                                             |
| Щ+ | XCHW R'X<br>W0, @RW2+                           | RV2+ @PC +d16                                                                               | XCHW R'XCHW RW<br>W1, @RW2+' @PC+d16 | R' XCHW RW1, XCHW<br>2+' @PC+d16 W2, @F                        |                     | R XCHW RW2, XCHW<br>+ @PC+d16 W3, @F | SW2                                                        | R XCHW RW3 XCHW<br>2+ @PC+d16 W4, @R  |                     | XCHW RW4<br>@PC+d16                   | XCHW<br>W5, @       |                                 | R' XCHW RW5,<br>3W2+ @PC+d16                         | R' XCHW RW5, XCHW<br>RW2+ @PC+d16 W6, @RW2         | R' XCHW RW5, XCHW<br>RW2+ @PC+d16 W6, @RW2                               | R' XCHW RW5,<br>3W2+ @PC+d16                                                              |
| Ч+ | XCHW R <sup>1</sup> )<br>W0, @RW3+ <sup>1</sup> | <pre>KCHW RW0,<br/>addr16</pre>                                                             | XCHW<br>W1, @RW3                     | R <sup>i</sup> XCHW RW1, XCHW<br>3+ <sup>1</sup> addr16 W2, @I | RW3                 | R XCHW RW2, XCHW<br>+ addr16 W3, @F  | SW3                                                        | R XCHW RW3 XCHW<br>3+ addr16 W4, @F   | SW3                 | R XCHW RW4 XCHW<br>3+ addr16 W5, @    | XCHW R<br>W5, @RW3+ | R.<br>8W3+                      | R <sup>1</sup> XCHW RW5,<br>8W3+ <sup>1</sup> addr16 | XCHW RW5, XCHW<br>addr16 W6, @RW3                  | XCHW RW5, XCHW<br>addr16 W6, @RW3                                        | XCHW RW5, XCHW R' X<br>addr16 W6, @RW3+                                                   |