

# ML63512A/514A

## **User's Manual**

CMOS 4-bit microcontroller

FIRST EDITION ISSUE DATE: May 2000

FEUL63512A-01

#### NOTICE

- 1. The information contained herein can change without notice owing to product and/or technical improvements. Before using the product, please make sure that the information being referred to is up-to-date.
- 2. The outline of action and examples for application circuits described herein have been chosen as an explanation for the standard action and performance of the product. When planning to use the product, please ensure that the external conditions are reflected in the actual circuit, assembly, and program designs.
- 3. When designing your product, please use our product below the specified maximum ratings and within the specified operating ranges including, but not limited to, operating voltage, power dissipation, and operating temperature.
- 4. Oki assumes no responsibility or liability whatsoever for any failure or unusual or unexpected operation resulting from misuse, neglect, improper installation, repair, alteration or accident, improper handling, or unusual physical or electrical stress including, but not limited to, exposure to parameters beyond the specified maximum ratings or operation outside the specified operating range.
- 5. Neither indemnity against nor license of a third party's industrial and intellectual property right, etc. is granted by us in connection with the use of the product and/or the information and drawings contained herein. No responsibility is assumed by us for any infringement of a third party's right which may result from the use thereof.
- 6. The products listed in this document are intended for use in general electronics equipment for commercial applications (e.g., office automation, communication equipment, measurement equipment, consumer electronics, etc.). These products are not authorized for use in any system or application that requires special or enhanced quality and reliability characteristics nor in any system or application where the failure of such system or application may result in the loss or damage of property, or death or injury to humans. Such applications include, but are not limited to, traffic and automotive equipment, safety devices, aerospace equipment, nuclear power control, medical equipment, and life-support systems.
- 7. Certain products in this document may need government approval before they can be exported to particular countries. The purchaser assumes the responsibility of determining the legality of export of these products and will take appropriate and necessary steps at their own expense for these.
- 8. No part of the contents contained herein may be reprinted or reproduced without our prior permission.
- 9. MS-DOS is a registered trademark of Microsoft Corporation.

Copyright 2000 Oki Electric Industry Co., Ltd.

#### Preface

This manual describes the hardware of Oki's original CMOS 4-bit microcontrollers ML63512A and ML63514A.

Refer to the "nX-4/250, 300 Core Instruction Manual" for details of the 4-bit CPU core nX-4/250 which is built into the ML63512A and ML63514A.

The manuals related to the ML63512A and ML63514A are shown below.

- nX-4/250, 300 Core Instruction Manual: Describes the base architecture and instruction set of nX-4/250 core and nX-4/300 core.
- SASM63K User's Manual: Describes the structured assembler operation and assembler language specification.
- Dr.63514 User's Manual: Describes the hardware of the emulator.
- SID63K Debugger User's Manual: Describes the debugger commands.

This document is subject to change without notice.

| Classification  | Notation                                                                                                                                        | Description                                                                                                                                                                                                                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ■ Numeric value | xxh, xxH<br>xxb                                                                                                                                 | Represents a hexadecimal number.<br>Represents a binary number.                                                                                                                                                                                                                  |
| ■ Unit          | word, W<br>byte, B<br>nibble, N<br>mega-, M<br>kilo-, K<br>kilo-, k<br>milli-, m<br>micro-, µ<br>nano-, n<br>second, s (lower case)<br>KB<br>MB | 1 word = 16 bits<br>1 byte = 2 nibbles = 8 bits<br>1 nibble = 4 bits<br>10 <sup>6</sup><br>$2^{10} = 1024$<br>$10^3 = 1000$<br>$10^{-3}$<br>$10^{-6}$<br>$10^{-9}$<br>second<br>1 KB = 1 kilobyte = 1024 bytes<br>1 MB = 1 megabyte = 2 <sup>20</sup> bytes<br>= 1,048,576 bytes |
| Symbol          | Note:                                                                                                                                           | Gives more information about mistakable items.                                                                                                                                                                                                                                   |
| ■ Terminology   | "H" level<br>"L" level                                                                                                                          | Indicates high side voltage signal levels $V_{IH}$ and $V_{OH}$ as specified by the electrical characteristics.<br>Indicates low side voltage signal levels $V_{IL}$ and $V_{OL}$ as specified by the electrical characteristics.                                                |

#### Notation

Register description

| Invalid bit   | : | When read, a value of "1" is always obtained. Write operations are invalid. |
|---------------|---|-----------------------------------------------------------------------------|
| R/W attribute | : | "R" indicates data can be read and "W" indicates data can be written.       |

| CMPCON   | (04CH)<br>(R/W) | bit 3 | bit 2 | bit 1 | bit 0<br>CMPOUT |                                       |
|----------|-----------------|-------|-------|-------|-----------------|---------------------------------------|
|          |                 |       |       |       |                 | ······ Bit name<br>······ Invalid bit |
|          | L               |       |       |       |                 | Address                               |
|          |                 |       |       |       |                 | ······ R/W attribute                  |
| <u> </u> |                 |       |       |       |                 | ······ Register name                  |

### Table of Contents

#### Chapter 1 Overview

| 1.1 | Overview                                                  | 1-1  |
|-----|-----------------------------------------------------------|------|
| 1.2 | Features                                                  | 1-1  |
| 1.3 | Block Diagram                                             | 1-4  |
| 1.4 | Pin Configuration                                         | 1-5  |
|     | 1.4.1 ML63512A, ML63514A Pin Configurations               | 1-5  |
| 1.5 | Pin Descriptions                                          | 1-9  |
|     | 1.5.1 Descriptions of the Basic Functions of Each Pin     | 1-9  |
|     | 1.5.2 Descriptions of the Secondary Functions of Each Pin | 1-12 |
|     | 1.5.3 Unused Pin Processing                               | 1-13 |
| 1.6 | Basic Timing                                              | 1-14 |
|     | 1.6.1 Basic Timing of CPU Operation                       |      |
|     | 1.6.2 Port I/O Basic Timing                               | 1-14 |
|     | 1.6.3 Interrupt Basic Timing                              | 1-16 |
|     |                                                           |      |

#### Chapter 2 CPU and Memory Spaces

| 2.1 |        | iew                                                     |     |
|-----|--------|---------------------------------------------------------|-----|
| 2.2 | Regist | ters                                                    | 2-1 |
|     | 2.2.1  | Accumulator (A)                                         | 2-1 |
|     | 2.2.2  | Flag Register                                           | 2-1 |
|     |        | 2.2.2.1 Carry Flag (C)                                  |     |
|     |        | 2.2.2.2 Zero Flag (Z)                                   | 2-2 |
|     |        | 2.2.2.3 G Flag (G)                                      |     |
|     | 2.2.3  | Master Interrupt Enable Flag (MIE)                      |     |
|     |        | Current Bank Register (CBR), Extra Bank Register (EBR), |     |
|     |        | HL Register (HL), XY Register (XY)                      | 2-3 |
|     | 2.2.5  | Program Counter (PC)                                    | 2-4 |
|     |        | RA Registers (RA3, RA2, RA1, RA0)                       |     |
|     | 2.2.7  | Stack Pointer (SP) and Call Stack                       | 2-5 |
|     | 2.2.8  | Register Stack Pointer (RSP) and Register Stack         |     |
| 2.3 |        | ry Spaces                                               |     |
|     |        | Program Memory Space                                    |     |
|     |        | Data Memory Space                                       |     |
|     |        |                                                         |     |

#### Chapter 3 CPU Control Functions

| 3.1 | Overv  | iew                                         | 3-1 |
|-----|--------|---------------------------------------------|-----|
| 3.2 | Syster | m Reset Mode (RST)                          | 3-2 |
|     | 3.2.1  | Transfer to and State of System Reset Mode  | 3-2 |
| 3.3 | Halt N | 1ode                                        | 3-3 |
|     | 3.3.1  | Transfer to and State of Halt Mode          | 3-3 |
|     | 3.3.2  | Halt Mode Release                           | 3-4 |
|     |        | 3.3.2.1 Release of Halt Mode by Interrupt   | 3-4 |
|     |        | 3.3.2.2 Release of Halt Mode by RESETB Pin  | 3-4 |
|     | 3.3.3  | Melody Data Interrupt and Halt Mode Release | 3-5 |
|     | 3.3.4  | Note Concerning HALT Instruction            | 3-5 |

#### Chapter 4 Interrupt (INT)

| 4-1  |
|------|
| 4-3  |
| 4-10 |
| 4-10 |
| 4-11 |
| 4-11 |
|      |

#### Chapter 5 Clock Generator Circuit (OSC)

| 5.1 | Overview                              | 5-1 |
|-----|---------------------------------------|-----|
| 5.2 | Clock Generator Circuit Configuration | 5-1 |
| 5.3 | Low-Speed Clock Generator Circuit     | 5-2 |
| 5.4 | High-Speed Clock Generator Circuit    | 5-4 |
|     | System Clock Control                  |     |
| 5.6 | Frequency Control Register (FCON)     | 5-7 |
|     | System Clock Select Timing            |     |

#### Chapter 6 Time Base Counter (TBC)

| 6.1 | Overview                        | 6-1 |
|-----|---------------------------------|-----|
| 6.2 | Time Base Counter Configuration | 6-1 |
| 6.3 | Time Base Counter Registers     | 6-2 |
| 6.4 | Time Base Counter Operation     | 6-3 |

#### Chapter 7 Timers (TIMER)

| 7.1 | Overv | iew                                         | 7-1  |
|-----|-------|---------------------------------------------|------|
| 7.2 | Timer | Configuration                               | 7-1  |
| 7.3 | Timer | Registers                                   | 7-3  |
| 7.4 | Timer | Operation                                   | 7-10 |
|     | 7.4.1 | Timer Clock                                 | 7-10 |
|     | 7.4.2 | Timer Data Registers                        | 7-10 |
|     | 7.4.3 | Timer Counter Registers                     | 7-10 |
|     | 7.4.4 | Timer Interrupt Requests and Overflow Flags | 7-11 |
|     | 7.4.5 | Auto-Reload Mode Operation                  | 7-12 |
|     | 7.4.6 | Capture Mode Operation                      | 7-14 |
|     | 7.4.7 | Frequency Measurement Mode Operation        | 7-17 |

#### Chapter 8 Ports (INPUT, OUTPUT, I/O PORT)

| Overvi | ew                                                                                                                               | 8-1                                                                    |
|--------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
|        |                                                                                                                                  |                                                                        |
| Port 0 | to Port 6, Port 9 and Port A                                                                                                     | 8-2                                                                    |
| 8.3.1  |                                                                                                                                  |                                                                        |
| 8.3.2  | Port 0 to Port 6, Port 9 and Port A Registers                                                                                    | 8-6                                                                    |
| Port 7 |                                                                                                                                  | 8-19                                                                   |
| 8.4.1  | Port 7 Configuration                                                                                                             | 8-19                                                                   |
| 8.4.2  |                                                                                                                                  |                                                                        |
| 8.4.3  | Port 7 Secondary Functions                                                                                                       | 8-21                                                                   |
| Port 8 |                                                                                                                                  |                                                                        |
| 8.5.1  | Port 8 Configuration                                                                                                             | 8-22                                                                   |
| 8.5.2  | Port 8 Registers                                                                                                                 | 8-23                                                                   |
| Extern | al Interrupt                                                                                                                     | 8-24                                                                   |
| 8.6.1  | External Interrupt Overview                                                                                                      | 8-24                                                                   |
| 8.6.2  | External Interrupt Configuration                                                                                                 | 8-24                                                                   |
| 8.6.3  | External Interrupt Control Registers                                                                                             | 8-25                                                                   |
|        | Ports L<br>Port 0<br>8.3.1<br>8.3.2<br>Port 7<br>8.4.1<br>8.4.2<br>8.4.3<br>Port 8<br>8.5.1<br>8.5.2<br>Extern<br>8.6.1<br>8.6.2 | <ul> <li>8.3.2 Port 0 to Port 6, Port 9 and Port A Registers</li></ul> |

#### Chapter 9 Serial Port (SIO)

| 9.1 | Overvie  | W                                    | 9-1  |
|-----|----------|--------------------------------------|------|
| 9.2 | Serial F | Port Configuration                   | 9-1  |
| 9.3 | Serial F | Port Registers                       | 9-3  |
| 9.4 | Serial F | Port Operation Description           | 9-12 |
|     | 9.4.1    | Data Format                          | 9-12 |
|     | 9.4.2    | Send Operation Description           | 9-13 |
|     | 9.4.3    | Receive Operation Description        | 9-19 |
| 9.5 | Send/R   | eceive Data LSB/MSB First Select     | 9-25 |
|     | 9.5.1    | Selecting Send Data LSB/MSB First    | 9-25 |
|     | 9.5.2    | Selecting Receive Data LSB/MSB First | 9-26 |
|     |          |                                      |      |

#### Chapter 10 Melody Driver (MELODY)

| 10.1 | Overview                                  | 10-1 |
|------|-------------------------------------------|------|
|      | Melody Driver Configuration               |      |
|      | Melody Driver Registers                   |      |
|      | Melody Circuit Operation                  |      |
|      | 10.4.1 Tempo Data                         |      |
|      | 10.4.2 Melody Data                        |      |
|      | 10.4.3 Melody Circuit Application Example |      |
| 10.5 | Buzzer Circuit Operation                  |      |

#### Chapter 11 Level Detector

| 11.1 | Overview                             | 11-1 |
|------|--------------------------------------|------|
|      | Level Detector Configuration         |      |
|      | Level Detector Registers             |      |
|      | 11.3.1 Input Levels and Output Codes |      |
| 11.4 | Level Detector Operation             | 11-7 |

#### Chapter 12 Comparator (CMP)

| 12.1 | Overview                 | 12-1 |
|------|--------------------------|------|
| 12.2 | Comparator Configuration | 12-1 |
| 12.3 | Comparator Register      | 12-2 |
| 12.4 | Comparator Operation     | 12-3 |

#### Chapter 13 Backup Circuit (BACKUP)

| 13.1 | Overview                                                                  | 13-1 |
|------|---------------------------------------------------------------------------|------|
| 13.2 | Power Supply Circuit Configuration                                        | 13-2 |
|      | 13.2.1 Power Supply Circuit Configuration When Backup Circuit is Used     | 13-2 |
|      | 13.2.2 Power Supply Circuit Configuration When Backup Circuit is Not Used | 13-3 |
| 13.3 | Backup Circuit Register                                                   | 13-4 |
| 13.4 | Power Supply Circuit Operation                                            | 13-5 |

#### Appendixes

| Appendix A | List of Special Function Registers                        | Appendix-1  |
|------------|-----------------------------------------------------------|-------------|
| Appendix B | Package Dimensions                                        | Appendix-4  |
| Appendix C | Electrical Characteristics                                | Appendix-6  |
| Appendix D | Instruction List                                          | Appendix-22 |
| Appendix E | Mask Option                                               | Appendix-44 |
| Appendix F | Differences between the ML63512/514 and the ML63512A/514A | Appendix-46 |

|   | Chapter 1    | Overview                        | 1 |   |
|---|--------------|---------------------------------|---|---|
|   |              |                                 |   |   |
|   | Chapter 2    | CPU and Memory Spaces           | 2 |   |
|   | ·            | · ·                             |   |   |
|   | Chapter 3    | CPU Control Functions           | 3 |   |
|   | ·            |                                 |   | - |
|   | Chapter 4    | Interrupt (INT)                 | 4 |   |
|   | ·            |                                 |   |   |
|   | Chapter 5    | Clock Generator Circuit (OSC)   | 5 | ; |
|   | I            |                                 |   | - |
|   | Chapter 6    | Time Base Counter (TBC)         | 6 | ; |
|   | ·            |                                 |   |   |
|   | Chapter 7    | Timers (TIMER)                  | 7 |   |
|   | 1            |                                 |   | - |
|   | Chapter 8    | Ports (INPUT, OUTPUT, I/O PORT) | 8 | 3 |
|   |              |                                 |   |   |
|   | Chapter 9    | Serial Port (SIO)               | 9 |   |
|   |              |                                 |   |   |
|   | Chapter 10   | Melody Driver (MELODY)          | 1 | 0 |
|   |              |                                 |   |   |
|   | Chapter 11   | Level Detector                  | 1 | 1 |
|   |              |                                 |   |   |
| Γ | Chapter 12   | Comparator (CMP)                | 1 | 2 |
| L |              |                                 |   |   |
|   | Chapter 13   | Backup Circuit (BACKUP)         | 1 | 3 |
| L |              |                                 |   |   |
|   | Appendixes   |                                 |   |   |
|   | , .pponaix00 |                                 |   |   |

# Chapter 1

1

Overview

### Chapter 1 Overview

#### 1.1 Overview

The ML63512A and ML63514A are CMOS 4-bit microcontrollers with built-in level detector and operate at 0.9 V (min.).

The ML63512A and ML63514A are M63512 series mask ROM-version products of OLMS-63K family, which employs Oki's original CPU core nX-4/250.

The program memory capacity and data memory capacity of the ML63512A differ from those of the ML63514A.

48-pin TQFP and 64-pin TQFP packages are available for the ML63512A and ML63514A.

#### 1.2 Features

The ML63512A and ML63514A have the following features.

- a. Extensive instruction set
  - 407 instructions

Transfer, rotate, increment/decrement, arithmetic operations, compare, logic operations, mask operations, bit operations, ROM table reference, stack operations, flag operations, jump, conditional branch, call/return, control

- b. Wide variety of addressing modes
  - 4 types of data memory indirect addressing modes with current bank register, extra bank register, HL register and XY register
  - Data memory bank internal direct addressing mode
- c. Processing speed
  - 2 clocks per machine cycle, with most instructions executed in 1 machine cycle
  - Minimum instruction execution time: 61 µs (@ 32.768 kHz system clock)

1 µs (@ 2 MHz system clock)

- d. Clock generation circuit
  - Low-speed clock: Crystal oscillation or RC oscillation selected with mask option (30 to 80 kHz)
  - High-speed clock:
  - Ceramic oscillation or RC oscillation selected with software (2 MHz max.)
- e. Program memory space
  - ML63512A: 4K words
  - ML63514A: 8K words
  - The basic instruction length is 16 bits per word.
- f. Data memory space
  - ML63512A: 128 nibbles
  - ML63514A: 256 nibbles

g. Stack level

|          | Call stack level | Register stack level |
|----------|------------------|----------------------|
| ML63512A | 16               | 16                   |
| ML63514A | 16               | 16                   |

h. Ports

- Input ports: Selectable as input with pull-up resistor or high impedance input.
- Output ports: N-channel open drain output (can directly drive LEDs)
- I/O ports: Selectable as input with pull-up resistor or high impedance input. Selectable as n-channel open drain output or CMOS output.
- Can be interfaced with external peripherals that use a different power supply than this device uses. (Power to the output port is supplied from V<sub>DDI</sub> (separate power supply)).
- Number of ports:

|                | Input ports            | Output ports           | I/O ports               |
|----------------|------------------------|------------------------|-------------------------|
| 48-pin package | 1 port $\times$ 4 bits | 1 port $	imes$ 4 bits  | 6 ports $\times$ 4 bits |
| 64-pin package | 1 port $\times$ 4 bits | 1 port $	imes$ 4 bits  | 9 ports $	imes$ 4 bits  |
| Chip           | 1 port $\times$ 4 bits | 1 port $\times$ 4 bits | 9 ports $	imes$ 4 bits  |

#### i. Melody output function

- Melody sound frequency: 529 to 2979 Hz (@ 32.768 kHz)
- Tone length:
- 63 varieties 15 varieties
- Tempo: 15 varietiesMelody data: Stored in the program memory
- Number of output ports: 1 (dedicated pin)
- Buzzer driver signal output: 4 kHz (@ 32.768 kHz)

j. Level detector

- Conversion time: Approx. 183 μs (@ 32.768 kHz)
- Dedicated input pins: 2 pins (switched by software; for the secondary functions of the input ports)
   Detection level: 12 levels

#### k. Comparator

| ٠ | Offset voltage:  | 50 mV max. (V <sub>DD</sub> = 1.5 V) |
|---|------------------|--------------------------------------|
| ٠ | Comparison time: | Approx. 183 μs (@ 32.768 kHz)        |

- Number of channels: 1 (for the secondary functions of the input ports)
- I. System reset function
  - System reset through RESETB pin (connected to the internal 32 kHz sampling circuit) (RESETB pin can be pulled up by mask option)

m. Power supply backup

• Backup circuit (voltage multiplier) enables operation at 0.9 V minimum

| n. Time  | ers, counters         |             |                                                                                  |
|----------|-----------------------|-------------|----------------------------------------------------------------------------------|
| •        | 8-bit timer:          | 2 channels  |                                                                                  |
|          |                       |             | as auto-reload mode, capture mode,<br>ency measurement mode                      |
| •        | 15-bit TBC:           | 1 channel   |                                                                                  |
|          |                       |             | 4 Hz, 8 Hz, 16 Hz, 32 Hz, 64 Hz,128 Hz, 256 Hz,                                  |
|          |                       | 512 Hz, 1 k | Hz, 2 kHz signals can be read (@ 32.768 kHz)                                     |
| o. Seria | al port               |             |                                                                                  |
| •        | Mode:                 |             | Selectable as UART mode/synchronous mode                                         |
| •        | UART communicat       | tion speed: | 2TBCCLK, TBCCLK, 1/2TBCCLK, Timers 0 & 1 overflow                                |
|          |                       |             | 24 kbps Max. (when 2TBCCLK @ 80 kHz selected)                                    |
| •        | Clock frequency in    | synchronou  | ,                                                                                |
|          |                       | -           | 30 to 80 kHz (internal clock mode), external clock frequency                     |
| •        | Data length:          |             | 5 to 8 bits                                                                      |
| p. Inter | rupt sources          |             |                                                                                  |
| •        | External interrupt (  | 4 sources): | Selectable as rising edge/falling edge/both rising and falling edges             |
| •        | Internal interrupt (1 | 0 sources): | Time base interrupt $\times$ 4 (2, 4, 16, and 32 Hz @ 32.768 kHz)                |
|          |                       |             | Timer interrupt $\times$ 2                                                       |
|          |                       |             | Level detector interrupt $\times$ 1                                              |
|          |                       |             | Serial port reception interrupt $\times$ 1                                       |
|          |                       |             | Serial port transmission interrupt $\times$ 1<br>Melody end interrupt $\times$ 1 |
|          |                       |             |                                                                                  |
| q. Ship  | ping products         |             |                                                                                  |
|          | Packa                 | ae          | Product                                                                          |

| 11 51                                                                     |                                |
|---------------------------------------------------------------------------|--------------------------------|
| Package                                                                   | Product                        |
| Chip (60 pads)                                                            | ML63512A-xxxWA, ML63514A-xxxWA |
| <ul> <li>48-pin flat package (48TQFP)<br/>TQFP48-P-0707-0.50-K</li> </ul> | ML63512A-xxxTB, ML63514A-xxxTB |
| <ul> <li>64-pin flat package (64TQFP)<br/>TQFP64-P-1010-0.50-K</li> </ul> | ML63512A-xxxTP, ML63514A-xxxTP |
|                                                                           |                                |

xxx indicates the ROM code number.

- r. Operating temperature
  - −20 to +70°C

s. Power supply voltage

- When using backup: 0.9 to 1.8 V (Maximum operating frequency 1 MHz)
  When not using backup: 1.8 to 3.5 V (Maximum operating frequency 2 MHz; when Level detector or Comparator is used) 1.8 to 5.5 V (Maximum operating frequency 2 MHz; when Level detector and Comparator are not used)

#### 1.3 Block Diagram

Block diagram of the ML63512A and ML63514A is shown in Figure 1-1.

Asterisks (\*) indicate the secondary function of each port. Signal names enclosed by chain lines (  $_{--}$  ) indicate interface signals of the V<sub>DDI</sub> power supply system.

Port 6 (P6.0 to P6.3)<sup>†</sup>, Port 9 (P9.0 to P9.3)<sup>†</sup> and Port A (PA.0 to PA.3)<sup>†</sup> are provided for the 64-pin packages and chips.



#### 1.4 Pin Configuration

#### 1.4.1 ML63512A, ML63514A Pin Configurations

The 48-pin package (48TQFP) pin configuration, 64-pin package ((64TQFP) pin configuration, chip pin configuration, and pad coordinates of the ML63512A and ML63514A are shown in Figure 1-2, 1-3, 1-4, and Table 1-1, respectively.

NC (not connected) indicates an unused pin that is left unconnected (open).



Figure 1-2 ML63512A, ML63514A 48-Pin TQFP Pin Configuration (Top View) (Package : TQFP48-P-0707-0.50-K)



Figure 1-3 ML63512A, ML63514A 64-Pin TQFP Pin Configuration (Top View) (Package : TQFP64-P-1010-0.50-K)



Note: The chip substrate voltage is  $V_{SS}$ .

Figure 1-4 ML63512A, ML63514A Chip Pin Configuration (Top View)

|         |          |        |        |         |                  | Chip cent | er: X = 0, Y = 0 |
|---------|----------|--------|--------|---------|------------------|-----------|------------------|
| Pad No. | Pad Name | X (µm) | Υ (μm) | Pad No. | Pad Name         | X (μm)    | Y (µm)           |
| 1       | P9.2     | -1175  | -1717  | 31      | P6.0             | 1604      | 1018             |
| 2       | P9.3     | -1018  | -1717  | 32      | P6.1             | 1604      | 1175             |
| 3       | P0.0     | -862   | -1717  | 33      | P6.2             | 1175      | 1717             |
| 4       | P0.1     | -705   | -1717  | 34      | P6.3             | 1018      | 1717             |
| 5       | P0.2     | -548   | -1717  | 35      | P7.0             | 862       | 1717             |
| 6       | P0.3     | -392   | -1717  | 36      | P7.1             | 705       | 1717             |
| 7       | P1.0     | -235   | -1717  | 37      | P7.2             | 548       | 1717             |
| 8       | P1.1     | -78    | -1717  | 38      | P7.3             | 392       | 1717             |
| 9       | P1.2     | 78     | -1717  | 39      | P8.0             | 235       | 1717             |
| 10      | P1.3     | 235    | -1717  | 40      | P8.1             | 78        | 1717             |
| 11      | P2.0     | 392    | -1717  | 41      | P8.2             | -78       | 1717             |
| 12      | P2.1     | 548    | -1717  | 42      | P8.3             | -235      | 1717             |
| 13      | P2.2     | 705    | -1717  | 43      | V <sub>DDI</sub> | -392      | 1717             |
| 14      | P2.3     | 862    | -1717  | 44      | V <sub>SS</sub>  | -934      | 1717             |
| 15      | PA.0     | 1018   | -1717  | 45      | V <sub>DD</sub>  | -1090     | 1717             |
| 16      | PA.1     | 1175   | -1717  | 46      | V <sub>DDH</sub> | -1247     | 1717             |
| 17      | PA.2     | 1604   | -1175  | 47      | CB1              | -1604     | 1127             |
| 18      | PA.3     | 1604   | -1019  | 48      | CB2              | -1604     | 971              |
| 19      | P3.0     | 1604   | -862   | 49      | V <sub>DDL</sub> | -1604     | 814              |
| 20      | P3.1     | 1604   | -705   | 50      | XT0              | -1604     | 502              |
| 21      | P3.2     | 1604   | -549   | 51      | XT1              | -1604     | 345              |
| 22      | P3.3     | 1604   | -392   | 52      | TST1B            | -1604     | 76               |
| 23      | P4.0     | 1604   | -235   | 53      | TST2B            | -1604     | -81              |
| 24      | P4.1     | 1604   | -79    | 54      | V <sub>SS</sub>  | -1640     | -236             |
| 25      | P4.2     | 1604   | 78     | 55      | OSC0             | -1604     | -392             |
| 26      | P4.3     | 1604   | 235    | 56      | OSC1             | -1604     | -548             |
| 27      | P5.0     | 1604   | 391    | 57      | RESETB           | -1604     | -705             |
| 28      | P5.1     | 1604   | 548    | 58      | MD               | -1604     | -862             |
| 29      | P5.2     | 1604   | 705    | 59      | P9.0             | -1604     | -1018            |
| 30      | P5.3     | 1604   | 861    | 60      | P9.1             | -1604     | -1175            |

Table 1-1 ML63512A, ML63514A Pad Coordinates

1

#### 1.5 Pin Descriptions

#### 1.5.1 Descriptions of the Basic Functions of Each Pin

The basic functions of each pin of the ML63512A and ML63514A are listed in Table 1-2. Use of a backslash ("/") in a pin name indicates that the pin has a secondary function. Refer to section 1.5.2, "Descriptions of the Secondary Functions of Each Pin."

In the I/O column, "—" indicates a power supply pin, "I" indicates an input pin, "O" indicates an output pin, and "I/O" indicates an input/output pin.

For pin, "TB" denotes a 48-pin flat package (48TQFP), and "TP" a 64-pin flat package (64TQFP).

| <b>F</b> unction | Symphol          | Pin    | No.    | Pad    | Туре | Description                                                                                                                                                                                                                                      |  |
|------------------|------------------|--------|--------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function         | Symbol           | тв     | TP     | No.    |      | Description                                                                                                                                                                                                                                      |  |
|                  | V <sub>DD</sub>  | 23     | 29     | 45     | —    | Positive power supply                                                                                                                                                                                                                            |  |
|                  | V <sub>SS</sub>  | 22, 32 | 28, 42 | 44, 54 | —    | Negative power supply                                                                                                                                                                                                                            |  |
|                  | V <sub>DDI</sub> | 21     | 27     | 43     | _    | Positive power supply pin for external interface<br>(PORT8 supply)                                                                                                                                                                               |  |
| Power<br>Supply  | V <sub>DDL</sub> | 27     | 37     | 49     |      | Positive power supply pin for internal logic (internally generated).<br>A capacitor $C_{I}$ (0.1 $\mu$ F) should be connected between this pin and $V_{SS}$ .                                                                                    |  |
|                  | Vddh             | 24     | 30     | 46     |      | Voltage multiplier pin for power supply backup (internally generated). A capacitor $C_h$ (1.0 $\mu$ F) should be connected between this pin and $V_{SS}$ .                                                                                       |  |
|                  | CB1              | 25     | 35     | 47     | —    | Pins to connect a capacitor for voltage multiplier.                                                                                                                                                                                              |  |
|                  | CB2              | 26     | 36     | 48     | —    | A capacitor (1.0 $\mu$ F) should be connected between CB1 and CB2.                                                                                                                                                                               |  |
|                  | XT0              | 28     | 38     | 50     | I    | Low-speed clock oscillation pins.<br>Crystal oscillation or RC oscillation is selected by the mask<br>option.                                                                                                                                    |  |
|                  | XT1              | 29     | 39     | 51     | 0    | If crystal oscillation is selected, connect a crystal between XT0 and XT1, and connect capacitor ( $C_G$ ) between XT0 and $V_{SS}$ .<br>If RC oscillation is selected, connect external oscillation resistor ( $R_{CRL}$ ) between XT0 and XT1. |  |
| Oscillation      | OSC0             | 33     | 43     | 55     | I    | High-speed clock oscillation pins.<br>Ceramic oscillation or RC oscillation is selected by the mask<br>option.<br>If ceramic oscillation is selected, connect a ceramic resonator                                                                |  |
|                  | OSC1             | 34     | 44     | 56     | 0    | between OSCO and OSC1, and connect capacitor ( $C_{L0}$ , $C_{L1}$ )<br>between OSCO and $V_{SS}$ , OSC1 and $V_{SS}$ .<br>If RC oscillation is selected, connect external oscillation<br>resistor ( $R_{CRH}$ ) between OSCO and OSC1.          |  |
| Toot             | TST1B            | 30     | 40     | 52     | I    | Input pins for testing.                                                                                                                                                                                                                          |  |
| Test             | TST2B            | 31     | 41     | 53     |      | A pull-up resistor is internally connected to these pins.                                                                                                                                                                                        |  |

 Table 1-2 Pin Description (Basic Functions)

| Function | Symbol                     | Pin | No. | Pad | <b>T</b> | Description                                                                                                                                                                                                                                                    |  |
|----------|----------------------------|-----|-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function | Symbol                     | тв  | TP  | No. | Туре     | Description                                                                                                                                                                                                                                                    |  |
| Reset    | RESETB                     | 35  | 45  | 57  | I        | Reset input pin.<br>Setting this pin to "L" level puts this device into a reset state<br>Then, setting this pin to "H" level starts executing an<br>instruction from address 0000H.<br>An internal or external pull-up resistor is selected by<br>mask option. |  |
| Melody   | MD                         | 36  | 46  | 58  | 0        | Melody output pin (non-inverted output)                                                                                                                                                                                                                        |  |
|          | P0.0/INT0                  | 37  | 51  | 3   |          | 4-bit input-output ports.                                                                                                                                                                                                                                      |  |
|          | P0.1/INT1                  | 38  | 52  | 4   | 1/0      | In input mode, pull-up resistor input or high-impedance                                                                                                                                                                                                        |  |
|          | P0.2/INT2                  | 39  | 53  | 5   | 1/0      | input is selectable for each bit.                                                                                                                                                                                                                              |  |
|          | P0.3/INT3                  | 40  | 54  | 6   |          | In output mode, N-channel open drain output or CMOS                                                                                                                                                                                                            |  |
|          | P1.0/<br>TM0CAP/<br>TM0OVF | 41  | 55  | 7   |          | output is selectable for each bit.                                                                                                                                                                                                                             |  |
|          | P1.1/<br>TM1CAP/<br>TM1OVF | 42  | 56  | 8   | I/O      |                                                                                                                                                                                                                                                                |  |
|          | P1.2/T0CK                  | 43  | 57  | 9   |          |                                                                                                                                                                                                                                                                |  |
|          | P1.3/T1CK                  | 44  | 58  | 10  |          |                                                                                                                                                                                                                                                                |  |
|          | P2.0/TBCCLK                | 45  | 59  | 11  |          |                                                                                                                                                                                                                                                                |  |
| Dout     | P2.1/HSCLK                 | 46  | 60  | 12  | - 1/0    |                                                                                                                                                                                                                                                                |  |
| Port     | P2.2                       | 47  | 61  | 13  |          |                                                                                                                                                                                                                                                                |  |
|          | P2.3                       | 48  | 62  | 14  | ]        |                                                                                                                                                                                                                                                                |  |
|          | P3.0/RXD                   | 1   | 3   | 19  |          |                                                                                                                                                                                                                                                                |  |
|          | P3.1/TXC                   | 2   | 4   | 20  | 1/0      |                                                                                                                                                                                                                                                                |  |
|          | P3.2/RXC                   | 3   | 5   | 21  | 1/0      |                                                                                                                                                                                                                                                                |  |
|          | P3.3/TXD                   | 4   | 6   | 22  |          |                                                                                                                                                                                                                                                                |  |
|          | P4.0                       | 5   | 7   | 23  |          |                                                                                                                                                                                                                                                                |  |
|          | P4.1                       | 6   | 8   | 24  | I/O      |                                                                                                                                                                                                                                                                |  |
|          | P4.2                       | 7   | 9   | 25  | 1/0      |                                                                                                                                                                                                                                                                |  |
|          | P4.3                       | 8   | 10  | 26  |          |                                                                                                                                                                                                                                                                |  |
|          | P5.0                       | 9   | 11  | 27  |          |                                                                                                                                                                                                                                                                |  |
|          | P5.1                       | 10  | 12  | 28  | I/O      |                                                                                                                                                                                                                                                                |  |
|          | P5.2                       | 11  | 13  | 29  |          |                                                                                                                                                                                                                                                                |  |
|          | P5.3                       | 12  | 14  | 30  |          |                                                                                                                                                                                                                                                                |  |

#### Table 1-2 Pin Description (Basic Functions) (continued)

1

| <b>F</b> unction | Symbol      | Pin No. |    | Pad | Turne | Description                                                                              |  |
|------------------|-------------|---------|----|-----|-------|------------------------------------------------------------------------------------------|--|
| Function         |             | тв      | TP | No. | Туре  | Description                                                                              |  |
|                  | P6.0        | _       | 15 | 31  |       | 4-bit input-output port.<br>In input mode, pull-up resistor input or high-impedance      |  |
|                  | P6.1        | _       | 16 | 32  | - 1/0 | input is selectable for each bit.<br>In output mode, N-channel open drain output or CMOS |  |
|                  | P6.2        | _       | 17 | 33  | 1/0   | output is selectable for each bit.                                                       |  |
|                  | P6.3        | —       | 18 | 34  |       | Note that these pins are available for a 64-pin package and chip.                        |  |
|                  | P7.0/CMPIN  | 13      | 19 | 35  |       | 4-bit input port.                                                                        |  |
|                  | P7.1/CMPREF | 14      | 20 | 36  | ·     | Pull-up resistor input or high-impedance input is selectable for each bit.               |  |
|                  | P7.2/LDIN0  | 15      | 21 | 37  |       |                                                                                          |  |
|                  | P7.3/LDIN1  | 16      | 22 | 38  |       |                                                                                          |  |
| Port             | P8.0        | 17      | 23 | 39  |       | 4-bit output port.                                                                       |  |
|                  | P8.1        | 18      | 24 | 40  | 0     | N-channel open drain output.                                                             |  |
|                  | P8.2        | 19      | 25 | 41  |       |                                                                                          |  |
|                  | P8.3        | 20      | 26 | 42  |       |                                                                                          |  |
|                  | P9.0        | _       | 47 | 59  |       | 4-bit input-output ports.                                                                |  |
|                  | P9.1        | _       | 48 | 60  | 1/0   | In input mode, pull-up resistor input or high-impedance                                  |  |
|                  | P9.2        | —       | 49 | 1   | 1/0   | input is selectable for each bit.                                                        |  |
|                  | P9.3        | —       | 50 | 2   |       | In output mode, N-channel open drain output or CMOS                                      |  |
|                  | PA.0        | _       | 63 | 15  |       | output is selectable for each bit.                                                       |  |
|                  | PA.1        | _       | 64 | 16  | 1/0   | Note that these pins are available for a 64-pin package                                  |  |
|                  | PA.2        | _       | 1  | 17  | 1/0   | and chip.                                                                                |  |
|                  | PA.3        | _       | 2  | 18  | 1     |                                                                                          |  |

#### Table 1-2 Pin Description (Basic Functions) (continued)

#### 1.5.2 Descriptions of the Secondary Functions of Each Pin

The secondary functions of each pin of the ML63512A and ML63514A are listed in Table 1-3.

| Function    | Symbol      | Pin | No. | Pad | Tunc | Description                                                           |  |
|-------------|-------------|-----|-----|-----|------|-----------------------------------------------------------------------|--|
| Function    | Symbol      | тв  | TP  | No. | Туре | Description                                                           |  |
|             |             |     |     |     |      | External 0 interrupt input pin.                                       |  |
|             | P0.0/INT0   | 37  | 51  | 3   | 1    | Edge detection can be selected from one of a rising edge,             |  |
|             |             |     |     |     |      | a falling edge, or both rising and falling edges.                     |  |
|             |             |     |     |     |      | External 1 interrupt input pin.                                       |  |
|             | P0.1/INT1   | 38  | 52  | 4   | I    | Edge detection can be selected from one of a rising edge,             |  |
| External    |             |     |     |     |      | a falling edge, or both rising and falling edges.                     |  |
| Interrupt   |             |     |     |     |      | External 2 interrupt input pin.                                       |  |
|             | P0.2/INT2   | 39  | 53  | 5   | 1    | Edge detection can be selected from one of a rising edge,             |  |
|             |             |     |     |     |      | a falling edge, or both rising and falling edges.                     |  |
|             |             |     |     |     |      | External 3 interrupt input pin.                                       |  |
|             | P0.3/INT3   | 40  | 54  | 6   | 1    | Edge detection can be selected from one of a rising edge,             |  |
|             |             |     |     |     |      | a falling edge, or both rising and falling edges.                     |  |
| Conturo     | P1.0/TM0CAP | 41  | 55  | 7   | I    | Timer 0 (TM0) capture trigger input pin.                              |  |
| Capture     | P1.1/TM1CAP | 42  | 56  | 8   | I    | Timer 1 (TM1) capture trigger input pin.                              |  |
|             | P1.0/TM00VF | 41  | 55  | 7   | 0    | Timer 0 (TM0) overflow flag output pin.                               |  |
| Timer       | P1.1/TM10VF | 42  | 56  | 8   | 0    | Timer 1 (TM1) overflow flag output pin.                               |  |
| Timer       | P1.2/T0CK   | 43  | 57  | 9   | I    | Timer 0 (TM0) external clock input pin.                               |  |
|             | P1.3/T1CK   | 44  | 58  | 10  | I    | Timer 1 (TM1) external clock input pin.                               |  |
| Oscillation | P2.0/TBCCLK | 45  | 59  | 11  | 0    | Low-speed oscillation clock output pin.                               |  |
| Output      | P2.1/HSCLK  | 46  | 60  | 12  | 0    | High-speed oscillation clock output pin.                              |  |
|             | P3.0/RXD    | 1   | 3   | 19  | I    | Serial port receive data input pin.                                   |  |
|             |             |     | 4   |     |      | Sync serial port clock input-output pin.                              |  |
|             |             |     |     | 20  |      | Transmit sync clock input-output pin when a serial port is used       |  |
|             | P3.1/TXC    | 2   |     |     | I/0  | synchronously.                                                        |  |
|             |             |     |     |     |      | Transmit clock output when this device is used as a master processor. |  |
| Serial      |             |     |     |     |      | Transmit clock input when this device is used as a slave processor.   |  |
| Port        |             |     |     |     |      | Sync serial port clock input-output pin.                              |  |
|             |             |     |     |     |      | Receive sync clock input-output pin when a serial port is used        |  |
|             | P3.2/RXC    | 3   | 5   | 21  | I/0  | synchronously.                                                        |  |
|             |             |     |     |     |      | Receive clock output when this device is used as a master processor.  |  |
|             |             |     |     |     |      | Receive clock input when this device is used as a slave processor.    |  |
|             | P3.3/TXD    | 4   | 6   | 22  | 0    | Serial port transmit data output pin.                                 |  |
| Comparator  | P7.0/CMPIN  | 13  | 19  | 35  | I    | Comparator analog input pin.                                          |  |
| Comparator  | P7.1/CMPREF | 14  | 20  | 36  | I    | Comparator reference voltage input pin.                               |  |
| Level       | P7.2/LDIN0  | 15  | 21  | 37  | I    | Level detector analog input pin.                                      |  |
| Detector    | P7.3/LDIN1  | 16  | 22  | 38  | I    | Level detector analog input pin.                                      |  |

#### 1.5.3 Unused Pin Processing

Table 1-4 lists the handling of unused pins.

| Pin          | Recommended pin handling           |
|--------------|------------------------------------|
| TST1B, TST2B | Open or V <sub>DD</sub>            |
| MD           | Open                               |
| OSCO, OSC1   | Open                               |
| CB1, CB2     | Open                               |
| P0.0-P0.3    | Open                               |
| P1.0-P1.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P2.0-P2.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P3.0–P3.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P4.0-P4.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P5.0–P5.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P6.0-P6.3    | Open                               |
| P7.0-P7.3    | V <sub>DD</sub> or V <sub>SS</sub> |
| P8.0–P8.3    | Open                               |
| P9.0–P9.3    | Open                               |
| PA.0-PA.3    | Open                               |

#### Table 1-4 Unused Pin Handling

Notes:

- 1. If a pin set as a high impedance input is left unconnected, the supply current may become excessive. Therefore, it is recommended that unused input ports and input/output ports be set as inputs with either a pull-down or pull-up resistor.
- When test pins TST1 and TST2 are left unconnected, malfunction may result if there is a large amount of external noise. Therefore, it is recommended to permanently connect TST1 and TST2 to V<sub>DD</sub>.

#### 1.6 Basic Timing

#### 1.6.1 Basic Timing of CPU Operation

The low-speed oscillation clock from the XT0/XT1 pins or the high-speed oscillation clock from the OSC0/OSC1 pins are used without frequency division as the system clock (CLK). The system clock signal is in phase with the signal from the XT0 pin or the OSC0 pin.

As shown in Figure 1-5, a single machine cycle is composed of two states, S1 and S2. One state is the interval from a falling edge of CLK to the falling edge of the next CLK.

Instructions are processed in machine cycle units and each instruction is executed in 1 to 3 machine cycles. Instructions are classified according to the number of machine cycles: 1 machine cycle instructions (M1), 2 machine cycle instructions (M1 + M2), and 3 machine cycle instructions (M1 + M2 + M3).

M1 M1 M2 M1 M2 M3 CLK S2 S1 S1 S2 S1 S2 S1 S2 **S1** S2 S1 S2 ł. (2 clocks) (4 clocks) (6 clocks) 1 machine cycle 2 machine cycles 3 machine cycles

Most instructions are executed in 1 machine cycle.

Figure 1-5 Clock Configuration of Each Machine Cycle

#### 1.6.2 Port I/O Basic Timing

Figure 1-6 shows the basic I/O timing.

During the execution of an instruction that outputs data to a port, setting data (data A) is output at the rising edge of the clock in the S2 state during the machine cycle of that instruction.

During the execution of an instruction that inputs data from a port, data at the input pin (data B) is captured internally while the clock is at a "H" level in the S1 state during the machine cycle of that instruction. That data is transferred to the accumulator at the start of the next machine cycle.





Note:

Regarding input signals

"0" will be captured in the internal register if a "L" level is input to the input pin even once ( $\bigcirc$  of Figure 1-7) during the data capture interval.

"1" will be captured in the internal register only if a "H" level is maintained (② of Figure 1-7) throughout the data capture interval.

Therefore, if noise occurs in the input data, implement noise reduction measures with the program and peripheral devices.





#### 1.6.3 Interrupt Basic Timing

Figure 1-8 shows the basic interrupt timing.

As shown in the figure, when an interrupt factor is generated, the interrupt factor is sampled at the falling edge of CLK and an interrupt request (IRQ) is set at the first half of S1.

When an interrupt condition is established and the CPU receives an interrupt, the interrupt routine will start beginning from the next machine cycle.



Figure 1-8 Interrupt Basic Timing

## Chapter 2

# **CPU and Memory Spaces**

### Chapter 2 CPU and Memory Spaces

#### 2.1 Overview

The ML63512A and ML63514A have an internal Oki's original CPU core nX-4/250.

The instruction set of the nX-4/250 core consists of 407 types of instructions.

The memory space consists of a 16-bit wide program memory space and a 4-bit wide data memory space. A stack for saving the program counter during a subroutine call or interrupt (call stack) and a stack for saving registers during a PUSH instruction (register stack) are provided separately from the memory space.

The program memory space is used for program data, ROM table data and melody note data.

In the data memory space, special function registers (SFRs) are located in bank 0, and data RAM in bank 1 (128 nibbles for the ML63512A, 256 nibbles for the ML63514A).

#### 2.2 Registers

The nX-4/250 core processes data mainly with the accumulator and register set.

The register set is a programming model consisting of the HL and XY registers that store data memory addresses, the current bank register (CBR), the extra bank register (EBR), the RA register that stores program memory addresses, registers that control program flow, and registers that control flags and memory.

#### 2.2.1 Accumulator (A)

The accumulator (A) is the central register for various arithmetic operations.

At system reset, the accumulator is initialized to "0". When an interrupt occurs, a "PUSH HL" instruction can be used if necessary to save the accumulator on the register stack. The accumulator can be restored with a "POP HL" instruction.

#### 2.2.2 Flag Register

The flag register consists of 3 flags: the carry flag (C), the zero flag (Z) and the G flag (G). When an interrupt occurs, a "PUSH HL" instruction can be used if necessary to save the flag register on the register stack. The flag register can be restored with a "POP HL" instruction.

| G             | С | Ζ |  |  |  |  |  |
|---------------|---|---|--|--|--|--|--|
| Flag register |   |   |  |  |  |  |  |

#### 2.2.2.1 Carry Flag (C)

The carry flag (C) is a 1-bit flag that is loaded with a carry during addition or a borrow during subtraction. At system reset, the carry flag is initialized to "0".

#### 2.2.2.2 Zero Flag (Z)

The zero flag (Z) is a 1-bit flag that is set to "1" when the contents of the accumulator (A) are loaded with "0H". The zero flag is set to "0" when the contents of the accumulator (A) are loaded with a value other than "0H". However, the XCH instruction does not change the zero flag. At system reset, the zero flag is initialized to "0".

#### 2.2.2.3 G Flag (G)

The G flag (G) changes to "1" when the HL, XY or RA registers overflow as the result of execution of a post-increment register indirect addressing instruction or as the result of an increment instruction for the HL, XY or RA registers. At system reset, the G flag is initialized to "0".

#### 2.2.3 Master Interrupt Enable Flag (MIE)

MIE (bit 0 of MIEF) is a flag that disables or enables all interrupts. MIEF is a 4-bit register in which bit 0 is the master interrupt enable flag (MIE).

If MIE is "0", all interrupts are disabled. If MIE is "1", all interrupts are enabled.

When any interrupt is received, MIE is cleared to "0". MIE is set to "1" by execution of a return from interrupt instruction (RTI instruction).

If multi-level interrupt processing is to be performed, execute a RTI instruction (MIE $\leftarrow$ "1") during the interrupt processing routines.

At system reset, MIE is initialized to "0". MIEF only supports data reference (R) of data memory through addressing instructions.



Note:

When setting MIE, use "EI" instructions (MIE $\leftarrow$ "1") and "DI" instructions (MIE $\leftarrow$ "0").

# 2.2.4 Current Bank Register (CBR), Extra Bank Register (EBR), HL Register (HL), XY Register (XY)

The CBR, EBR, HL, and XY registers are used for indirect addressing of data memory.

The CBR and EBR registers indicate the data memory bank. The HL and XY registers indicate addresses in the bank. CBR is also used in combination with 8-bit data in the instruction code for direct addressing within the current bank.

Figure 2-1 shows the various register combinations.



Figure 2-1 Various Register Combinations

A11 to A0 in Figure 2-1 indicate data memory addresses (4K nibbles max.).

At system reset, the CBR, EBR, HL, and XY registers are initialized to "0".

When an interrupt occurs, a "PUSH HL" or "PUSH XY" instruction can be used if necessary to save the CBR, EBR, HL, and XY registers on the register stack. These registers can be restored with a "POP HL" or "POP XY" instruction.

The CBR, EBR, HL, and XY registers are assigned to special function register (SFR) addresses 0F9H to 0FEH.

|            | bit 3          | bit 2          | bit 1          | bit 0          |
|------------|----------------|----------------|----------------|----------------|
| EBR (OFEH) | e <sub>3</sub> | e2             | е1             | eo             |
| (R/W)      | bit 3          | bit 2          | bit 1          | bit 0          |
| CBR (OFDH) | C3             | C2             | C1             | C <sub>0</sub> |
| (R/W)      | bit 3          | bit 2          | bit 1          | bit 0          |
| H (OFCH)   | h <sub>3</sub> | h <sub>2</sub> | h <sub>1</sub> | h <sub>0</sub> |
| (R/W)      | bit 3          | bit 2          | bit 1          | bit 0          |
| L (OFBH)   | l <sub>3</sub> | l <sub>2</sub> | l <sub>1</sub> | I <sub>0</sub> |
| (R/W)      | bit 3          | bit 2          | bit 1          | bit 0          |
| X (OFAH)   | x <sub>3</sub> | Х <sub>2</sub> | Х <sub>1</sub> | X0             |
| (R/W)      | bit 3          | bit 2          | bit 1          | bit 0          |
| Y (0F9H)   | У3             | У2             | У1             | Уо             |

#### 2.2.5 Program Counter (PC)

The program counter (PC) is a counter with 16 valid bits that specifies the program memory space.

#### 2.2.6 RA Registers (RA3, RA2, RA1, RA0)

The RA registers are used for indirect program memory addressing (ROM table reference instructions).

Figure 2-2 shows the address configuration of the RA registers.

| RA3     | RA2    | RA1   | RA0   |
|---------|--------|-------|-------|
| A15-A12 | A11-A8 | A7-A4 | A3-A0 |

Figure 2-2 Address Configuration of RA3 to RA0 Registers

Within the A15 to A0 of Figure 2-2, A14 to A0 indicate program memory addresses (32K words max.).

RA3 to RA0 are assigned to special function register (SFR) addresses 0F2H to 0F5H.

|            | bit 3           | bit 2           | bit 1           | bit 0           |
|------------|-----------------|-----------------|-----------------|-----------------|
| RA3 (0F5H) | a <sub>15</sub> | a <sub>14</sub> | a <sub>13</sub> | a <sub>12</sub> |
| (R/W)      | bit 3           | bit 2           | bit 1           | bit 0           |
| RA2 (0F4H) | a <sub>11</sub> | a <sub>10</sub> | a <sub>g</sub>  | a <sub>8</sub>  |
| (R/W)      | hit 0           | hit 0           | h:t 1           | hit O           |
|            | bit 3           | bit 2           | bit 1           | bit 0           |
| RA1 (0F3H) | a <sub>7</sub>  | a <sub>6</sub>  | a <sub>5</sub>  | a <sub>4</sub>  |
| (R/W)      |                 |                 |                 |                 |
|            | bit 3           | bit 2           | bit 1           | bit 0           |
| RA0 (0F2H) | a <sub>3</sub>  | a <sub>2</sub>  | a <sub>1</sub>  | a <sub>0</sub>  |
| (R/W)      |                 |                 |                 |                 |

At system reset, RA3 to RA0 are initialized to "0".

Note:

When executing a ROM table reference instruction that uses RA registers, do not use addresses located in the SFR area to transfer ROM table data to RA registers, otherwise indirect addressing of program memory will not operate properly.

#### 2.2.7 Stack Pointer (SP) and Call Stack

The stack pointer (SP) is a pointer that indicates the call stack address where the program counter is saved when a subroutine call or interrupt occurs.

The SP is a 4-bit up/down counter that is incremented during stack saves and is decremented during stack restores.

The call stack has 16 levels from address 0H to address 0FH. Because the hardware requires 1 level of the call stack during program execution, only 15 levels can be used for stack saves. The contents of the call stack cannot be read or written by the program.

Figure 2-3 shows the relation between SP and the call stack.



Figure 2-3 Relation Between SP and Call Stack

SP is assigned to special function register (SFR) address 0F7H.

|           | bit 3 | bit 2 | bit 1 | bit 0 |
|-----------|-------|-------|-------|-------|
| SP (0F7H) | SP3   | SP2   | SP1   | SP0   |
| (R)       |       |       |       |       |

At system reset, SP is initialized to "0" and points to address "0H" of the call stack. SP is a read-only register and writes are invalid.

#### 2.2.8 Register Stack Pointer (RSP) and Register Stack

The register stack pointer (RSP) is a pointer that indicates the register stack address for saving various registers.

RSP is a 4-bit up/down counter that is incremented during stack saves (execution of PUSH instructions) and is decremented during stack restores (execution of POP instructions).

The register stack has 16 levels from address 0H to address 0FH. The contents of the register stack cannot be read or written by the program.

Figure 2-4 shows the relation between RSP and the register stack.



Figure 2-4 Relation Between RSP and Register Stack

The various registers shown in Figure 2-5 are saved onto and restored from the register stack by PUSH and POP instructions.

| "PU       | "PUSH HL" and "POP HL" instruction execution |    |    |    |    |    |   |   |   |        |   |   |          |   |   |   |
|-----------|----------------------------------------------|----|----|----|----|----|---|---|---|--------|---|---|----------|---|---|---|
|           | 15                                           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6      | 5 | 4 | 3        | 2 | 1 | 0 |
| — G C Z A |                                              |    | -  |    | ŀ  | 1  | I |   |   | _<br>I |   |   |          |   |   |   |
|           | Register stack                               |    |    |    |    |    |   |   |   |        |   |   |          |   |   |   |
| "PU       | "PUSH XY" and "POP XY" instruction execution |    |    |    |    |    |   |   |   |        |   |   |          |   |   |   |
|           | 15                                           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6      | 5 | 4 | 3        | 2 | 1 | 0 |
|           | EBR                                          |    |    |    | CB | R  | - |   | ) | (      |   |   | <b>۱</b> | 1 |   |   |
|           | Register stack                               |    |    |    |    |    |   |   |   |        |   |   |          |   |   |   |

```
Figure 2-5 Register Save/Restore by Execution of PUSH/POP Instructions
```

RSP is assigned to special function register (SFR) address 0F6H.

|            | bit 3 | bit 2 | bit 1 | bit 0 |
|------------|-------|-------|-------|-------|
| RSP (0F6H) | rsp3  | rsp2  | rsp1  | rsp0  |
| (R/W)      |       |       |       |       |

At system reset, RSP is initialized to "0" and points to address "0H" of the register stack.

#### 2.3 Memory Spaces

#### 2.3.1 Program Memory Space

The program memory space is the read-only memory that stores program data.

The program memory space has a data length of 16 bits and extends from address 0000H to address 0FFFH in the ML63512A and from address 0000H to address 1FFFH in the ML63514A.

In addition to program data, the program memory can also store ROM table data and the melody data. Figure 2-6 shows the configuration of the program memory space.



Figure 2-6 Program Memory Space Configuration

After system reset, instruction execution begins at address 0000H. The interrupt area from address 0010H to address 002BH contains starting addresses of the interrupt processing routines that are executed when interrupts are generated. (Refer to Chapter 4, "Interrupt.")

ROM table data is transferred to data memory by ROM table reference instructions.

The melody data defines the tone, tone length, and end tone used in the melody circuit of the ML63512A/514A. After an MSA instruction specifies the starting address, the melody data is automatically transferred to the melody circuit when a melody data interrupt occurs. (Refer to Chapter 10, "Melody Driver.")

Because the test data area contains program data for testing, it cannot be used as a program data area.

#### 2.3.2 Data Memory Space

ML63512A

The data memory space contains data RAM and special function registers (SFRs).

The data memory consists of 2 banks. One bank unit is 256 nibbles. Bank 0 is allocated as a SFR area, and bank 1 is data RAM (from address 100H to address 17FH for the ML63512A; from address 100H to address 1FFH for the ML63514A).



Figure 2-7 shows the configuration of the data memory space.

Figure 2-7 Data Memory Space Configuration

ML63514A

## **Chapter 3**

# **CPU Control Functions**

### Chapter 3 CPU Control Functions

#### 3.1 Overview

Operating states, including system reset, are classified as follows.

- Normal operation mode
- System reset mode
- Halt mode

Figure 3-1 shows the CPU operating state transition diagram.



Figure 3-1 Operating State Transition Diagram

The normal operation mode is the state in which the CPU executes instructions sequentially.

The system reset mode begins when a reset input causes the CPU to begin system reset processing where registers and pins are initialized. The CPU remains in this state until instruction execution begins. After system reset processing, instruction execution begins from address 0000H.

The halt mode is the state in which the CPU is halted (instruction execution suspended) but internal peripheral functions continue to operate. During the halt mode, the PC is not incremented. Even upon entering the halt mode, port and peripheral functions will not change. Transfer to the halt mode is accomplished by executing a "HALT" instruction.

#### 3.2 System Reset Mode (RST)

#### 3.2.1 Transfer to and State of System Reset Mode

The following one factor causes a transfer to the system reset mode.

• Setting the RESETB pin to a "L" level

Since the ML63512A/514A have an internal reset sampling (32 kHz) circuit, keep the RESETB pin (pulse width) set to a "L" level for 1.25 seconds or more.

The following operations are performed in the system reset mode.

- (1) CPU is initialized.
- (2) Backup flag changes to "1" and backup circuit changes to ON state.
- (3) Bias reference voltage supply (VR) is energized.

(4) All special function registers (SFRs) are initialized. However, data RAM is not initialized.

After system reset processing, instruction execution begins from address 0000H.

Figures 3-2 and 3-3 show the system reset generator circuit and signals when a system reset is generated.

Whether the internal pull-up resistor is selected or whether the external pull-up resistor is used is specified by the mask option.



Note:

System reset takes priority over all other processing and terminates all processing up to that point in time. Therefore, the content of RAM, which is not initialized, cannot be guaranteed after a system reset.

#### 3.3 Halt Mode

#### 3.3.1 Transfer to and State of Halt Mode

Transfer to the halt mode is performed by the software when a HALT instruction is executed.

When a HALT instruction is executed, the CPU enters the HALT mode at the S2 state of the HALT instruction.

Oscillation and time base counter operation continue while in the halt mode.

If an interrupt request occurs at the same time as execution of a HALT instruction, interrupt processing has priority and the HALT instruction will not be executed. After the HALT instruction performs the equivalent operation of a NOP instruction, the interrupt routine is entered. When an RTI instruction is used to complete the interrupt routine, the main routine is resumed beginning from the instruction immediately following the HALT instruction.

Figure 3-4 shows the timing when a HALT instruction and interrupt request occur simultaneously.





Note:

While an interrupt request is generated, execution of a HALT instruction will not transfer operation to the halt mode.

#### 3.3.2 Halt Mode Release

The following two methods are available to release the halt mode.

- Release by interrupt generation (transfer to normal operation mode)
- Release by RESETB pin (transfer to system reset mode)

#### 3.3.2.1 Release of Halt Mode by Interrupt

If the halt mode is to be released by an interrupt, the enable flag of the interrupt used for release must be set to "1" prior to entering the halt mode. When the halt mode is released by an interrupt, operation transfers to the normal operation mode.

Figure 3-5 shows the timing of transferring to the halt mode by execution of a HALT instruction and of releasing the halt mode by an interrupt.

When the halt mode is released by an interrupt request, the first instruction immediately following the HALT instruction is executed and then the interrupt routine is entered. When an RTI instruction is used to complete the interrupt routine, the main routine is resumed beginning from the second instruction after the HALT instruction.



Figure 3-5 Timing of Transfer to Halt Mode and Release of Halt Mode by Interrupt

Note:

If the halt mode is to be released, set individual interrupt enable flags to "1". If an individual interrupt enable flag is "0", the corresponding interrupt request signal cannot reset the HLT flag, regardless of whether the master interrupt enable flag (MIE) is "0" or "1".

#### 3.3.2.2 Release of Halt Mode by RESETB Pin

If a low-level is input to the RESETB pin (a pulse width of 1.25 seconds or more), the CPU is released from the halt mode and transfers to the system reset mode.

#### 3.3.3 Melody Data Interrupt and Halt Mode Release

The halt mode is not released by a melody data interrupt.

The melody data interrupt is different from a conventional interrupt in that the melody data interrupt is a hardware processing interrupt used for transfer of melody data to the melody circuit. It is not dependent on the program.

When this interrupt is generated, the instruction immediately after the HALT instruction is executed, then the melody data is transferred to the melody circuit, and the HALT instruction is executed again. This sequence is indicated in Figure 3-6.



Figure 3-6 Melody Data Request Interrupt Operation

#### 3.3.4 Note Concerning HALT Instruction

As described above, the instruction immediately after the HALT instruction may be executed any number of times. For this reason, always place an NOP instruction immediately after the HALT instruction.



# **Chapter 4**

4

# Interrupt (INT)

4

### Chapter 4 Interrupt (INT)

#### 4.1 Overview

The ML63512A and ML63514A support 14 interrupt factors: 4 external interrupts and 10 internal interrupts.

Interrupt enable/disable is controlled by the master interrupt enable flag (MIE) and the individual interrupt enable registers (IE0 to IE3).

When interrupt conditions are met, the interrupt routine is executed from the interrupt start address.

Table 4-1 lists the interrupt factors, and Figure 4-1 shows the interrupt control equivalent circuit.

|                                   |                                    | -        |                         |
|-----------------------------------|------------------------------------|----------|-------------------------|
| Priority                          | Interrupt factor                   | Symbol   | Interrupt start address |
| 1                                 | External interrupt 0 (P0.0)        | XIOINT   | 0010H                   |
| 2                                 | External interrupt 1 (P0.1)        | XI1INT   | 0012H                   |
| 3                                 | External interrupt 2 (P0.2)        | XI2INT   | 0014H                   |
| 4                                 | External interrupt 3 (P0.3)        | XI3INT   | 0016H                   |
| 5 Timer 0 interrupt               |                                    | TMOINT   | 0018H                   |
| 6 Timer 1 interrupt               |                                    | TM1INT   | 001AH                   |
| 7 Serial port reception interrupt |                                    | SRINT    | 001CH                   |
| 8                                 | Serial port transmission interrupt | STINT    | 001EH                   |
| 9                                 | TBC10 (1/1024 TBC) interrupt       | TBC10INT | 0020H                   |
| 10                                | TBC11 (1/2048 TBC) interrupt       | TBC11INT | 0022H                   |
| 11                                | TBC13 (1/8192 TBC) interrupt       | TBC13INT | 0024H                   |
| 12                                | TBC14 (1/16384 TBC) interrupt      | TBC14INT | 0026H                   |
| 13                                | Melody end interrupt               | MDINT    | 0028H                   |
| 14 Level detector interrupt       |                                    | LDINT    | 002AH                   |

#### Table 4-1 List of Interrupt Factors

If multiple interrupts are detected simultaneously, the lowest interrupt start address is given priority.

For details on interrupt operation, refer to Chapter 6 (Time Base Counter), Chapter 7 (Timers), Chapter 8 (Ports), Chapter 9 (Serial Port), Chapter 10 (Melody Driver), and Chapter 11 (Level Detector).



Figure 4-1 Interrupt Control Equivalent Circuit

#### 4.2 Interrupt Registers

The following three types of registers are used to control interrupts.

(1) Master interrupt enable flag register (MIEF)

- (2) Interrupt enable registers (IE0 to IE3)
- (3) Interrupt request registers (IRQ0 to IRQ3)

These registers are described below.

(1) Master interrupt enable flag register (MIEF)

MIEF is a 4-bit register in which bit 0 is the master interrupt enable flag (MIE).

MIE (bit 0 of MIEF) is a flag that disables or enables all interrupts.

If MIE is "0", all interrupts are disabled. If MIE is "1", all interrupts are enabled.

When any interrupt is received, MIE is cleared to "0". MIE is set to "1" by execution of a return from interrupt instruction (RTI instruction).

If multi-level interrupt processing is to be performed, execute a RTI instruction (MIE $\leftarrow$ "1") during the interrupt processing routines.

At system reset, MIE is initialized to "0". MIEF only supports data reference (R) of data memory through addressing instructions.



Note:

When setting MIE, use "EI" instructions (MIE $\leftarrow$ "1") and "DI" instructions (MIE $\leftarrow$ "0").

(2) Interrupt enable registers (IE0 to IE3)

IE0, IE1, IE2 and IE3 are registers that consist of 4 bits each.

A logical AND of the corresponding bits of an interrupt enable register (IE0 to IE3) and an interrupt request register (IRQ0 to IRQ3) determines whether or not each interrupt request is issued to the CPU.

If multiple interrupts request the CPU at the same time, as shown in Table 4-1, the interrupts are accepted in order of highest priority and low priority interrupts are placed on hold.

When an interrupt is received, the master interrupt enable flag (MIE) is cleared to "0". The corresponding bits in the interrupt enable registers (IE0 to IE3) do not change.

At system reset, each bit of IE0 through IE3 is initialized to "0".

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | bit 3 | bit 2        | bit 1         | bit 0         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------|---------------|---------------|
| IE0 (050H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | EXI3  | EXI2         | EXI1          | EXI0          |
| (R/W) External interrupt 3 enable flag 0: Disable (initial value) 1: Enable External interrupt 2 enable flag 0: Disable (initial value) 1: Enable External interrupt 1 enable flag 0: Disable (initial value) 1: Enable External interrupt 1 enable flag 0: Disable (initial value) 1: Enable External interrupt 0 enable flag 0: Disable (initial value) 1: Enable External interrupt 0 enable flag 0: Disable (initial value) 1: Enable External interrupt 1 enable flag 0: Disable (initial value) 1: Enable External interrupt 1 enable flag 0: Disable (initial value) 1: Enable |       |              |               |               |
| IE1 (051H)<br>(R/W)<br>Serial port transmission interrupt ena<br>0: Disable (initial value)<br>1: Enable<br>0: Disable (initial value)<br>1: Enable<br>Timer 1 interrupt enable flag<br>0: Disable (initial value)<br>1: Enable<br>Timer 0 interrupt enable flag<br>0: Disable (initial value)                                                                                                                                                                                                                                                                                        | flag  | bit 2<br>ESR | bit 1<br>ETM1 | bit 0<br>ETM0 |

|                                                                                                                                                                                                                                                                                                                                                                           | bit 3  | bit 2  | bit 1  | bit 0  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------|--|--|
| IE2 (052H)                                                                                                                                                                                                                                                                                                                                                                | ETBC14 | ETBC13 | ETBC11 | ETBC10 |  |  |
| (R/W)<br><u>TBC14 (1/16384 TBC) interrupt enabl</u><br>0: Disable (initial value)<br>1: Enable<br><u>TBC13 (1/8192 TBC) interrupt enable</u><br>0: Disable (initial value)<br>1: Enable<br><u>TBC11 (1/2048 TBC) interrupt enable</u><br>0: Disable (initial value)<br>1: Enable<br><u>TBC10 (1/1024 TBC) interrupt enable</u><br>0: Disable (initial value)<br>1: Enable | flag   |        |        |        |  |  |
|                                                                                                                                                                                                                                                                                                                                                                           | bit 3  | bit 2  | bit 1  | bit 0  |  |  |
| IE3 (053H)                                                                                                                                                                                                                                                                                                                                                                | _      | —      | ELD    | EMD    |  |  |
| (R/W) Level detector transmission interrupt enable flag          0: Disable (initial value)         1: Enable         Melody end reception interrupt enable flag         0: Disable (initial value)         1: Enable         1: Enable         1: Enable         1: Enable         1: Enable                                                                             |        |        |        |        |  |  |

4

(3) Interrupt request registers (IRQ0 to IRQ3)

IRQ0, IRQ1, IRQ2 and IRQ3 are registers that consist of 4 bits each.

When an interrupt request is generated, the corresponding bit of the interrupt request register is set to "1" in the first half of the S1 state of the next instruction. So that the CPU can receive interrupt requests, set the master interrupt enable flag (MIE) to "1" and set the appropriate flag of the corresponding interrupt enable register (IE0 to IE3) to "1".

Setting the appropriate bits of an interrupt request register to "1" allows software interrupts to be generated.

When an interrupt request is received, the corresponding bits of IRQ0 to IRQ3 are cleared to "0".

At system reset, each bit of IRQ0 through IRQ3 is initialized to "0".

|                                                                                  | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------------------------------------------------------------|-------|-------|-------|-------|
| IRQ0 (055H)<br>(R/W)                                                             | QXI3  | QXI2  | QXI1  | QXI0  |
| External interrupt 3 request flag<br>O: No request (initial value)<br>1: Request |       |       |       |       |
| External interrupt 2 request flag<br>0: No request (initial value)<br>1: Request |       |       |       |       |
| External interrupt 1 request flag<br>0: No request (initial value)<br>1: Request |       |       |       |       |
| External interrupt 0 request flag<br>0: No request (initial value)<br>1: Request |       |       |       |       |

bit 3: QXI3 (reQuest of eXternal Interrupt 3)

The external interrupt 3 request flag.

The external interrupt 3 is assigned as the secondary function of port 0.3.

bit 2: QXI2 (reQuest of eXternal Interrupt 2)

The external interrupt 2 request flag.

The external interrupt 2 is assigned as the secondary function of port 0.2.

bit 1: QXI1 (reQuest of eXternal Interrupt 1)

The external interrupt 1 request flag.

The external interrupt 1 is assigned as the secondary function of port 0.1.

bit 0: QXI0 (reQuest of eXternal Interrupt 0)

The external interrupt 0 request flag.

The external interrupt 0 is assigned as the secondary function of port 0.0.

|                                             | bit 3        | bit 2 | bit 1 | bit 0 |
|---------------------------------------------|--------------|-------|-------|-------|
| IRQ1 (056H)                                 | QST          | QSR   | QTM1  | QTM0  |
| (R/W)                                       |              |       |       |       |
| Serial port transmission interrupt req      | uest flag    |       |       |       |
| 0: No request (initial value)<br>1: Request |              |       |       |       |
| Serial port reception interrupt reques      | t flag       |       |       |       |
| 0: No request (initial value)               | <u>r nug</u> |       |       |       |
| 1: Request                                  |              |       |       |       |
| Timer 1 interrupt request flag              |              |       |       |       |
| 0: No request (initial value)<br>1: Request |              |       |       |       |
| Timer 0 interrupt request flag —            |              |       |       |       |
| 0: No request (initial value)               |              |       |       |       |
| 1: Request                                  |              |       |       |       |

bit 3: QST (reQuest of Serial port Transmission)

Serial port transmission interrupt request flag.

This interrupt is requested when serial port transmission is complete.

#### bit 2: QSR (reQuest of Serial port Reception)

Serial port reception interrupt request flag.

This interrupt is requested when serial port reception is complete.

#### bit 1: QTM1 (reQuest of TiMer 1)

Timer 1 interrupt request flag.

A timer 1 interrupt request is generated whenever timer 1 overflows.

#### bit 0: QTM0 (reQuest of TiMer 0)

Timer 0 interrupt request flag.

A timer 0 interrupt request is generated whenever timer 0 overflows.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | bit 3  | bit 2  | bit 1  | bit 0  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------|
| IRQ2 (057H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | QTBC14 | QTBC13 | QTBC11 | QTBC10 |
| (R/W)<br><u>TBC14 (1/16384 TBC) interrupt request</u><br>0: No request (initial value)<br>1: Request<br><u>TBC13 (1/8192 TBC) interrupt request</u><br>0: No request (initial value)<br>1: Request<br><u>TBC11 (1/2048 TBC) interrupt request</u><br>0: No request (initial value)<br>1: Request<br><u>TBC10 (1/1024 TBC) interrupt request</u><br>0: No request (initial value)<br>1: Request<br><u>TBC10 (1/1024 TBC) interrupt request</u><br>0: No request (initial value)<br>1: Request | t flag |        |        |        |

bit 3: QTBC14 (reQuest of TBC14)

TBC14 interrupt request flag.

A TBC14 interrupt request is generated at every falling edge of the 1/16384 TBC (2 Hz @ 32.768 kHz) output of the time base counter.

#### bit 2: QTBC13 (reQuest of TBC13)

TBC13 interrupt request flag.

A TBC13 interrupt request is generated at every falling edge of the 1/8192 TBC (4 Hz @ 32.768 kHz) output of the time base counter.

#### bit1: QTBC11 (reQuest of TBC11)

TBC11 interrupt request flag.

A TBC11 interrupt request is generated at every falling edge of the 1/2048 TBC (16 Hz @ 32.768 kHz)output of the time base counter.

#### bit 0: QTBC10 (reQuest of TBC10)

TBC10 interrupt request flag.

A TBC10 interrupt request is generated at every falling edge of the 1/1024 TBC (32 Hz @ 32.768 kHz) output of the time base counter.

|                                             | bit 3 | bit 2 | bit 1 | bit 0 |
|---------------------------------------------|-------|-------|-------|-------|
| IRQ3 (058H)                                 | —     |       | QLD   | QMD   |
| (R/W)                                       |       |       |       |       |
| Level detector interrupt request flag       |       |       |       |       |
| 0: No request (initial value)<br>1: Request |       |       |       |       |
| Melody end interrupt request flag           |       |       |       |       |
| 0: No request (initial value)               |       |       |       |       |
| 1: Request                                  |       |       |       |       |

bit1: QLD (reQuest of Level Detector)

Level Detector interrupt request flag.

A level detector interrupt request is generated when the level detector starts its operation.

bit 0: QMD (reQuest of MeloDy)

Melody end interrupt request flag.

Melody end interrupts are generated when the melody driver outputs the end notes data (END bit = "1").

#### 4.3 Interrupt Sequence

#### 4.3.1 Interrupt Processing

While MIE is "1", operation transfers to interrupt processing when individual interrupt factors are generated.

The following processes are performed when an interrupt is generated.

(1) MIE and the corresponding interrupt request flag are cleared to "0".

(2) The program counter (PC) is saved on the call stack.

(3) The call stack pointer (SP) is incremented by 1. (SP $\leftarrow$ SP+1)

(4) The starting address of the interrupt routine is loaded into the program counter (PC).

Interrupt processing is performed in 0 machine cycles.

Figure 4-2 shows the stack contents after an interrupt is generated.



Figure 4-2 Call Stack Contents after Interrupt Generation

4

#### 4.3.2 Return from an Interrupt Routine

Return from all other interrupt routines is performed with an "RTI" instruction.

Execution of "RTI" instructions requires 1 machine cycle.

When returning from an interrupt routine, the CPU performs the following processes.

(1) The call stack pointer (SP) is decremented by 1. (SP $\leftarrow$ SP–1)

- (2) MIE is set to "1".
- (3) 1 is added to the call stack contents and that value is loaded into the program counter (PC).

#### 4.3.3 Interrupt Hold Instructions

Interrupt requests are not accepted immediately after an interrupt hold instruction is executed; they are accepted after execution of instruction other than interrupt hold instructions.

Following are the interrupt hold instructions:

- ROM table reference instructions
- Stack operation instructions
- Jump instructions
- Conditional branch instructions
- Call/return instructions
- "EI" (set MIE flag) instructions, "DI" (clear MIE flag) instructions and "MSA cadr15" (start melody output) instructions within control instructions

Note:

If interrupt hold instructions are used in succession, consider that an interrupt, when generated, will be put on hold for some time before the corresponding interrupt routine begins.

## Chapter 5

**Clock Generator Circuit (OSC)** 

### Chapter 5 Clock Generator Circuit (OSC)

#### 5.1 Overview

The clock generator circuit (OSC) consists of a low-speed clock generator circuit, a high-speed clock generator circuit and a clock controller unit. The clock generator circuit generates the system clock (CLK), time base clock (TBCCLK) and the high-speed clock (HSCLK).

The following modes can be selected for the low-speed clock generator circuit and the high-speed clock generator circuit.

- Low-speed clock generator circuit: crystal oscillation mode or RC oscillation mode (mask option selection)
- High-speed clock generator circuit: ceramic oscillation mode or RC oscillation mode (mask option selection)

The system clock is the basic operation clock for the CPU. The time base clock is the basic operation clock for the time base counter.

Depending on the contents of the frequency control register (FCON), the system clock frequency is switched to either the output of the low-speed clock oscillation circuit (TBCCLK) or the output of the high-speed clock oscillation circuit (HSCLK).

#### 5.2 Clock Generator Circuit Configuration

Figure 5-1 shows a block diagram of the clock generator circuit.



Figure 5-1 Clock Generator Circuit Configuration

#### 5.3 Low-Speed Clock Generator Circuit

The low-speed clock generator circuit has two modes that are selected by the mask option, the RC oscillation mode and crystal oscillation mode. The oscillation frequency is 30 to 80 kHz.

For the RC oscillation mode, attach an external resistor, R<sub>OSL</sub>, as shown in Figure 5-2(a).

For the crystal oscillation mode, attach an external crystal unit and capacitor,  $C_G$ , as shown in Figure 5-2(b).



(b) External Circuit for Crystal Oscillation Mode

#### Figure 5-2 External Circuits for Low-Speed Clock Oscillation



For convenience, the descriptions of this manual assume that a 32.768 kHz crystal unit is used in the low-speed clock oscillation circuit.

For the method of specifying mask options for the low-speed clock oscillation circuit, see "Appendix E: Mask Option."

Table 5-1 lists typical values of oscillation frequency when the low-speed side RC oscillation mode is selected. Table 5-2 shows an example external component to be attached when the low-speed side crystal oscillation mode is selected.

| Table 5-1 | Typical | Oscillation | Frequencies | for the Low-Speed | d Side RC Oscillation Mo | ode |
|-----------|---------|-------------|-------------|-------------------|--------------------------|-----|
|           | . ypiou | ocomation   | rioquonoioo | Tor the Lon opood |                          | 200 |

| R <sub>CRL</sub> | f <sub>CRL</sub> |
|------------------|------------------|
| 1.5 MΩ           | 32 kHz ±30%      |
| 700 kΩ           | 60 kHz ±30%      |
| 500 kΩ           | 80 kHz ±30%      |

#### Table 5-2 Example External Component for the Low-Speed Side Crystal Oscillation Mode

| C <sub>G</sub> | f <sub>XT</sub> |
|----------------|-----------------|
| 12 pF          | 32.768 kHz      |

#### 5.4 High-Speed Clock Generator Circuit

The high-speed clock generator circuit has two modes that are selected by the mask option, the RC oscillation mode and ceramic oscillation mode. The maximum oscillation frequency is 2 MHz.

If the high-speed clock is not to be used, leave the OSC0 and OSC1 pins open (unconnected).

For the RC oscillation mode, attach an external resistor, R<sub>CRH</sub>, as shown in Figure 5-3(a).

For the ceramic oscillation mode, attach an external ceramic unit and capacitors as shown in Figure 5-3(b).



(a) External Circuit for RC Oscillation Mode



Figure 5-3 External Circuits for High-Speed Clock Oscillation

Table 5-3 lists typical values of oscillation frequency when the high-speed side RC oscillation mode is selected. Table 5-4 lists example external components to be attached when the high-speed side ceramic oscillation mode is selected.

| R <sub>CRH</sub> (kΩ) | V <sub>DD</sub> (V) | Backup flag | f <sub>CRH</sub> |
|-----------------------|---------------------|-------------|------------------|
| 300                   | 1.5                 | ON          | Approx. 350 kHz  |
| 100                   |                     |             | Approx. 840 kHz  |
| 100                   | 3.0                 | OFF         | Approx. 840 kHz  |
| 75                    |                     |             | Approx. 1 MHz    |
| 47                    |                     |             | Approx. 1.4 MHz  |
| 30                    |                     |             | Approx. 1.8 MHz  |

#### Table 5-3 Typical Oscillation Frequencies for the High-Speed Side RC Oscillation Mode

#### Table 5-4 Example External Components for the High-Speed Side Ceramic Oscillation Mode

| C <sub>L0</sub> (pF) | C <sub>L1</sub> (pF) | Ceramic unit       |
|----------------------|----------------------|--------------------|
| 330                  | 330                  | CSB200D (200 kHz)* |
| 220                  | 220                  | CSB300D (300 kHz)* |
| 150                  | 150                  | CSB500E (500 kHz)* |
| 68                   | 68                   | CSB1000J (1 MHz)*  |
| 30                   | 30                   | CSA2.00MG (2 MHz)* |

\* Ceramic unit manufactured by Murata MFG. Co., Ltd.

5

#### 5.5 System Clock Control

The system clock is the basic operation clock of the CPU.

The clock can be selected as follows with the CPUCLK (bit 0 of FCON) setting.

• CPUCLK = "0" (initial value)

The output of the low-speed clock generator circuit (TBCCLK) is the system clock.

• CPUCLK = "1"

The output of the high-speed clock generator circuit (HSCLK) is the system clock.

When HSCLK is selected as the system clock, the high-speed clock must be in the oscillating state (ENOSC = "1"). The crystal generator circuit will continue to oscillate even when the high-speed generator circuit is selected.

To reduce the total power consumption in applications that use the high-speed clock generator circuit, the following clock controls are generally implemented in software.

- During normal operation, the output of the low-speed clock generator circuit (CPUCLK = "0") should be the system clock.
- Only when high-speed operation is necessary should the high-speed clock oscillate (ENOSC = "1") and output of the high-speed clock generator circuit (CPUCLK = "1") should be selected.

For details of the system clock select timing, refer to section 5.7, "System Clock Select Timing."

#### 5.6 Frequency Control Register (FCON)

FCON is a special function register (SFR) that selects the system clock.



#### bit 1: ENOSC

This bit starts and stops oscillation of the high-speed clock generator circuit. At system reset, this bit is cleared to "0", stopping oscillation of the high-speed clock generator circuit.

#### bit 0: CPUCLK

This bit selects the system clock, the basic operation clock of the CPU. At system reset, this bit is cleared to "0", selecting output of the low-speed clock generator circuit (TBCCLK).

#### 5.7 System Clock Select Timing

After system reset, the system clock is TBCCLK.

When high-speed operation is necessary, switch the system clock to HSCLK.

A flowchart of system clock operation is shown below.



When ENOSC (bit 1 of FCON) is set to "1", oscillation starts in the mode selected by OSCSEL. At the same time, the internal logic power supply ( $V_{DDL}$ ) switches from the constant voltage circuit output level (approx. 1.5 V) to the  $V_{DDH}$  level. Next, if CPUCLK is set to "1", the system clock switches from crystal oscillation output (TBCCLK) to high-speed clock output (HSCLK).

Figure 5-4 shows the system clock select timing and status of the internal logic power supply ( $V_{DDL}$ ).



Figure 5-4 System Clock Select Timing

In the ceramic oscillation mode, 10 ms are required from the time when ENOSC is set to "1" until the high-speed clock generator circuit enters the oscillating state. Therefore, in this mode, when switching CPUCLK to a high-speed setting, wait for an interval of at least  $T_{WAIT}$  = 10 ms after the rising edge of ENOSC.

In the CR oscillation mode, oscillation begins soon after setting ENOSC to "1". When switching CPUCLK to a high-speed setting, wait for an interval of at least  $T_{WAIT} = 300 \,\mu s$  after the rising edge of ENOSC.

When switching from the high-speed mode to the low-speed mode, set the CPUCLK bit to "0", and sometime after the next instruction, set the ENOSC bit to "0".

For details regarding the constant voltage circuit for the internal logic power supply, refer to Chapter 13, "Backup Circuit."

## **Chapter 6**

# Time Base Counter (TBC)

### Chapter 6 Time Base Counter (TBC)

#### 6.1 Overview

The time base counter (TBC) is a 15-bit internal counter, which generates the clock supplied to internal peripheral functions.

The TBC clock is a time base clock (TBCCLK).

TBC outputs are used for functions such as time base interrupts and various other circuits. TBC4–7, TBC8–11 and TBC12–15 can be read/reset by software.

The TBC generates an interrupt request at the falling edge of 32 Hz/16 Hz/4 Hz/2 Hz output.

The TBC is initialized to 0000H at system reset.

#### 6.2 Time Base Counter Configuration

The configuration of the time base counter (TBC) is shown in Figure 6-1.





#### 6.3 Time Base Counter Registers

Time base counter register 0 (TBCR0), time base counter register 1 (TBCR1), time base counter register 2 (TBCR2)

These 4-bit special function registers (SFRs) are used to read the TBC4 to TBC7, TBC8 to TBC11 and TBC12 to TBC15 outputs of the time base counter.

A write operation to TBCR0 initializes the time base counter to "0000H".

A write operation to TBCR1 sets the TBC8 to TBC15 outputs to "0", and a write operation to TBCR2 sets the TBC12 to TBC15 output to "0".

|                       | bit 3 | bit 2 | bit 1 | bit 0 |  |
|-----------------------|-------|-------|-------|-------|--|
| TBCR0 (060H)<br>(R/W) | TBC7  | TBC6  | TBC5  | TBC4  |  |
| (1000)                | bit 3 | bit 2 | bit 1 | bit 0 |  |
| TBCR1 (061H)<br>(R/W) | TBC11 | TBC10 | TBC9  | TBC8  |  |
|                       | bit 3 | bit 2 | bit 1 | bit 0 |  |
| TBCR2 (062H)<br>(R/W) | TBC15 | TBC14 | TBC13 | TBC12 |  |
| (1777)                |       |       |       |       |  |

#### 6.4 Time Base Counter Operation

After system reset the time base counter (TBC) begins to count up from 0000H. The count is incremented at the falling edge of the TBCCLK.

TBC TBC10/TBC11/TBC13/TBC14 outputs are used as time base interrupts. At each output falling edge, four bits of interrupt request register 2 (IRQ2) are set to "1", namely bit 3 (QTBC10), bit 2 (QTBC11), bit 1 (QTBC13) and bit 0 (QTBC14), requesting an interrupt to the CPU. TBC outputs are also used as clocks for various circuits.

TBC TBC4 to TBC7 output, TBC8 to TBC11 output and TBC12 to TBC15 output can be read through the time base counter register 0/1/2 (TBCR0/TBCR1/TBCR2).

A write operation to TBCR0 initializes the time base counter to "0000H". A write operation to TBCR2 sets the TBC12 to TBC15 output counter to "0", and a write operation to TBCR1 sets both the TBC8 to TBC11 and TBC12 to TBC15 output counters to "0". The write data in these write operations has no significance. For example, the "MOV TBCR0, A" instruction can be used to write, but is not dependent on accumulator content in any way. When a write operation is executed to TBCR0, TBCR1, and TBCR2 so as to reset the TBC1 to TBC7 output counter, TBC8 to TBC11 output counter, and TBC12 to TBC15 output counter respectively, if the TBC10, TBC11, TBC13, and TBC14 outputs are "1", their respective interrupt requests will be generated. To disable these interrupts, first set the master interrupt enable flag (MIE) or interrupt enable register 2 (IE2) to "0", execute the write operation to TBCR 0/1/2, and set the interrupt request flag 2 (IRQ2) to "0".

Figure 6-2 shows interrupt generation timing and time base counter output reset timing by writing "1" to TBCR1 and TBCR2.



Figure 6-2 Interrupt Timing and Reset Timing by Writing "1" to TBCR1, TBCR2

(when a 32.768 kHz crystal is used for low-speed clock oscillation)

## Chapter 7

# Timers (TIMER)

7

### Chapter 7 Timers (TIMER)

#### 7.1 Overview

The ML63512A and ML63514A have two internal 8-bit timers (0 and 1). Timers 0 and 1 can be used in tandem as a 16-bit timer.

Timers 0 and 1 have three operation modes: auto-reload mode, capture mode and frequency measurement mode. Timer clock may be set to the time base clock (TBCCLK), the high-speed clock (HSCLK), high-speed dividing clock (1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK, 1/32 HSCLK), or an external clock (P1.2/T0CK, P1.3/T1CK). When using the timers as a 16-bit timer, the overflow signals of timer 0 is used as the clocks for timer 1.

In addition to pulse generation and time measurement, timers can also be used.

|                            | Timer 0                                              | Timer 1                     |  |  |
|----------------------------|------------------------------------------------------|-----------------------------|--|--|
| 8-bit timer                | •                                                    | •                           |  |  |
| 16-bit timer               |                                                      | •                           |  |  |
|                            | (Timer 0 over                                        | flow signal is              |  |  |
|                            | used as clock for timer 1)                           |                             |  |  |
| Clock                      | TBCCLK / HSCLK / 1/2 HSCLK / 1/4 HSCLK / 1/8 HSCLK / |                             |  |  |
|                            | 1/16 HSCLK / 1/32 HSCLK /                            | External clock (T0CK, T1CK) |  |  |
| Auto-reload mode           | •                                                    | •                           |  |  |
| Capture mode               | •                                                    | •                           |  |  |
| Frequency measurement mode | •                                                    | •                           |  |  |

#### 7.2 Timer Configuration

Figures 7-1 and 7-2 show the configuration of timers 0 and 1 respectively.







Figure 7-2 Timer 1 Configuration

#### 7.3 Timer Registers

The following four registers are used for timer control.

- (1) Timer data registers (TM0DL, TM0DH, TM1DL, TM1DH)
- (2) Timer counter registers (TM0CL, TM0CH, TM1CL, TM1CH)(3) Timer control registers
- (TM0CON0, TM0CON1, TM1CON0, TM1CON1)
- (4) Timer status registers (TM0STAT, TM1STAT)

Each register is described below.

(1) Timer data registers

(TM0DL, TM0DH, TM1DL, TM1DH)

- During the auto-reload mode, timer data registers store the reload values.
- During the capture mode, timer data registers store the capture data. Writing to a timer data register causes the contents of the timer counter register to be transferred to the timer data register.
- At system reset, all valid bits are cleared to "0".
- Note regarding register values: Writing to the timer counter register causes the same value to also be written to the timer data register. However, when writing to the timer data register, the same value is not written to the timer counter register.

Timer 0 Registers

| TM0DL           | (068H) | bit 3 | bit 2 | bit 1 | bit 0 | ] |
|-----------------|--------|-------|-------|-------|-------|---|
| (Timer 0 lower) | (R/W)  | TOD3  | T0D2  | T0D1  | T0D0  |   |
| TM0DH           | (069H) | bit 3 | bit 2 | bit 1 | bit 0 | ] |
| (Timer 0 upper) | (R/W)  | T0D7  | T0D6  | T0D5  | T0D4  |   |

**Timer 1 Registers** 

|                          | _               | bit 3 | bit 2 | bit 1 | bit 0 |
|--------------------------|-----------------|-------|-------|-------|-------|
| TM1DL<br>(Timer 1 lower) | (06AH)<br>(R/W) | T1D3  | T1D2  | T1D1  | T1D0  |
|                          | (17,44) -       |       |       |       |       |
|                          |                 | bit 3 | bit 2 | bit 1 | bit 0 |
| TM1DH                    | (06BH)          | T1D7  | T1D6  | T1D5  | T1D4  |
| (Timer 1 upper)          | (R/W) └         |       |       |       |       |

#### (2) Timer counter registers

#### (TM0CL, TM0CH, TM1CL, TM1CH)

- 8-bit binary counter operation
- At system reset, all valid bits are cleared to "0".
- Note regarding register values:

Writing to the timer counter register causes the same value to also be written to the timer data register. However, when writing to the timer data register, the same value is not written to the timer counter register.

#### Timer 0 Registers

| TM0CL           | (06CH) | bit 3 | bit 2 | bit 1 | bit 0 |
|-----------------|--------|-------|-------|-------|-------|
| (Timer 0 lower) | (R/W)  | T0C3  | T0C2  | T0C1  | TOCO  |
| TM0CH           | (06DH) | bit 3 | bit 2 | bit 1 | bit 0 |
| (Timer 0 upper) | (R/W)  | T0C7  | T0C6  | T0C5  | T0C4  |

Timer 1 Registers

| TM1CL           | (06EH) | bit 3 | bit 2 | bit 1 | bit 0 |
|-----------------|--------|-------|-------|-------|-------|
| (Timer 1 lower) | (R/W)  | T1C3  | T1C2  | T1C1  | T1C0  |
| TM1CH           | (06FH) | bit 3 | bit 2 | bit 1 | bit 0 |
| (Timer 1 upper) | (R/W)  | T1C7  | T1C6  | T1C5  | T1C4  |

#### (3) Timer control registers

(TM0CON0, TM0CON1, TM1CON0, TM1CON1)

- Timer control registers select the operation mode and clock for each timer.
- At system reset, all valid bits are cleared to "0".
- Note regarding register values: Writing to the timer counter register causes the same value to also be written to the timer data register. However, when writing to the timer data register, the same value is not written to the timer counter register.

#### Timer 0 Registers

To use timer 1 in combination as a 16-bit timer, set timer 1 control registers TM1CON0 and TM1CON1.

|       |       |       |      |       | bit 3              | bit 2          | bit 1   | bit 0  |
|-------|-------|-------|------|-------|--------------------|----------------|---------|--------|
|       | TM    | DCON  | •    | ,     | _                  | FMEAS0         | TM0ECAP | TMORUN |
|       |       |       | (K   | /W)   |                    |                |         |        |
| Timer | 0 mc  | de se | lect |       |                    |                |         |        |
| bit 2 | bit 1 | bit 0 |      |       |                    |                |         |        |
| 0     | 0     | 0     | :    | Auto- | reload mode stop ( | initial value) |         |        |
| 0     | 0     | 1     | :    |       | reload mode operat | ,              |         |        |
| 0     | 1     | 0     | :    | Captu | re mode stop       |                |         |        |
| 0     | 1     | 1     | :    | Captu | re mode operation  |                |         |        |
| 1     | 0     | 0     | :    | Frequ | ency measurement   | mode operation |         |        |
| 1     | 0     | 1     | :    | Not u | sed                |                |         |        |
| 1     | 1     | 0     | :    | Not u | sed                |                |         |        |
| 1     | 1     | 1     | :    | Not u | sed                |                |         |        |
|       |       |       |      |       |                    |                |         |        |

bit 2, 1, 0: FMEAS0, TM0ECAP, TM0RUN

These bits select the timer 0 operation mode.

The timer 0 operation mode can be selected as auto-reload mode, capture mode, or frequency measurement mode.

| _ |              |         |        |      |        |                    |                   |        |        |
|---|--------------|---------|--------|------|--------|--------------------|-------------------|--------|--------|
|   |              |         |        |      |        | bit 3              | bit 2             | bit 1  | bit 0  |
|   |              | ΤM      | OCON   | •    | ,      | _                  | TM0CL2            | TM0CL1 | TMOCLO |
|   |              |         |        | ()   | R/W)   |                    |                   |        |        |
|   | Time         | r O clo | ock se | lect |        |                    |                   |        |        |
|   | bit 2        | bit 1   | bit 0  |      |        |                    |                   |        |        |
|   | 0 0 0 : TBCC |         |        |      |        | LK (initial value) |                   |        |        |
|   | 0            | 0       | 1      | :    | HSCL   | K (high-speed cloc | k)                |        |        |
|   | 0            | 1       | 0      | :    | 1/2 H  | SCLK (high-speed   | dividing clock)   |        |        |
|   | 0            | 1       | 1      | :    | 1/4 H  | SCLK (high-speed   | dividing clock)   |        |        |
|   | 1            | 0       | 0      | :    | 1/8 H  | SCLK (high-speed   | dividing clock)   |        |        |
|   |              |         |        |      |        | HSCLK (high-speed  | d dividing clock) |        |        |
|   | 1            | 1       | 0      | :    | 1/32 ł | ISCLK (high-speed  | d dividing clock) |        |        |
|   | 1            | 1       | 1      | :    |        | nal clock          | - /               |        |        |
| 1 |              |         |        |      |        |                    |                   |        |        |

bit 2, 1, 0: TM0CL2, TM0CL1, TM0CL0

These bits select the timer 0 clock.

The timer 0 clock can be selected as TBCCLK (low-speed clock), HSCLK (high-speed clock), 1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK, 1/32 HSCLK (high-speed dividing clock), or external clock (T0CK: secondary function of P1.2).

Note:

If HSCLK, 1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK, or 1/32 HSCLK is used as the clock, after ENOSC (bit 1 of FCON) is set to "1", wait for the following time interval before starting timer operation.

- Wait at least 10 ms when using ceramic oscillation.
- Wait at least 300 µs when using RC oscillation.

7

Timer 1 Registers



#### bit 1, 0: TM1ECAP, TM1RUN

These bits select the timer 1 operation mode.

The timer 1 operation mode can be selected as auto-reload mode, capture mode, or 16-bit timer mode.

|               |                    |       |      |       | bit 3                | bit 2           | bit 1  | bit 0  |
|---------------|--------------------|-------|------|-------|----------------------|-----------------|--------|--------|
|               | ТМ                 | 1CON  | ``   | ,     |                      | TM1CL2          | TM1CL1 | TM1CL0 |
|               |                    |       | (F   | R/W)  |                      |                 |        |        |
| <u>Time</u> ı | <sup>-</sup> 1 clo | ck se | lect |       |                      |                 |        |        |
| bit 2         | bit 1              | bit 0 |      |       |                      |                 |        |        |
| 0 0 0 : TBCC  |                    |       |      | TBCC  | LK (initial value)   |                 |        |        |
| 0             | 0                  | 1     | :    | HSCL  | K (high-speed cloc   | k)              |        |        |
| 0             | 1                  | 0     | :    | 1/2 H | SCLK (high-speed     | dividing clock) |        |        |
| 0             | 1                  | 1     | :    | 1/4 H | SCLK (high-speed     | dividing clock) |        |        |
| 1             | 0                  | 0     | :    | 1/8 H | SCLK (high-speed     | dividing clock) |        |        |
| 1             | 0                  | 1     | :    | 1/16  | HSCLK (high-speed    | dividing clock) |        |        |
| 1             | 1                  | 0     | :    | Exter | nal clock            |                 |        |        |
| 1             | 1                  | 1     | :    | Time  | r 0 overflow (16-bit | timer mode)     |        |        |

bit 2, 1, 0: TM1CL2, TM1CL1, TM1CL0

These bits select the timer 1 clock.

The timer 1 clock can be selected as TBCCLK (low-speed clock), HSCLK (high-speed clock), 1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK (high-speed dividing clock), external clock (T1CK: secondary function of P1.2), or the timer 0 overflow flag.

When using as a 16-bit timer, select timer 0 overflow for the clock.



If HSCLK, 1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, or 1/16 HSCLK is used as the clock, after ENOSC (bit 1 of FCON) is set to "1", wait for the following time interval before starting timer operation.

- Wait at least 10 ms when using ceramic oscillation.
- Wait at least 300  $\mu s$  when using RC oscillation.

(4) Timer status registers (TM0STAT, TM1STAT)

- Timer status registers read the status of each timer.
- At system reset, all valid bits are cleared to "0".

#### Timer 0 Registers



#### bit 1: TM0CAP (TiMer0 CAPture)

This bit indicates whether or not new capture data is present. When TMOCAP = "0":

A value of "0" indicates that there has been no new capture data since system reset or since the last time TM0CAP was read.

When TM0CAP = "1":

A value of "1" indicates that there is new capture data since system reset or since the last time TM0CAP was read. Additional captures are disabled. At system reset, TM0CAP is cleared to "0".

In the capture mode, if the level of the capture input pin (P1.0/TM0CAP) changes and a capture is generated, TM0CAP is automatically set to "1". If TM0STAT is read, TM0CAP is automatically cleared to "0".

bit 0: TM0OVF (TiMer0 OVerFlow)

This bit indicates that the timer counter register has overflowed. This bit toggles between "0" and "1" whenever overflow occurs. At system reset, TM0OVF is cleared to "0".

#### Timer 1 Registers

|                                                                                            | bit 3             | bit 2                | bit 1                | bit 0     |
|--------------------------------------------------------------------------------------------|-------------------|----------------------|----------------------|-----------|
| TM1STAT (075H)                                                                             | —                 | —                    | TM1CAP               | TM10VF    |
| (R)<br><u>Timer 1 capture flag</u><br>0: No new capture data (initi<br>1: New capture data | al value)         |                      |                      |           |
| Timer 1 overflow flag<br>0: Initial value<br>1: Toggles                                    | between 0 and 1 e | ach time the timer 1 | l counter register o | verflows. |

#### bit 1: TM1CAP (TiMer1 CAPture)

This bit indicates whether or not new capture data is present. When TM1CAP = "0":

A value of "0" indicates that there has been no new capture data since system reset or since the last time TM1CAP was read.

When TM1CAP = "1":

A value of "1" indicates that there is new capture data since system reset or since the last time TM0CAP was read. Additional captures are disabled. At system reset, TM1CAP is cleared to "0".

In the capture mode, if the level of the capture input pin (P1.1/TM1CAP) changes and a capture is generated, TM1CAP is automatically set to "1". If TM1STAT is read, TM1CAP is automatically cleared to "0".

#### bit 0: TM1OVF (TiMer1 OVerFlow)

This bit indicates that the timer counter register has overflowed. This bit toggles between "0" and "1" whenever overflow occurs. At system reset, TM1OVF is cleared to "0".

[Supplement] List of Timer Registers

| Name                       | Symbol  | Address | R/W | Initial value |
|----------------------------|---------|---------|-----|---------------|
| Timer 0 data register L    | TMODL   | 068H    | B/W | OH            |
| Timer 0 data register H    | TM0DH   | 069H    |     | OH            |
| Timer 0 counter register L | TMOCL   | 06CH    | R/W | OH            |
| Timer 0 counter register H | TMOCH   | 06DH    |     | OH            |
| Timer 0 control register 0 | TM0CON0 | 070H    |     | 8H            |
| Timer 0 control register 1 | TM0CON1 | 071H    | R/W | 8H            |
| Timer 0 status register    | TMOSTAT | 074H    | R   | 0CH           |

#### Timer 0 Registers

#### Timer 1 Registers

| Name                       | Symbol  | Address | R/W | Initial value |
|----------------------------|---------|---------|-----|---------------|
| Timer 1 data register L    | TM1DL   | 06AH    | B/W | 0H            |
| Timer 1 data register H    | TM1DH   | 06BH    | n/W | OH            |
| Timer 1 counter register L | TM1CL   | 06EH    | DAM | OH            |
| Timer 1 counter register H | TM1CH   | 06FH    | R/W | 0H            |
| Timer 1 control register 0 | TM1CON0 | 072H    | B/W | 0CH           |
| Timer 1 control register 1 | TM1CON1 | 073H    | n/W | 8H            |
| Timer 1 status register    | TM1STAT | 075H    | R   | 0CH           |

#### 7.4 Timer Operation

#### 7.4.1 Timer Clock

The timer clock can be selected as TBCCLK (low-speed clock: 32.768 kHz), HSCLK (high-speed clock), 1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK, 1/32 HSCLK (high-speed dividing clock), or an external clock. By using timer 0 overflow signals as clocks for timer 1, the timers can be used in pairs as 16-bit timers.

If the high-speed clock (HSCLK) or high-speed dividing clock (1/2 HSCLK, 1/4 HSCLK, 1/8 HSCLK, 1/16 HSCLK, 1/32 HSCLK) is to be used, after setting bit 1 (ENOSC) of the frequency control register (FCON), wait at least 10 ms in the ceramic oscillation mode or 300  $\mu$ s in the RC oscillation mode before operating the timer.

The external clock is input to a port assigned as a secondary function port. In the case of timer 0, P1.2/T0CK is used as the input pin for the external clock. In the case of timer 1, P1.3/T1CK is used as the input pin for the external clock. Since the external clock is sampled by the system clock (CLK), the high- and low-levels of the external clock should be longer than 1 cycle of the system clock (CLK).

#### 7.4.2 Timer Data Registers

TM0DL, TM0DH, TM1DL, TM1DH are 4-bit registers.

In the auto-reload mode, the timer data registers save values that are reloaded into the timer counter registers when the timer counter registers overflow.

In the capture mode, the timer data registers save the value of the timer counter registers when a capture signal is input. Each timer data register can be read/written by software. Writing to timer data registers does not change the contents of the timer counter registers.

#### 7.4.3 Timer Counter Registers

TM0CL and TM0CH, TM1CL and TM1CH are 8-bit binary counters that are incremented at the falling edge of the timer clock.

Each timer counter register can be read/written by software. However, if the CPU clock and timer clock are different, values that are read or written during the count operation cannot be guaranteed. If an external clock is used as the timer clock, reading/writing is always possible.

When a value is written to any timer counter register, the same value is also written to the corresponding timer data register.

#### 7.4.4 Timer Interrupt Requests and Overflow Flags

Timers generate timer interrupt requests when the timer counter register overflows. The overflow flag toggles between "1" and "0" at each overflow. The output of the overflow flag of timers 0 and 1 can be output to secondary port functions P1.0/TM0OVF and P1.1/TM1OVF pins.

Figure 7-5 indicates the operation timing for timer counter register overflow. Table 7-1 lists timer interrupts.



Figure 7-5 Timer Counter Register Overflow Timing (for Timer 0)

| Interrupt factor  | Symbol | IRQ flag<br>(IRQ1) | IE flag<br>(IE1) | Interrupt vector address |
|-------------------|--------|--------------------|------------------|--------------------------|
| Timer 0 interrupt | TMOINT | QTM0               | ETM0             | 0018H                    |
| Timer 1 interrupt | TM1INT | QTM1               | ETM1             | 001AH                    |

#### Table 7-1 List of Timer Interrupts

When the master interrupt enable flag (MIE) is set to "1" with the interrupt enable flags (ETM0, ETM1) set to "1", and a timer overflow occurs, a CPU interrupt request is generated.

#### 7.4.5 Auto-Reload Mode Operation

Timers 0 and 1 can be used as auto-reload mode timers. The setup method is as follows.

- Timer 0: Set FMEAS0 (bit 2 of TM0CON0) to "0", and set TM0ECAP (bit 1 of TM0CON0) to "0".
- Timer 1: Set TM1ECAP (bit 1 of TM1CON0) to "0".

In the auto-reload mode, each time the timer counter register overflows, the timer data register value is reloaded into the timer counter register, and counting begins from the value. Setting the RUN bits (TMORUN, TM1RUN) for each timer control register to "1" will restart the count, and resetting to "0" stops the count.

In the 16-bit timer mode for timers 0 and 1 the TM1RUN bit is disabled, and start/stop is controlled with the TM0RUN bit.

Figure 7-6 shows auto-reload mode timing for pulse generation when timers 0 and 1 are used as a 16-bit timer.



Figure 7-6 Auto-Reload Mode Timing

The operation procedures are as follows.

- ① Set P1.1 to the output mode (TM1OVF) secondary function.
- 2 Write 534FH to the timer data and timer counter registers.

| TM1DH = TM1CH = 5H | (bits 15–12) |
|--------------------|--------------|
| TM1DL = TM1CL = 3H | (bits 11–8)  |
| TM0DH = TM0CH = 4H | (bits 7–4)   |
| TMODL = TMOCL = FH | (bits 3–0)   |

- ③ If TM0CON and TM1CON are set to auto-reload mode and TM0RUN is set to "1", the timer counter register will start to count from 534FH.
- ④ Before the timer counter register overflows, write the next reload value BFFFH to the timer data register.
- (5) When the timer counter register overflows, BFFFH is set to the timer counter register, timer interrupt (TM1INT) is generated and timer 1 overflow flag (TM1OVF) toggles. The timer counter register continues to count up from BFFFH.
- 6 Before the timer counter register overflows, write the next reload value 534FH to the timer data register.
- ⑦ When the timer counter register overflows, 534FH is set to the timer counter register, timer interrupt (TM1INT) is generated and timer 1 overflow flag (TM1OVF) toggles. The timer counter register resumes counting from address 534FH.
- ⑧ Repeat steps 4 through 7. This allows a user-defined pulse to be output from P1.1/TM1OVF.
- (9) Halt the count by resetting TM0RUN to "0".

Figure 7-7 shows TM0RUN count start/halt timing.



Figure 7-7 TM0RUN Count Start/Halt Timing

When TMORUN is set to "1", the timer counter starts to count from the second falling edge of the selected clock. When TMORUN is reset to "0", the counter stops counting at the falling edge of the selected clock which appears immediately after the TMORUN falling edge.

#### 7.4.6 Capture Mode Operation

Timer 0 and timer 1 can be used as capture mode timers.

In a capture operation, a change in the capture input (P1.0/TM0CAP, P1.1/TM1CAP) level during operation of the timer counter register triggers loading of the value of the timer counter register into the timer data register.

Methods to set the capture mode for each timer are listed below.

- Timer 0: Set TM0ECAP (bit 1 of TM0CON0) to "1", and set FMEAS0 (bit 2 of TM0CON0) to "0".
- Timer 1: Set TM1ECAP (bit 1 of TM1CON0) to "1".

In the capture mode, reloading the timer data register data into the timer counter register is inhibited, and when the timer counter register overflows, counting is restarted from 00H.

When a capture occurs, the capture flags (TM0CAP, TM1CAP) of the timer status registers (TM0STAT, TM1STAT) are set to "1". Additional captures are disabled while the capture flags are "1". The capture flags are assigned to bit 0 of the timer status registers, and are automatically cleared to "0" when the timer status registers are read.

If both the TM1CL1 and TM1CL0 bits of the timer 1 control register 1 (TM1CON1) are set to "1" and timer 0 overflow is selected as the clock, the 16-bit capture mode will be set. In this case, the P1.0/TM0CAP pin is the capture trigger input.



Figure 7-8 shows the timer 0 capture mode timing for pulse width measurement.



The operation procedure is listed below.

- ① Set P1.0/TM0CAP to input mode, and enable XI0INT and TM0INT.
- ② Clear all bits of the timer counter registers and timer data registers to "0".
- ③ Set TM0CON0 to the capture mode, and set TM0RUN to "1" to begin upward counting.
- ④ If the P1.0/TM0CAP input changes, the TM0CH/TM0CL value is captured by TM0DH/TM0DL and TM0CAP is set to "1" (first capture). The CPU detects this through XI0INT and reads the values of TM0DH/TM0DL.
- (5) After the TM0DH/TM0DL read is complete, TM0CAP is cleared to "0" to wait for the next capture.
- 6 If the P1.0/TM0CAP input changes, repeat operations ④ and ⑤ (second capture).

The high-level pulse width t1 of the P1.0 input can be determined as follows.

t1 = (F0H - 50H) 
$$\times$$
 t<sub>CLK</sub> t<sub>CLK</sub>: TMCLK cycle

- $\bigcirc$  TM0INT is generated when the timer counter register overflows. When overflow occurs, the timer counter register changes from FFH to 00H and continues upward counting.
- (8) If the P1.0/TM0CAP input changes, repeat operations (4) and (5) (third capture). Because the counter overflows once during the interval between the second capture and the third capture, the low-level pulse width t2 of the P1.0 input can be determined as follows.

$$t2 = (60H - F0H + 100H) \times t_{CLK}$$

(9) While TM0CAP = "1", there is no capture even when P1.0/TM0CAP changes.

Figure 7-9 shows the capture timing and Figure 7-10 shows the capture signal (CAPT) generator circuit.







Figure 7-10 Capture Signal (CAPT) Generator Circuit

Note:

The maximum delay from a P1.0/TM0CAP input level change until capture is one cycle of the timer clock.

7

#### 7.4.7 Frequency Measurement Mode Operation

The frequency measurement mode is used to measure the frequency of the RC oscillator clock, which has wide product variation.

Timers 0 and 1 can be used in the frequency measurement mode. These timers are set as follows for the frequency measurement mode:

- Timer 0: Set FMEAS0 (bit 2 of TM0CON0) to "1", and set TM0ECAP (bit 1 of TM0CON0) and TM0RUN (bit 0 of TM0CON0) to "0".
- Timer 1: Set TM1ECAP (bit 1 of TM1CON0) and TM1RUN (bit 0 of TM1CON0) to "0".

The frequency measurement mode measures the frequency of the RC oscillator clock, which varies because of production line variation. The count can be used to determine the autoreload mode timer data register value, and overflow the timer at the Baud rate needed for serial transmission.

Figure 7-11 indicates frequency measurement mode timing when timers 0 and 1 are used as a 16-bit timer.



Figure 7-11 Frequency Measurement Mode Timing

The operation sequence for Figure 7-11 is as follows.

- ① Timer 1 control registers 0 and 1 (TM1CON0, TM1CON1) are set for 16-bit timer mode, and the timer counter and timer data register are cleared to "0". Enable the high-speed clock by the frequency control register (FCON) and the timer clock is set to HSCLK.
- (2) Wait 10 ms or more in the ceramic oscillation mode or 300  $\mu$ s or more in the RC oscillation mode after starting the high-speed clock and set FMEAS0 to "1" to enter the frequency measurement mode.
- ③ When FMEAS0 is "1", the counter starts at the 1/512 TBC (64 Hz @ 32.768 kHz) falling edge.
- ④ When the 437C signal is "1", FMEAS0 is reset to "0", and the counter stops at the falling edge of the next clock. The 437C signal is a pulse signal which rises in 437/ 32768 second after the 1/512 TBC (64 Hz @ 32.768 kHz) falling edge.
- 5 Timer counter register value N1 is read.

Assuming that the ceramic oscillation clock is exactly 2 MHz, value N1 read from the timer counter register is:

N1 = 2000000 × 437/32768 = 26672 (decimal) = 6830 (hexadecimal) = 0110 1000 0011 0000 (binary) (truncated)

Because 437/32768 second is equivalent to 128 clocks at 9600 Hz (more precisely, 9598 Hz), a division of the count by 128 provides the frequency ratio (N2) between 2 MHz and 9600 Hz. Because  $128 = 2^7$ , that can be determined by merely truncating the righthand seven digits of N1 (binary), yielding

N2 = 26672/128 = 011010000 (binary) = D0 (hexadecimal) = 208 (decimal)

This indicates that 9600 Hz is about 208 times the cycle of 2 MHz, which means that the timer data register should be set to FF30H so that the counter overflows every 208 counts of the 2 MHz clock in auto-reload mode. As a result, overflow produces a TM1INT cycle  $t_{TM1INT}$  of

 $t_{\text{TM1INT}} = 1/2000000 \times 208 = 0.104 \text{ ms} (9615 \text{ Hz})$ 

In the same way, assuming that RC oscillation clock is 600 kHz due to manufacturing variation, we get

 $N1 = 600000 \times 437/32768 = 8001 \text{ (decimal)} \\ = 1F41 \text{ (hexadecimal)} \\ = 0001 1111 0 \underbrace{100 0001}_{\text{(truncated)}} \text{ (binary)}$ 

Truncating the righthand seven digits of N1 (binary), we get

N2 = 8001/128 = 000111110 (binary) = 3E (hexadecimal) = 62 (decimal)

Set the timer data register to FFC2H so that the counter overflows every 62 counts of the 600 kHz clock in auto-reload mode. As a result, overflow produces a TM1INT cycle t<sub>TM1INT</sub> of

 $t_{\text{TM1INT}} = 1/600000 \times 62 = 0.10333 \text{ ms} (9677 \text{ Hz})$ 

In this way the frequency measurement mode can be applied to generate TM1INT signals with precision cycles even from RC oscillators with large variation. These TM1INT signals can be supplied to the serial port as a Baud rate clock. Changing the value of N2 makes it possible to generate Baud rates of 4800 Hz, 2400 Hz or user-defined rates. The precision of the generated Baud rate clock is within  $\pm 2\%$  for 9600 Hz, and within  $\pm 1\%$  for 4800 Hz or lower.

Figure 7-12 illustrates the operation of Baud rate clock generation for an RC oscillator clock frequency of 600 kHz.



Figure 7-12 Baud Rate Clock Generation 1/512 TBC (@32.768 kHz)

## **Chapter 8**

# Ports (INPUT, OUTPUT, I/O PORT)

8

### Chapter 8 Ports (INPUT, OUTPUT, I/O PORT)

#### 8.1 Overview

The ML63512A and ML63514A have one 4-bit input port, one 4-bit output port, and nine 4-bit I/O ports. Port 6, Port 9, and Port A are provided for the 64-pin flat packages (64TQFP) and chip.

The V<sub>DDI</sub> (interface power supply) pin supplies power to the output port (Port 8).

If the output port is to be connected to an external device that operates on a different power supply, the power supply of the external device must be fed to the  $V_{DDI}$  pin.



Since  $V_{DDI}$  is separated from the positive power supply pin ( $V_{DD}$ ), power must be supplied to the  $V_{DDI}$  pin.

#### 8.2 Ports List

The ports of the ML63512A and the ML63514A are shown in Table 8-1.

| Port   | I/O | Interrupt | Sedondary<br>function | Page |
|--------|-----|-----------|-----------------------|------|
| Port 0 |     | •         |                       | 8-2  |
| Port 1 |     | _         |                       | 8-2  |
| Port 2 |     | _         | •                     | 8-2  |
| Port 3 | I/0 | _         |                       | 8-2  |
| Port 4 |     |           | —                     | 8-2  |
| Port 5 |     |           | —                     | 8-2  |
| Port 6 | 1   | _         | _                     | 8-2  |
| Port 7 | 1   |           | •                     | 8-19 |
| Port 8 | 0   | _         | _                     | 8-22 |
| Port 9 | 1/0 | _         | _                     | 8-2  |
| Port A | I/0 | _         | —                     | 8-2  |

#### Table 8-1 Ports List

## 8.3 Port 0 to Port 6, Port 9 and Port A (P0.0–P0.3, P1.0–P1.3, P2.0–P2.3, P3.0–P3.3, P4.0–P4.3, P5.0–P5.3, P6.0–P6.3, P9.0–P9.3, PA.0–PA.3)

The ML63512A and ML63514A have Port 0 to Port 6, Port 9 and Port A, 4-bit input/output ports.

#### 8.3.1 Port 0 to Port 6, Port 9 and Port A Configuration

The circuit configurations for port 0 to port 6, port 9 and port A are shown in Figures 8-1 to 8-4.



Figure 8-1 Input/Output Port (Ports 0 and 1) Configuration



Figure 8-2 Input/Output Port (Ports 2, 3 and 4) Configuration

8







Figure 8-4 Input/Output (Port A) Configuration

#### 8.3.2 Port 0 to Port 6, Port 9 and Port A Registers

(1) Port data registers (P0D, P1D, P2D, P3D, P4D, P5D, P6D, P9D, PAD)

The port 0 data register (P0D), port1 data register (P1D), port 2 data register (P2D), port 3 data register (P3D), port 4 data register (P4D), port 5 data register (P5D), port 6 data register (P6D), port 9 data register (P9D), and port A data register (PAD) are 4-bit special function registers (SFRs) used to set the output values for the ports.

When port direction registers (P0DIR, P1DIR, P2DIR, P3DIR, P4DIR, P5DIR) bits are set to "1" and the output mode selected, the contents of the port data registers are output to the ports.

When port direction registers (P6DIR, P9DIR, PADIR) bits are set to "0" and the output mode selected, the contents of the port data registers are output to the ports.

When the output mode is selected and the port data register read, the contents of the data register are read.

The port pin levels are read when the port data registers (P0DIR, P1DIR, P2DIR, P3DIR, P4DIR, P5DIR) are read with the port direction register bits set to "0" and the input mode selected.

The port pin levels are read when the port data registers (P6DIR, P9DIR, PADIR) are read with the port direction register bits set to "1" and the input mode selected.

• Port 0



Port 1

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P1D (001H)                 | P13   | P12   | P11   | P10   |
| (R/W)                      |       |       |       |       |
| Port 1 input/output data — |       |       |       |       |

• Port 2

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P2D (002H)                 | P23   | P22   | P21   | P20   |
| (R/W)                      |       |       |       |       |
| Port 2 input/output data — |       |       |       |       |

#### • Port 3

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P3D (003H)                 | P33   | P32   | P31   | P30   |
| (R/W)                      |       |       |       |       |
| Port 3 input/output data — |       |       |       |       |

• Port 4

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P4D (004H)                 | P43   | P42   | P41   | P40   |
| (R/W)                      |       |       |       |       |
| Port 4 input/output data — |       |       |       |       |

• Port 5



Port 6

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P6D (006H)                 | P63   | P62   | P61   | P60   |
| (R/W) <sup>L</sup>         |       |       |       |       |
| Port 6 input/output data — |       |       |       |       |

• Port 9

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| P9D (01CH)                 | P93   | P92   | P91   | P90   |
| (R/W) <sup>L</sup>         |       |       |       |       |
| Port 9 input/output data — |       |       |       |       |

• Port A

|                            | bit 3 | bit 2 | bit 1 | bit 0 |
|----------------------------|-------|-------|-------|-------|
| PAD (01DH)                 | PA3   | PA2   | PA1   | PA0   |
| (R/W)                      |       |       |       |       |
| Port A input/output data — |       |       |       |       |

At system reset the port data registers are set to "0". When data is written to a port data register, the actual pin change timing is at the rising edge of the system clock for state 2 of the write instruction.

Figure 8-5 shows port change timing.



Figure 8-5 Port Change Timing

(2) Port 0, Port 1, Port 2, Port 3, Port 4, Port 5, Port 6, Port 9, Port A direction registers (P0DIR, P1DIR, P2DIR, P3DIR, P4DIR, P5DIR, P6DIR, P9DIR, PADIR)

The port 0 direction register (P0DIR), port 1 direction register (P1DIR), port 2 direction register (P2DIR), port 3 direction register (P3DIR), port 4 direction register (P4DIR), port 5 direction register (P5DIR), port 6 direction register (P6DIR), port 9 direction register (P9DIR), and port A direction register (PADIR) are 4-bit special function registers (SFRs) which specify the port input/output direction for each bit.

For ports 0–5, pins corresponding to port direction register bits set to "0" are input, and those corresponding to bits set to "1" are output. For ports 6, 9 and A, pins corresponding to bits set to "0" are output, and those corresponding to bits set to "1" are input.

At system reset, each direction register is set to "0", and ports 0–5 are initialized to input and ports 6, 9 and A initialized to output.



Port 1



Port 2



#### Port 3



• Port 4

|                                                                             | bit 3  | bit 2  | bit 1  | bit 0  |
|-----------------------------------------------------------------------------|--------|--------|--------|--------|
| P4DIR (010H)                                                                | P43DIR | P42DIR | P41DIR | P40DIR |
| (R/W)                                                                       |        |        |        |        |
| <u>Port 4 input/output setting</u><br>0: Input (initial value)<br>1: Output |        |        |        |        |

#### • Port 5

|                                                                      | bit 3  | bit 2  | bit 1  | bit 0  |   |
|----------------------------------------------------------------------|--------|--------|--------|--------|---|
| P5DIR (011H)                                                         | P53DIR | P52DIR | P51DIR | P50DIR |   |
| (R/W)                                                                |        |        |        |        | • |
| Port 5 input/output setting<br>0: Input (initial value)<br>1: Output |        |        |        |        |   |

Port 6

|                                                                      | bit 3  | bit 2  | bit 1  | bit 0  |
|----------------------------------------------------------------------|--------|--------|--------|--------|
| P6DIR (012H)                                                         | P63DIR | P62DIR | P61DIR | P60DIR |
| (R/W)                                                                |        |        |        |        |
| Port 6 input/output setting<br>0: Output (initial value)<br>1: Input |        |        |        |        |

• Port 9



• Port A

|                                                                      | bit 3         | bit 2  | bit 1  | bit 0  |
|----------------------------------------------------------------------|---------------|--------|--------|--------|
| PADIR (01FH)                                                         | <b>PA3DIR</b> | PA2DIR | PA1DIR | PAODIR |
| (R/W)                                                                |               |        |        |        |
| Port A input/output setting<br>0: Output (initial value)<br>1: Input |               |        |        |        |

Note:

The initial values of ports 0-5 are "input" and those of ports 6, 9 and A are "output".

8

(3) Port 0, Port 1, Port 2, Port 3, Port 4, Port 5, Port 6, Port 9, Port A control registers (P0CON, P1CON, P2CON, P3CON, P4CON, P5CON, P6CON, P9CON, PACON)

The port 0 control register (P0CON), port 1 control register (P1CON), port 2 control register (P2CON), port 3 control register (P3CON), port 4 control register (P4CON), port 5 control register (P5CON), port 6 control register (P6CON), port 9 control register (P9CON), and port A control register (PACON) are 4-bit special function registers (SFRs) used to select port input/output mode.

The input mode may be pull-up resistor input or high-impedance input.

The output mode may be CMOS output or N-channel open drain output.

|  | • | P | ort | ( | ) |  |  |
|--|---|---|-----|---|---|--|--|
|--|---|---|-----|---|---|--|--|

|                                                                                                                                                                                                                                                                 | bit 3                                                                 | bit 2                                                                                                            | bit 1 | bit 0 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-------|
| POCON (013H)                                                                                                                                                                                                                                                    | P03CN                                                                 | P02CN                                                                                                            | P01CN | POOCN |
| (R/W)<br><u>Port 0.3 input/output mode sele</u><br>Input mode<br>0: High-impedance input (initia<br>1: Input with pull-up resistor<br><u>Port 0.2 input/output mode sele</u><br>Input mode<br>0: High-impedance input (initia<br>1: Input with pull-up resistor | Outpu<br>Il value) 0: CM<br>1: N-c<br>ect<br>Outpu<br>Il value) 0: CM | t mode<br>OS output (initial va<br>hannel open drain o<br>t mode<br>OS output (initial va<br>hannel open drain o | lue)  |       |
| Port 0.1 input/output mode selection<br>Input mode<br>0: High-impedance input (initia<br>1: Input with pull-up resistor<br>Port 0.0 input/output mode selection<br>Input mode<br>0: High-impedance input (initia<br>1: Input with pull-up resistor              | Outpu<br>Il value) 0: CM<br>1: N-c<br>ect<br>Outpu<br>Il value) 0: CM | t mode<br>OS output (initial va<br>hannel open drain o<br>t mode<br>OS output (initial va<br>hannel open drain o | lue)  |       |

• Port 1

|                                                                                                                                                                                                                                                 | bit 3                                                                                  | bit 2                                                                                                            | bit 1 | bit 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-------|
| P1CON (014H)                                                                                                                                                                                                                                    | P13CN                                                                                  | P12CN                                                                                                            | P11CN | P10CN |
| (R/W)<br><u>Port 1.3 input/output mode s</u><br>Input mode<br>0: High-impedance input (in<br>1: Input with pull-up resisto<br><u>Port 1.2 input/output mode s</u><br>Input mode<br>0: High-impedance input (in<br>1: Input with pull-up resisto | Outpu<br>itial value) 0: CM<br>r 1: N-c<br><u>elect</u><br>Outpu<br>itial value) 0: CM | t mode<br>OS output (initial va<br>hannel open drain c<br>                                                       | utput |       |
| Port 1.1 input/output mode s<br>Input mode<br>0: High-impedance input (in<br>1: Input with pull-up resisto<br>Port 1.0 input/output mode s<br>Input mode<br>0: High-impedance input (in<br>1: Input with pull-up resisto                        | Outpu<br>itial value) 0: CM<br>r 1: N-c<br><u>elect</u><br>Outpu<br>itial value) 0: CM | t mode<br>OS output (initial va<br>hannel open drain c<br>t mode<br>OS output (initial va<br>hannel open drain c | lue)  |       |

#### • Port 2

|                                                                                                                                                                                                                              | bit 3                                                                             | bit 2                                                                                                            | bit 1 | bit O |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-------|
| P2CON (015H)<br>(R/W)                                                                                                                                                                                                        | P23CN                                                                             | P22CN                                                                                                            | P21CN | P20CN |
| Port 2.3 input/output mode s<br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull-up resiston<br>Port 2.2 input/output mode s<br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull-up resiston | Outpu<br>itial value) 0: CMu<br>- 1: N-c<br>elect<br>Outpu<br>itial value) 0: CMu | t mode<br>DS output (initial va<br>hannel open drain o<br>t mode<br>DS output (initial va<br>hannel open drain o | lue)  |       |
| Port 2.1 input/output mode s<br>Input mode<br>O: High-impedance input (in<br>1: Input with pull-up resistor                                                                                                                  | Outpu<br>tial value) 0: CM                                                        | t mode<br>DS output (initial va<br>hannel open drain o                                                           | ,     |       |
| Port 2.0 input/output mode s<br>Input mode<br>0: High-impedance input (in<br>1: Input with pull-up resistor                                                                                                                  | Outpu<br>tial value) 0: CM                                                        | t mode<br>DS output (initial va<br>hannel open drain o                                                           |       |       |

8

#### Port 3

| bit                                                                                                                                                                                                                                                                                 | 3                                 | bit 2                                                      | bit 1 | bit 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------------------------------------------------------|-------|-------|
| P3CON (016H) P33(                                                                                                                                                                                                                                                                   | CN                                | P32CN                                                      | P31CN | P30CN |
| (R/W)<br><u>Port 3.3 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor<br><u>Port 3.2 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor | 0: CM<br>1: N-c<br>Outpu<br>0: CM | t mode<br>OS output (initial va<br>hannel open drain o<br> | lue)  |       |
| Port 3.1 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | 0: ĊM                             | t mode<br>OS output (initial va<br>hannel open drain o     |       |       |
| Port 3.0 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | 0: CM                             | t mode<br>OS output (initial va<br>hannel open drain o     | ,     |       |

#### • Port 4

| bit 3                                                                                                                                                                                                                                                                               | bit 2                                                                                                                      | bit 1                    | bit 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------|-------|
| P4CON (017H) P43C                                                                                                                                                                                                                                                                   | N P42CN                                                                                                                    | P41CN                    | P40CN |
| (R/W)<br><u>Port 4.3 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor<br><u>Port 4.2 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor | Output mode<br>0: CMOS output (init<br>1: N-channel open dr<br>Output mode<br>0: CMOS output (init<br>1: N-channel open dr | ain output<br>ial value) |       |
| Port 4.1 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | Output mode<br>0: CMOS output (init<br>1: N-channel open dr                                                                | ,                        |       |
| Port 4.0 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | Output mode<br>0: CMOS output (init<br>1: N-channel open dr                                                                | ,                        |       |

• Port 5

| bit 3                                                                                                                                                                                                                                                                               | 3 bit                                                                                                | 2                           | bit 1        | bit 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------------|--------------|-------|
| P5CON (018H) P53C                                                                                                                                                                                                                                                                   | N P52                                                                                                | CN                          | P51CN        | P50CN |
| (R/W)<br><u>Port 5.3 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor<br><u>Port 5.2 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor | Output mode<br>0: CMOS output<br>1: N-channel op<br>Output mode<br>0: CMOS output<br>1: N-channel op | en drain ou<br>(initial val | utput<br>ue) |       |
| Port 5.1 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor<br>Port 5.0 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                        | Output mode<br>0: CMOS output<br>1: N-channel op<br>Output mode<br>0: CMOS output<br>1: N-channel op | en drain ou                 | utput<br>ue) |       |

#### • Port 6

| bit 3                                                                                                                                                                                                                                                                               | B bit                                                                                                  | 2                            | bit 1       | bit 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------|-------------|-------|
| P6CON (019H) P63C                                                                                                                                                                                                                                                                   | N P620                                                                                                 | CN                           | P61CN       | P60CN |
| (R/W)<br><u>Port 6.3 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor<br><u>Port 6.2 input/output mode select</u><br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor | Output mode<br>0: CMOS output<br>1: N-channel ope<br>Output mode<br>0: CMOS output<br>1: N-channel ope | n drain out<br>(initial valu | tput<br>ie) |       |
| Port 6.1 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | Output mode<br>0: CMOS output<br>1: N-channel ope                                                      | •                            | ,           |       |
| Port 6.0 input/output mode select<br>Input mode<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                        | Output mode<br>0: CMOS output<br>1: N-channel ope                                                      | •                            | ,           |       |

8

#### Port 9

|                                                                                                                                                                                                                                                                                  | bit 3                                     | bit 2                                                      | bit 1 | bit 0 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------|-------|-------|
| -                                                                                                                                                                                                                                                                                | 93CN                                      | P92CN                                                      | P91CN | P90CN |
| (R/W) <u>Port 9.3 input/output mode select</u> –<br>Input mode<br>0: High-impedance input (initial valu<br>1: Input with pull-up resistor<br><u>Port 9.2 input/output mode select</u> –<br>Input mode<br>0: High-impedance input (initial valu<br>1: Input with pull-up resistor | ue) 0: CM<br>1: N-c<br>Outpu<br>ue) 0: CM | t mode<br>OS output (initial va<br>hannel open drain o<br> | lue)  |       |
| Port 9.1 input/output mode select<br>Input mode<br>O: High-impedance input (initial value)<br>1: Input with pull-up resistor                                                                                                                                                     | ue) 0: CM                                 | t mode<br>OS output (initial va<br>hannel open drain o     |       |       |
| Port 9.0 input/output mode select<br>Input mode<br>0: High-impedance input (initial valu<br>1: Input with pull-up resistor                                                                                                                                                       | ue) 0: CM                                 | t mode<br>OS output (initial va<br>hannel open drain o     |       |       |

#### • Port A

| -                                                                                                                                                                                                                                                   | bit 3                                                                                | bit 2                                                                                                            | bit 1 | bit 0 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-------|
| PACON (021H)                                                                                                                                                                                                                                        | PA3CN                                                                                | PA2CN                                                                                                            | PA1CN | PAOCN |
| (R/W)<br><u>Port A.3 input/output mode s</u><br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull-up resistor<br><u>Port A.2 input/output mode s</u><br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull up resistor | Outpur<br>tial value) 0: CM<br>1: N-c<br><u>elect</u><br>Outpur<br>tial value) 0: CM | t mode<br>DS output (initial va<br>hannel open drain o<br>t mode<br>DS output (initial va<br>hannel open drain o | lue)  |       |
| 1: Input with pull-up resistor<br><u>Port A.1 input/output mode s</u><br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull-up resistor                                                                                               | elect<br>Outpu<br>tial value) 0: CM                                                  | t mode<br>DS output (initial va<br>hannel open drain o                                                           | lue)  |       |
| Port A.0 input/output mode s<br>Input mode<br>0: High-impedance input (ini<br>1: Input with pull-up resistor                                                                                                                                        | Outpu<br>tial value) 0: CM                                                           | t mode<br>DS output (initial va<br>hannel open drain o                                                           | ,     |       |

(4) Port Mode Registers (P1MOD, P2MOD, P3MOD)

The port 1 mode register (P1MOD), port 2 mode register (P2MOD), and port 3 mode register (P3MOD) are 4-bit special function registers (SFRs) used to select the secondary functions and normal port functions of ports 1–3.

Table 8-2 lists the secondary functions of ports 1–3.

| Port | Secondary<br>function | Description                                                 |
|------|-----------------------|-------------------------------------------------------------|
| P1.0 | TM0CAP                | Timer 0 capture input                                       |
| P1.1 | TM1CAP                | Timer 1 capture input                                       |
| P1.2 | TOCK                  | Timer 0 external clock input                                |
| P1.3 | T1CK                  | Timer 1 external clock input                                |
| P1.0 | TM00VF                | Timer 0 overflow flag output                                |
| P1.1 | TM10VF                | Timer 1 overflow flag output                                |
| P2.0 | TBCCLK                | Low-speed oscillation clock output                          |
| P2.1 | HSCLK                 | High-speed oscillation clock output                         |
| P3.0 | RXD                   | Serial port receive data input                              |
| P3.1 | TXC                   | Synchronous clock input/output for serial port transmission |
| P3.2 | RXC                   | Synchronous clock input/output for serial port reception    |
| P3.3 | TXD                   | Serial port transmit data output                            |

#### Table 8-2 Ports 1–3 Secondary Functions

Port 1

|                                                                                                                                                                                                                                                                                     | bit 3                                       | bit 2     | bit 1  | bit 0  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------|--------|--------|
| P1MOD (00BH)                                                                                                                                                                                                                                                                        | —                                           | —         | P11MOD | P10M0D |
| (R/W)<br><u>Port 1.1 pin function select</u><br>0: Input/output function (ini<br>1: Timer 1 overflow flag out<br>(Goes into output mode irre<br><u>Port 1.0 pin function select</u><br>0: Input/output function (ini<br>1: Timer 0 overflow flag out<br>(Goes into output mode irre | put (TM1OVF) func<br>spective of P11DIR<br> | )<br>tion |        |        |

#### ML63512A/514A User's Manual Chapter 8 Ports (INPUT, OUTPUT, I/O PORT)

#### Port 2

|                                                                                                                                               | bit 3              | bit 2 | bit 1  | bit 0  |
|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------|--------|--------|
| P2MOD (00DH)                                                                                                                                  | —                  | —     | P21MOD | P20M0D |
| (R/W)<br><u>Port 2.1 pin function select</u><br>0: Input/output function (ini<br>1: High-speed oscillation clo<br>(Goes into output mode irre |                    |       |        |        |
| Port 2.0 pin function select<br>0: Input/output function (initial value)<br>1: Low-speed oscillation clock output (TBCCLK)                    |                    |       |        |        |
| (Goes into output mode irre                                                                                                                   | spective of P20DIR | )     |        |        |

#### • Port 3

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | bit 3                                                                                                                                                                                                  | bit 2                                     | bit 1   | bit 0   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------|---------|
| P3MOD (00FH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | P33M0D                                                                                                                                                                                                 | P32M0D                                    | P31MOD  | P30M0D  |
| (R/W)<br><u>Port 3.3 pin function select</u><br>0: Input/output function (init<br>1: Serial port transmit data of<br>(Goes into output mode irre<br><u>Port 3.2 pin function select</u><br>0: Input/output function (init<br>1: Serial port receive clock in<br>(Switching of input/output n<br>port receive control register<br><u>Port 3.1 pin function select</u><br>0: Input/output function (init<br>1: Serial port transmit clock<br>(Switching of input/output n<br>register STCON1, irrespective<br><u>Port 3.0 pin function select</u><br>0: Input/output function (init<br>1: Serial port receive data in<br>(Goes into input mode irrespective) | autput (TXD)<br>spective of P33DIR<br>ial value)<br>node depends on th<br>SRCON1, irrespect<br>ial value)<br>input/output (TXC)<br>node depends on th<br>e of the P31DIR va<br>ial value)<br>put (RXD) | e SRCLK bit of the<br>ive of the P32DIR v | ralue.) | control |

#### 8.4 Port 7 (P7.0-P7.3)

#### 8.4.1 Port 7 Configuration

The ML63512A and ML63514A have Port 7, a 4-bit input-only port.

Figure 8-6 shows the configuration of port 7.



#### Figure 8-6 Input-Only Port (Port 7) Configuration

#### 8.4.2 Port 7 Registers

(1) Port 7 Data Register (P7D)

The port 7 data register (P7D) is a 4-bit read-only special function register (SFR) used to read the pin level of each bit of port 7.



#### (2) Port Control Registers (P7CON)

Port 7 control register (P7CON) is a 4-bit special function register (SFR) that selects pull-up resistor input or high-impedance input.

|                                                                                                                                        | bit 3 | bit 2 | bit 1 | bit 0 |  |
|----------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|--|
| P7CON (01AH)                                                                                                                           | P73CN | P72CN | P71CN | P70CN |  |
| (R/W)  Port 7.3 input mode select  0: High-impedance input (initial value)  1: Input with pull-up resistor  Port 7.2 input mode select |       |       |       |       |  |
| Port 7.2 input mode select<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                |       |       |       |       |  |
| Port 7.1 input mode select<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                |       |       |       |       |  |
| Port 7.0 input mode select<br>0: High-impedance input (initial value)<br>1: Input with pull-up resistor                                |       |       |       |       |  |

#### 8.4.3 Port 7 Secondary Functions

Port 7 is assigned the following secondary functions:

- Comparator analog input pin (assigned to P7.0)
- Comparator reference voltage input pin (assigned to P7.1)
- Level detector analog input pin (assigned to P7.2 and P7.3)

When using a secondary function, select high-impedance input.

#### 8.5 Port 8 (P8.0-P8.3)

The ML63512A and ML63514A have Port 8, a 4-bit N-channel open drain output port.

Port 8 enables direct driving of LED.

Power is supplied to port 8 through  $V_{DDI}$  (interface power supply).

If port 8 is to be connected to an external device that uses a different power supply, use the power supply to supply power to  $V_{\text{DDI}}.$ 

Note:

Be sure to supply power to  $V_{DDI},$  because  $V_{DDI}$  is separated from the positive power supply pin (V\_{DD}) of the chip.

#### 8.5.1 Port 8 Configuration

The circuit configuration for port 8 is shown in Figure 8-7.



Figure 8-7 Output Port (Port 8) Configuration

#### 8.5.2 Port 8 Registers

(1) Port 8 data register (P8D)

P8D is a 4-bit special function register used to set the output values for port 8.



At system reset the port 8 data register (P8D) is set to "0FH". When data is written to the port 8 data register, the actual pin change timing is at the rising edge of the system clock for state 2 of the write instruction.

Figure 8-8 indicates port change timing.



Figure 8-8 Port 8 Change Timing

#### 8.6 External Interrupt

#### 8.6.1 External Interrupt Overview

External interrupts are assigned to port 0 (P0.0–P0.3) as secondary functions. Interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt can be specified for external interrupt 0 (assigned to P0.0), external interrupt 1 (assigned to P0.1), external interrupt 2 (assigned to P0.2), and external interrupt 3 (assigned to P0.3).

Table 8-3 lists the external interrupts.

| Port      | Interrupt factor     | Mnemonic | IRQ flag      | IE flag      | Interrupt vector<br>address |
|-----------|----------------------|----------|---------------|--------------|-----------------------------|
| P0.0/INT0 | External interrupt 0 | XIOINT   | QXI0 (IRQ0.0) | EXI0 (IE0.0) | 0010H                       |
| P0.1/INT1 | External interrupt 1 | XI1INT   | QXI1 (IRQ0.1) | EXI1 (IE0.1) | 0012H                       |
| P0.2/INT2 | External interrupt 2 | XI2INT   | QXI2 (IRQ0.2) | EXI2 (IE0.2) | 0014H                       |
| P0.3/INT3 | External interrupt 3 | XI3INT   | QXI3 (IRQ0.3) | EXI3 (IE0.3) | 0016H                       |

#### Table 8-3 List of External Interrupts

If a rising or falling edge signal is input to each port when the master interrupt enable flag (MIE) and each of the interrupt enable flags (EXI0–EXI3) are both set to "1", an interrupt will be requested to the CPU.

#### 8.6.2 External Interrupt Configuration

Figure 8-9 shows the external interrupt circuit configuration.



Figure 8-9 External Interrupt Circuit Configuration

#### 8.6.3 External Interrupt Control Registers

External interrupt control register 0, 1 (XICON0, XICON1) are 4-bit special function registers (SFRs). These registers are used to select interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt for the external interrupts assigned to port 0 (P0.0–P0.3).

At system reset XICON0 and XICON1 are initialized to "0" and enter the interrupt reception disabled state.



#### bit 3, 2: XI1SEL1, XI1SEL0

These bits select interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt for external interrupt 1.

#### bit 1, 0: XI0SEL1, XI0SEL0

These bits select interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt for external interrupt 0.



#### bit 3, 2: XI3SEL1, XI3SEL0

These bits select interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt for external interrupt 3.

#### bit 1, 0: XI2SEL1, XI2SEL0

These bits select interrupt reception disabled, rising edge interrupt, falling edge interrupt, or both rising and falling edges interrupt for external interrupt 2.

## **Chapter 9**

# Serial Port (SIO)

9

### Chapter 9 Serial Port (SIO)

#### 9.1 Overview

The ML63512A and ML63514A have a built-in serial communication port (serial port) for either synchronous or asynchronous communication.

The serial port implements the send and receive circuits in independent circuits, making it possible to send and receive simultaneously.

The send and receive modes can be UART mode (asynchronous communication mode) or synchronous mode (synchronous communication mode).

In synchronous mode an internal clock mode generates the shift clock internally, and an external clock mode receives an external shift clock.

Table 9-1 shows the serial port modes.

| side                |           | Mode        |                                          | Baud rate                      |  |
|---------------------|-----------|-------------|------------------------------------------|--------------------------------|--|
|                     | UART mode |             | Can be set to a user-specified value     |                                |  |
|                     |           |             |                                          | with timers 0, 1 (TM0, 1)      |  |
|                     | Send      | Synchronous | Internal clock mode                      | Low-speed clock (30 to 80 kHz) |  |
| ort                 |           | mode        | External clock mode                      | From external clock            |  |
| Serial port<br>side |           |             |                                          | • 2 TBCCLK                     |  |
|                     | UART mode |             | • TBCCLK                                 |                                |  |
|                     |           |             |                                          | • 1/2 TBCCLK                   |  |
| Receive             |           |             | • Timer 0,1 overflow (16-bit timer mode) |                                |  |
| Ĕ                   |           | Synchronous | Internal clock mode                      | Low-speed clock (30 to 80 kHz) |  |
|                     |           | mode        | External clock mode                      | From external clock            |  |

#### Table 9-1 Serial Port Modes

#### 9.2 Serial Port Configuration

Figure 9-1 indicates the serial port configuration.

The serial port consists of the send/receive clock generator circuits, the send/receive control registers, the buffer registers to store send/receive data, send/receive data transfer shift registers, and the send/receive status registers.

P3.0/RXD is the send serial data input pin, P3.3/TXD is the send serial data output pin, P3.1/ TXC is the serial send clock I/O pin, and P3.2/RXC is the serial receive clock I/O pin. Set I/ O and secondary functions with the port control registers as needed for each communication mode.



9-2

#### 9.3 Serial Port Registers

(1) Send control registers 0/1 (STCON0, STCON1)

STCON0 and STCON1 are 4-bit special function registers (SFRs) to control the serial port send operation. STCON0 and STCON1 are initialized to "0" at system reset.



bit 3: STSTB (Serial Transmission STop Bit)

This bit specifies stop bit length. Valid only when bit 0 is "0" (UART mode).

bit 2, 1: STL1 (Serial Transmission Length select bit 1),

STL0 (Serial Transmission Length select bit 0)

These bits specify the send data length.

bit 0: STMOD (Serial Transmission MODe bit)

This bit specifies the serial port send operation mode.

|                                                                                                                                                                                 | bit 3 | bit 2 | bit 1 | bit 0 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|
| STCON1 (0A7H)                                                                                                                                                                   | STLMB | STP0E | STPEN | STCLK |
| (R/W)<br><u>LSB/MSB head select</u><br>0 : Start from LSB (initial v<br>1 : Start from MSB<br><u>Odd/even parity select</u><br>0 : Odd parity (initial value<br>1 : Even parity |       |       |       |       |
| Parity set<br>0 : No parity bit (initial val<br>1 : Parity bit                                                                                                                  | ue)   |       |       |       |
| Send external/internal cloc<br>0 : External clock mode (ir<br>1 : Internal clock mode                                                                                           |       |       |       |       |

bit 3: STLMB (Serial Transmission Least significant bit first or Most significant Bit first) This bit specifies either LSB first or MSB first for send data.

bit 2: STPOE (Serial Transmission Parity Odd or Even number bit)

This bit specifies whether the parity bit is even or odd. Valid only when bit 1 is "1" (parity bit).

bit 1: STPEN (Serial Transmission Parity ENable bit)

This bit specifies whether or not a parity bit is added.

bit 0: STCLK (Serial Transmission CLocK select bit)

This bit specifies the external/internal send clock for synchronous mode. Valid only during synchronous mode.

#### (2) Send buffer registers (STBUFL, STBUFH)

STBUFL and STBUFH are 4-bit special function registers (SFRs) that set send data for serial port send operation.

LSB/MSB selection (described later) allows the data send direction (LSB or MSB first) to be specified. Both STBUFL and STBUFH are initialized to "0" at system reset.

Send operation begins when send data is set to STBUFH. Be sure to set send data to STBUFL before setting data to STBUFH.

Also set the baud rate and send mode before beginning send operation.

If send operation is already under way when send data is set to STBUFH, send for the new data begins when the prior send has ended, and at the same time an interrupt request signal (STINT) is generated. In the STINT interrupt routine the program should first write the send data to STBUFL and STBUFH to assure no pauses in the send sequence.

#### (3) Send register

The send register is a shift register that handles the shift operation in send. At system reset it is cleared to 00H. The send register cannot be directly accessed from the CPU.

The hardware send flow is indicated in Figure 9-2, to explain the timing for transfer of data from STBUFL/H to the send register.

First set the send mode and baud rate. When send data is set to STBUFH, the status (SSTAT) buffer full flag (BFULL) is set to "1", and unless send operation is already under way the content of STBUFL/H is transferred to the send register and send operation begins. When send operation begins the BFULL flag is reset to "0", and the next send data can be set to STBUFL/H.

If prior data send operation is not complete, the send data is held in STBUFL/H until send is completed. In this case BFULL remains set to "1". When the prior send operation is complete the send data will be transferred from STBUFL/H to the send register, and send begins.

Note:

When BFULL is "1" it is possible to set data to STBUFL/H, but prior data set to STBUFL/H that is being held there is overwritten and lost. Always set data after verifying that the BFULL flag is "0".



Figure 9-2 Hardware Send Operation Flow

(4) Receive control registers 0/1 (SRCON0, SRCON1)

SRCON0 and SRCON1 are 4-bit special function registers (SFRs) controlling serial port receive operation.

SRCON0 and SRCON1 are initialized to "0" at system reset.



bit 3: SREN (Serial Reception ENable bit)

This bit specifies receive operation disable/enable. After receive is enabled in the synchronous mode, this bit is reset to "0" after receiving one frame of data. In the UART mode it does not change.

bit 2, 1: SRL1 (Serial Reception Length select bit 1), SRL0 (Serial Reception Length select bit 0)

These bits specify the receive data length.

bit 0: SRMOD (Serial Reception MODe bit)

This bit specifies the serial port receive operation mode.

| -                                                                                                                                                                                | bit 3       | bit 2 | bit 1 | bit 0 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|-------|-------|
| SRCON1 (0ABH)                                                                                                                                                                    | SRLMB       | SRPOE | SRPEN | SRCLK |
| (R/W)<br><u>LSB/MSB head select</u> —<br>0 : Start at LSB (initial val<br>1 : Start at MSB<br><u>Odd/even parity select</u> —<br>0 : Odd parity (initial valu<br>1 : Even parity |             |       |       |       |
| Parity set<br>0 : No parity bit (initial va<br>1 : Parity bit<br><u>Receive external/internal c</u><br>0 : External clock mode<br>1 : Internal clock mode                        | lock select |       |       |       |

bit 3: SRLMB (Serial Reception Least significant bit first or Most significant Bit first) This bit specifies either LSB first or MSB first for receive data.

bit 2: SRPOE (Serial Reception Parity Odd or Even number bit)

This bit specifies whether the parity bit is even or odd. Valid only when bit 1 is "1" (parity bit).

bit 1: SRPEN (Serial Reception Parity ENable bit)

This bit specifies whether or not a parity bit is added.

bit 0: SRCLK (Serial Reception CLocK select bit)

This bit specifies the external/internal receive clock for synchronous mode. Valid only during synchronous mode.

#### (5) Receive register

The receive register is the shift register that handles shift operation at receive. It is initialized to 00H at system reset. It cannot be directly accessed by the CPU. When a receive operation is complete, the data read into the receive register is transferred to SRBUFL/H, and at the same time the receive interrupt request signal (SRINT) is generated.



(6) Receive buffer registers (SRBUFL, SRBUFH)

SRBUFL and SRBUFH are 4-bit special function registers (SFRs) used to hold the received data in serial port reception. SRBUFL and SRBUFH are initialized to "0" at system reset.

When receive operation is completed the contents of the receive register are sent to SRBUFL/ H, and the receive interrupt request (SRINT) is generated. The contents of SRBUFL/H are held until the next receive operation is completed.

If data from a prior receive operation is in SRBUFL/H and new data is received, an overrun error will result. When an overrun error is generated, new received data cannot be loaded into SRBUFL/H.

(7) Receive baud rate set register (SRBRT)

SRBRT is a 4-bit special function register (SFR) used to set the receive baud rate for serial port receive operation in UART mode.

SRBRT is initialized to 0CH at system reset.



bit 1, 0: BRT1 (Baud RaTe select bit1), BRT0 (Baud RaTe select bit 0)

These bits set the receive baud rate.

(8) Serial status register (SSTAT)

SSTAT is a 4-bit special function register (SFR) used to indicate the status of serial port send/ receive.

SSTAT is initialized to "0" at system reset.

SSTAT is a read-only register, and the content is reset every time it is read.

|                                                                                                                                                                                                                                     | bit 3 | bit 2 | bit 1 | bit 0 |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|--|--|
| SSTAT (0ADH)                                                                                                                                                                                                                        | BFULL | PERR  | OERR  | FERR  |  |  |
| (R)<br><u>Send buffer status flag</u><br>0 : Send buffer empty (init<br>1 : Send buffer full<br><u>Parity error flag</u><br>0 : No parity error (initial v<br>1 : Parity error                                                      |       |       |       |       |  |  |
| 1 : Parity error         Overrun flag         0 : No overrun error (initial value)         1 : Overrun error         Framing error         0 : No framing error (initial value)         1 : Framing error         1 : Framing error |       |       |       |       |  |  |

bit 3: BFULL (send Buffer FULL flag)

This bit is enabled in both UART and synchronous modes, and is set to "1" when send data is set to STBUFL/H in the send mode, and reset to "0" when the send data is transferred to the send register.

When BFULL is set to "1" and send data is set (written) to STBUFL/H, the previous data set to those registers is overwritten and lost. Always set data only after verifying that the BFULL flag is "0".

bit 2: PERR (Parity ERRor flag)

This bit is enabled in both UART and synchronous modes, and is set to "1" when the parity for the received data does not match the parity bit attached to the data.

bit 1: OERR (Overrun ERRor flag)

This bit is enabled in both UART and synchronous modes, and is set to "1" when data reception is completed and the data received the previous time has still not been transferred to the CPU. In this case, the new data cannot be transferred to SRBUFL/H.

bit 0: FERR (Framing ERRor flag)

This is only enabled in the UART mode and is set to "1" in the following instances.

(1) when a "1" is detected in start bit sampling

(2) when a "0" is detected in stop bit sampling

In either case a receive interrupt request signal (SRINT) is generated.

#### 9.4 Serial Port Operation Description

#### 9.4.1 Data Format

(1) UART mode

The data format for the UART mode is shown in Figure 9-3.

SRCON0/1 and STCON0/1 can be set to specify a data bit length of 5 to 8 bits. The parity bit can be enabled/disabled. If enabled it can be set to even or odd. Stop bit length can be set to 1 or 2 bits.

The combination of these parameters gives a range of from 7 to 12 bits for send/ receive data frames.



Figure 9-3 UART Mode Data Format

(2) Synchronous mode

The data format for the UART mode is shown in Figure 9-4.

SRCON0/1 and STCON0/1 can be set to specify a data bit length of 5 to 8 bits. The parity bit can be enabled/disabled, and if enabled can be set to even or odd.

The combination of these parameters gives a range of from 5 to 9 bits for send/ receive data frames.



Figure 9-4 Synchronous Mode Data Format

#### 9.4.2 Send Operation Description

The serial port send circuit has a two-stage configuration. This consists of the send register and the send buffer register (STBUFL/H), so it is possible to set send data to STBUFL/H while sending the previous data. When the serial status flag is (SSTAT) BFULL flag is "1", however, it indicates that STBUFL/H send data has not yet been transferred to the send register. Always verify that the BFULL flag is "0" before transferring data.

(1) UART mode

The UART mode is specified by setting STMOD (bit 0 of STCON0) to "0". Figure 9-5 is the UART mode send timing chart. The UART mode send procedure is described below. The send baud rate is set first, then the timer, and then the send format (data bit length, parity bit, etc.) in STCON0, STCON1. The TM1INT signal supplied from timer 0, 1 is the baud rate clock.

- A Set send data to STBUFL/H.
- <sup>(B)</sup> The send data is transferred from STBUFL/H to the send register, and send operation begins. At the same time generate the serial port send interrupt request (STINT) is generated.
- $\bigcirc$  Verify that BFULL = "0", then set the next send data to STBUFL/H.
- When send operation is complete, the send data set to STBUFL/H is transferred to the send register, and send operation begins. At the same time the serial port send interrupt request (STINT) is generated.

Repeat operation <sup>©</sup> the required number of times.



Figure 9-5 UART Mode Send Timing Chart

(2) Synchronous internal clock mode

The synchronous internal clock mode is selected by setting STMOD (bit 0 of STCON0) to "1", and STCLK (bit 0 of STCON1) to "1".

Figure 9-6 is the send timing chart for the synchronous internal clock mode.

The synchronous internal clock send procedure is described below.

First the send format (data bit length, parity bit, etc.) is set to STCON0 and STCON1.

(A) Set send data to STBUFL/H.

- B The send data is transferred from STBUFL/H to the send register, and send operation begins. At the same time the interrupt request signal (STINT) is generated.
- © Check that BFULL = "0", then set the next send data to STBUFL/H.
- When the send operation is complete, the send data set to STBUFL/H is transferred to the send register, and the send operation begins. At the same time, the serial port send interrupt signal (STINT) is generated.

Repeat step (C) the required number of times.

In the synchronous internal clock mode the send baud rate is fixed at the crystal oscillation frequency, that is, the frequency of the time base clock (TBCCLK).

After data is set to STBUFH, the send clock (TXCO) generates between 2 and 3.5 clocks of the TBCCLK source, and a send operation starts.



(3) Synchronous external clock mode

The synchronous external clock mode is selected by setting STMOD (bit 0 of STCON0) to "1", and STCLK (bit 0 of STCON1) to "0".

Figure 9-7 is the send timing chart for the synchronous external clock mode.

The synchronous external clock send procedure is described below.

First set the send format (data bit length, parity bit, etc.) to STCON0 and STCON1.

Set send data to STBUFL/H.

- <sup>®</sup> The send data is transferred from STBUFL/H to the send register, and at the same time the interrupt request signal (STINT) is generated.
- © Send operation is started by the send shift clock (TXCI).
- O Check that BFULL = "0", then set the next send data to STBUFL/H.
- ©When the send operation is complete, the send data set to STBUFL/H is transferred to the send register. At the same time, the serial port send interrupt signal (STINT) is generated.

Repeat step <sup>(D)</sup> the required number of times.

In the synchronous external clock mode the send baud rate is determined by the input shift clock (TXCI).

To send data continuously, keep an interval of at least 3.5 clocks of TBCCLK for one frame of clocked (TXCI) send data.



#### 9.4.3 Receive Operation Description

#### (1) UART mode

The UART mode is specified by setting SRMOD (bit 0 of SRCON0) to "0". Figure 9-8 is the UART mode receive timing chart. The UART mode receive procedure is described below.

First set the receive baud rate in the receive baud rate set register (SRBRT). Supported baud rates for UART mode receive are 2 TBCCLK, TBCCLK, 1/2 TBCCLK, and Timer 0/1 overflow (16-bit timer mode).

Set the receive format (data bit length, parity bit, etc.) in SRCON0 and SRCON1.

Set SREN (bit 3 of SRCON0) to "1" to enable receive.

 BAt the negative edge of the receive data (RXD) start bit, receive operation will start.

©Receive operation ends.

If a framing or overrun error occurs the FERR or OERR flag of the status register (SSTAT) will be set to "1".

If a parity error occurs, the PERR flag of the status register (SSTAT) is set to "1".

©The serial port receive interrupt request (SRINT) is generated.

Receive data is received until receive is disabled (SREN = "0"). When receive is ended, reset the receive enable/disable flag (SREN) to "0".

The receive data sampling clock (SRSMPL) is based on the low-speed clock supply, not on the high-speed clock. This allows receive operations to be executed while in the energy-saving mode.



9-20

(2) Synchronous internal clock mode

The synchronous internal clock mode is selected by setting SRMOD (bit 0 of SRCON0) to "1" and SRCLK (bit 0 of SRCON1) to "1".

Figure 9-9 is the receive timing chart for the synchronous internal clock mode.

The synchronous internal clock receive procedure is indicated below.

First set the receive format (data bit length, parity bit, etc.) in SRCON1 and SRCON0.

Set SREN (bit 3 of SRCON0) to "1" (receive enable).

 B After 3 to 4 BRTC clock cycles later the receive shift clock (RXCO) is generated, and the receive operation starts.

(The shift clock is supplied from the P3.2/RXC pin.)

- © At the positive edge of RXCO the data received from the P3.0/RXD pin is written to the receive register.
- ① Receive operation ends.

If an overrun error occurs the OERR flag in status register (SSTAT) is set to "1".

E Received data is transferred to SRBUFL/H.

If a parity error occurs, the PERR flag of status register (SSTAT) is set to "1".

<sup>(E)</sup> The serial port receive interrupt request signal (SRINT) is generated.

<sup>(G)</sup> At the negative edge of SRINT, SREN is reset to "0".

Repeat step A the required number of times. In the synchronous internal clock mode the receive baud rate is fixed to TBCCLK.

9



(3) Synchronous external clock mode

The synchronous external clock mode is selected by setting SRMOD (bit 0 of SRCON0) to "1" and SRCLK (bit 0 of SRCON1) to "0".

Figure 9-10 is the receive timing chart for the synchronous external clock mode.

The synchronous external clock receive procedure is indicated below.

First set the receive format (data bit length, parity bit, etc.) in SRCON1 and SRCON0.

Set SREN (bit 3 of SRCON0) to "1" (receive enable).

B At the positive edge of the receive shift clock input through P3.2/RXC pin, the receive data from P3.0/RXD pin is written to the receive register.

© Receive operation ends.

If an overrun error occurs the OERR flag in status register (SSTAT) is set to "1".

D Received data is transferred to SRBUFL/H.

If a parity error occurs, the PERR flag of status register (SSTAT) is set to "1".

© The serial port receive interrupt request signal (SRINT) is generated.

(E) At the negative edge of SRINT, SREN is reset to "0".

Repeat step (A) the required number of times.

In the synchronous external clock mode the receive baud rate is determined by the external clock (RXCI). Allow at least five clocks of TBCCLK between the time the receive is enabled (SREN = "1") and the time the external clock (RXCI) is input.



#### 9.5 Send/Receive Data LSB/MSB First Select

Either LSB first or MSB first for send can be selected by setting STLMB (bit 3 of STCON1). Either LSB first or MSB first for receive can be selected by setting SRLMB (bit 3 of SRCON1).

#### 9.5.1 Selecting Send Data LSB/MSB First

Set STLMB (bit 3 of STCON1) to "0" to select LSB first for send.

The correspondence between LSB first send data and the send buffer register bit is shown in Figure 9-11. In this case, the LSB is TB0 (bit 0 of STBUFL)

Set STLMB to "1" to send the MSB first.

The correspondence between MSB first send data and the send buffer register bit is shown in Figure 9-12. In this case, the MSB is TB7 (bit 3 of STBUFH).



#### Figure 9-11 Correspondence Between LSB First Send Data and Send Buffer Register

| [Send data length] | Send dire | (Send | l first) |     |     |     |     |     |        |
|--------------------|-----------|-------|----------|-----|-----|-----|-----|-----|--------|
|                    | 8         | 7     | 6        | 5   | 4   | 3   | 2   | 1   | ↓<br>1 |
| 8 bits             | TB0       | TB1   | TB2      | TB3 | TB4 | TB5 | TB6 | TB7 |        |
|                    |           | 7     | 6        | 5   | 4   | 3   | 2   | 1   |        |
| 7 bits             |           | TB1   | TB2      | TB3 | TB4 | TB5 | TB6 | TB7 |        |
|                    |           |       | 6        | 5   | 4   | 3   | 2   | 1   |        |
| 6 bits             |           |       | TB2      | TB3 | TB4 | TB5 | TB6 | TB7 |        |
|                    |           |       |          | 5   | 4   | 3   | 2   | 1   |        |
| 5 bits             |           |       |          | TB3 | TB4 | TB5 | TB6 | TB7 |        |



#### 9.5.2 Selecting Receive Data LSB/MSB First

When the LSB is first in receive data, set SRLMB (bit 3 of SRCON1) to "0".

If the MSB is first, set SRLMB to "1".

The correspondence between receive data and SRBUFL/H bits for LSB first receive is shown in Figure 9-13, and for MSB first receive in Figure 9-14.



#### Figure 9-13 Correspondence Between LSB First Receive Data and Receive Buffer Register



#### Figure 9-14 Correspondence Between MSB First Receive Data and Receive Buffer Register

## Chapter 10

# Melody Driver (MELODY)

10

### Chapter 10 Melody Driver (MELODY)

#### 10.1 Overview

The ML63512A and ML63514A contain an internal melody circuit and buzzer circuit.

While automatically reading melody data in ROM (program memory) as specified by an MSA instruction, the melody circuit outputs a melody signal via the MD pin.

The melody circuit can select 29 different tones, 63 different tone lengths, and 15 different tempos.

The buzzer circuit has four different buzzer output modes at a frequency of 4 kHz. The buzzer driver signal is output via the MD pin.

Melody output is a higher priority operation than buzzer output.

#### 10.2 Melody Driver Configuration

The melody driver configuration is shown in Figure 10-1.





10-1

#### **10.3 Melody Driver Registers**

(1) Tempo Register (TEMPO)

TEMPO is a 4-bit special function register (SFR) that sets the tempo of the melody driver.

|       |         |       | _          | bit 3             | bit 2 | bit 1 | bit 0 |
|-------|---------|-------|------------|-------------------|-------|-------|-------|
|       | TI      | EMP   | 0 (096H)   | TMP3              | TMP2  | TMP1  | TMP0  |
|       |         |       | (R/W) L    |                   |       |       |       |
| Meloc | ly tem  | po se | elect      |                   |       |       |       |
| bit 3 | bit 2 I | bit 1 | bit 0      |                   |       |       |       |
| 0     | 0       | 0     | 0 : 🖌 = 48 | 0 (initial value) |       |       |       |
| 0     | 0       |       | 1 : 🚽 = 48 |                   |       |       |       |
| 0     | 0       |       | 0 : 🚽 = 32 |                   |       |       |       |
| 0     | 0       |       | 1 : 🚽 = 24 |                   |       |       |       |
| 0     | 1       | 0     | 0 : 🚽 = 19 |                   |       |       |       |
| 0     | 1       | 0     | 1 : 🚽 = 16 |                   |       |       |       |
| 0     | 1       | 1     | 0 : 🖌 = 13 |                   |       |       |       |
| 0     | 1       |       | 1 : 🚽 = 12 |                   |       |       |       |
| 1     | 0       | 0     | 0 : 🖌 = 10 |                   |       |       |       |
|       | 0       |       | 1 : 🚽 = 96 |                   |       |       |       |
|       | 0       | 1     | 0 : 🚽 = 87 |                   |       |       |       |
|       | 0       | 1     | 1: = 80    |                   |       |       |       |
|       | 1       | 0     | 0: = 74    |                   |       |       |       |
|       | 1       |       | 1: = 69    |                   |       |       |       |
|       | 1       | 1     | 0: J = 64  |                   |       |       |       |
|       | 1       | 1     | 1 : 🚽 = 60 |                   |       |       |       |

#### (2) Melody Driver Control Register (MDCON)

MDCON is a 4-bit special function register (SFR) that controls output of the melody driver.



#### bit 3: MSF

This flag indicates the melody output status.

When an MSA instruction starts the melody, MSF is set to "1". After output of the last melody data (END bit is "1"), MSF is cleared to "0".

Setting MSF to "0" during melody output will forcibly stop the melody output. Once melody output is forcibly stopped, the melody output cannot be restarted from the address where it is stopped.

At system reset, MSF is cleared to "0".



When stopping melody output forcibly by setting MSF (Bit 3 of MDCON) to "0", it is required to set the stop address on the ROM table to the end-data address (8000H). Set MSF to "0" after writing the melody end data that consists of two words of melody (silence with the END bit set to "1") data. If these are not described in programming, melody output may not be stopped even if MSF is set to "0". Example programming is shown below.

;\*Program part\*\*\*\*\*\*\*\*\*

| DI                       | ; 0. Disable master interrupt.                    |
|--------------------------|---------------------------------------------------|
| MSA MDSTOP_DATA          | ; 1. Write melody end data to the melody circuit. |
| MOV A,#0                 | ; 2. Set the MSF flag to "0".                     |
| MOV MDCON,A              | . ,                                               |
| MOV A,#1101b             | ; 3. Clear melody interrupt request (QMD).        |
| AND IRQ0,A               | •                                                 |
| EI                       | ; 4. Enable master interrupt (MIE).               |
| *ROM table data part**** |                                                   |
|                          |                                                   |

;\*Provide two words of melody data so that a melody will always be terminated even if a melody ;\*request is issued twice.

| MDSTO    | P_DATA: |                  |
|----------|---------|------------------|
| DW       | 8000H   | ; Silence data 1 |
| DW       | 8000H   | ; Silence data 2 |
| .******* | *****   |                  |

The Development Support System (Dr.63514 Emulator) differs from the IC in actual operation: In the Dr.63514 Emulator, melody output will be stopped only by setting MSF to "0"; writing melody end data is not needed.

#### bit 2: EMBD

This bit turns the buzzer output ON or OFF.

At system reset, EMBD is cleared to "0" and buzzer output is turned OFF.

In the single tone output mode, setting EMBD to "1" turns ON the buzzer output. After the second falling edge of the 32 Hz output, EMBD is cleared to "0" and buzzer output is turned OFF.

If melody output is started during buzzer output, EMBD is cleared to "0" and the buzzer output is turned OFF.

bit 1, 0: MBM1, MBM0
These bits select the buzzer output mode.
Output of two types of intermittent tones, a single tone or a continuous tone can be selected.
At system reset, MBM1 and MBM0 are cleared to "0", selecting output of intermittent tone 1.

| Buzzer output mode  | Waveform                                                                                                                                              |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intermittent tone 1 | Intermittent tone waveform synchronized to 8 Hz output of time base counter                                                                           |
| Intermittent tone 2 | Intermittent tone waveform synchronized to the logical<br>AND of 8 Hz signal output and a "L" level of 1 Hz<br>signal output of the time base counter |
| Single tone         | Single tone waveform beginning when EMBD is set<br>to "1" until second falling edge of 32 Hz output of time<br>base counter                           |
| Continuous tone     | Continuous tone waveform that is constant while EMBD is "1"                                                                                           |

Figure 10-2 shows the output waveforms of the melody driver output pins.



#### Figure 10-2 Output Waveforms of Melody Driver Output Pins

#### 10.4 Melody Circuit Operation

After the melody tempo is set in the tempo register (TEMPO), execution of an MSA instruction will start operation of the melody circuit.

The melody circuit outputs melody data while automatically reading melody data in ROM (program memory) as specified by an MSA instruction. When the last melody data is read (END bit is "1"), the melody circuit generates a melody end interrupt request. At this time, if an MSA instruction is executed, after the last melody data is output, melody output will continue from the melody data specified by the MSA instruction. If an MSA instruction is not executed, the melody output will stop after the last melody data is output.

MSF (bit 3 of MDCON) is a flag indicating the melody output status. When MSF is "1", the melody is being output, and when "0", the melody is stopped. Melody output can be stopped forcibly by setting MSF to "0" during melody output. To enable this operation, describe a program in accordance with the Note items on page 10-3. Once melody output is forcibly stopped, the melody output cannot be restarted from the address where it is stopped.

#### 10.4.1 Tempo Data

Tempo data defines the basic tone length. Tempo data is set in the tempo register (TEMPO). The tempos (number of counts per minute) set by TEMPO are shown in Table 10-1.

|       |     |       |     |     | (Low-speed clock = 32.768 kHz) |
|-------|-----|-------|-----|-----|--------------------------------|
|       |     | TEMPO |     |     | Tampa                          |
| TP3-0 | TP3 | TP2   | TP1 | TP0 | Tempo                          |
| 0H    | 0   | 0     | 0   | 0   | = 480                          |
| 1H    | 0   | 0     | 0   | 1   | = 480                          |
| 2H    | 0   | 0     | 1   | 0   | = 320                          |
| 3H    | 0   | 0     | 1   | 1   | = 240                          |
| 4H    | 0   | 1     | 0   | 0   | = 192                          |
| 5H    | 0   | 1     | 0   | 1   | = 160                          |
| 6H    | 0   | 1     | 1   | 0   | = 137                          |
| 7H    | 0   | 1     | 1   | 1   | = 120                          |
| 8H    | 1   | 0     | 0   | 0   | ⊨ 107                          |
| 9H    | 1   | 0     | 0   | 1   | = 96                           |
| AH    | 1   | 0     | 1   | 0   | = 87                           |
| BH    | 1   | 0     | 1   | 1   | = 80                           |
| СН    | 1   | 1     | 0   | 0   | = 74                           |
| DH    | 1   | 1     | 0   | 1   | = 69                           |
| EH    | 1   | 1     | 1   | 0   | = 64                           |
| FH    | 1   | 1     | 1   | 1   | = 60                           |

#### Table 10-1 Melody Tempo

#### 10.4.2 Melody Data

Melody data is 14-bit format data in the program ROM defining tone, tone length and end tone. The melody data format is indicated in Figure 10-3.

| bit 15  | bit 14 | bit 13 | bit 12 | bit 11 | bit 10               | bit 9 | bit 8   | bit 7 | bit 6 | bit 5 | bit 4 | bit 3   | bit 2 | bit 1 | bit 0 |
|---------|--------|--------|--------|--------|----------------------|-------|---------|-------|-------|-------|-------|---------|-------|-------|-------|
| END     | *      | L5     | L4     | L3     | L2                   | L1    | L0      | *     | N6    | N5    | N4    | N3      | N2    | N1    | NO    |
| End bit | t      | * Bits |        |        | gth coc<br>/ be eith |       | or "1". |       | L     |       | 1     | Tone co | de    | 1     |       |

Figure 10-3 Melody Data Format

(1) Tone code

The tone code is set in bits 6 through 0 of the melody data. The frequencies that can be output by the melody circuit are defined as:

 $\frac{2 \text{ TBCCLK}}{(N+2)}$ Hz (where N is an integer from 4 to 127, TBCCLK is Low-speed clock frequency)

The relation between N and tone code bits is:

 $\mathsf{N} = 2^6\mathsf{N}6 + 2^5\mathsf{N}5 + 2^4\mathsf{N}4 + 2^3\mathsf{N}3 + 2^2\mathsf{N}2 + 2^1\mathsf{N}1 + 2^0\mathsf{N}0$ 

If N6 through N2 are all set to "0", there is no melody output for the time specified by the tone length code. Values for N1 and N0 are irrelevant.

Table 10-2 indicates the relations between tones and tone codes.

| Table 10-2 | Tone and | Tone | Code | Correspondence |
|------------|----------|------|------|----------------|
|------------|----------|------|------|----------------|

|                  |           |    |    |    |         | (  | Low-speed | clock = 3 | 2.768 kHz) |
|------------------|-----------|----|----|----|---------|----|-----------|-----------|------------|
| Topo             | Frequency |    |    |    | Tone co | de |           |           |            |
| Tone             | (Hz)      | N6 | N5 | N4 | N3      | N2 | N1        | NO        | N6-N0      |
| C1               | 529       | 1  | 1  | 1  | 1       | 0  | 1         | 1         | 7BH        |
| Cis <sup>1</sup> | 560       | 1  | 1  | 1  | 0       | 0  | 1         | 1         | 73H        |
| D <sup>1</sup>   | 590       | 1  | 1  | 0  | 1       | 1  | 0         | 1         | 6DH        |
| Dis <sup>1</sup> | 624       | 1  | 1  | 0  | 0       | 1  | 1         | 1         | 67H        |
| E1               | 662       | 1  | 1  | 0  | 0       | 0  | 0         | 1         | 61H        |
| F <sup>1</sup>   | 705       | 1  | 0  | 1  | 1       | 0  | 1         | 1         | 5BH        |
| Fis <sup>1</sup> | 745       | 1  | 0  | 1  | 0       | 1  | 1         | 0         | 56H        |
| G1               | 790       | 1  | 0  | 1  | 0       | 0  | 0         | 1         | 51H        |
| Gis <sup>1</sup> | 840       | 1  | 0  | 0  | 1       | 1  | 0         | 0         | 4CH        |
| A <sup>1</sup>   | 886       | 1  | 0  | 0  | 1       | 0  | 0         | 0         | 48H        |
| Ais <sup>1</sup> | 936       | 1  | 0  | 0  | 0       | 1  | 0         | 0         | 44H        |
| B1               | 993       | 1  | 0  | 0  | 0       | 0  | 0         | 0         | 40H        |
| C <sup>2</sup>   | 1057      | 0  | 1  | 1  | 1       | 1  | 0         | 0         | 3CH        |
| Cis <sup>2</sup> | 1111      | 0  | 1  | 1  | 1       | 0  | 0         | 1         | 39H        |
| D <sup>2</sup>   | 1192      | 0  | 1  | 1  | 0       | 1  | 0         | 1         | 35H        |

| _                | Frequency |    |    |       | Tone co |    |    |    | 2.7 00 ((12) |
|------------------|-----------|----|----|-------|---------|----|----|----|--------------|
| Tone             | (Hz)      | N6 | N5 | N4 N3 |         | N2 | N1 | NO | N6-N0        |
| Dis <sup>2</sup> | 1260      | 0  | 1  | 1     | 0       | 0  | 1  | 0  | 32H          |
| E <sup>2</sup>   | 1338      | 0  | 1  | 0     | 1       | 1  | 1  | 1  | 2FH          |
| F <sup>2</sup>   | 1394      | 0  | 1  | 0     | 1       | 1  | 0  | 1  | 2DH          |
| Fis <sup>2</sup> | 1490      | 0  | 1  | 0     | 1       | 0  | 1  | 0  | 2AH          |
| G <sup>2</sup>   | 1560      | 0  | 1  | 0     | 1       | 0  | 0  | 0  | 28H          |
| Gis <sup>2</sup> | 1680      | 0  | 1  | 0     | 0       | 1  | 0  | 1  | 25H          |
| A <sup>2</sup>   | 1771      | 0  | 1  | 0     | 0       | 0  | 1  | 1  | 23H          |
| Ais <sup>2</sup> | 1872      | 0  | 1  | 0     | 0       | 0  | 0  | 1  | 21H          |
| B <sup>2</sup>   | 1986      | 0  | 0  | 1     | 1       | 1  | 1  | 1  | 1FH          |
| C <sup>3</sup>   | 2114      | 0  | 0  | 1     | 1       | 1  | 0  | 1  | 1DH          |
| D <sup>3</sup>   | 2341      | 0  | 0  | 1     | 1       | 0  | 1  | 0  | 1AH          |
| Dis <sup>3</sup> | 2521      | 0  | 0  | 1     | 1       | 0  | 0  | 0  | 18H          |
| E <sup>3</sup>   | 2621      | 0  | 0  | 1     | 0       | 1  | 1  | 1  | 17H          |
| Fis <sup>3</sup> | 2979      | 0  | 0  | 1     | 0       | 1  | 0  | 0  | 14H          |

#### Table 10-2 Tone and Tone Code Correspondence (continued)

(Low-speed clock = 32.768 kHz)

(2) Tone length code

The tone length code is set in melody data bits 13 through 8. Table 10-3 indicates the relation between tone length and tone length code (L5 to L0). The tone length that is set during execution of the MSA instruction is shorter by approximately 1 to 3 ms. When all bits are "0", the tone length is the minimum tone length (the same as setting only L0 to "1").

| Tone   | Tone length code |    |    |    |    |    |      |  |  |  |  |  |  |
|--------|------------------|----|----|----|----|----|------|--|--|--|--|--|--|
| length | L5               | L4 | L3 | L2 | L1 | LO | L5–0 |  |  |  |  |  |  |
| 0      | 1                | 1  | 1  | 1  | 1  | 1  | 3FH  |  |  |  |  |  |  |
|        | 1                | 0  | 1  | 1  | 1  | 1  | 2FH  |  |  |  |  |  |  |
|        | 0                | 1  | 1  | 1  | 1  | 1  | 1FH  |  |  |  |  |  |  |
| ,      | 0                | 1  | 0  | 1  | 1  | 1  | 17H  |  |  |  |  |  |  |
|        | 0                | 0  | 1  | 1  | 1  | 1  | 0FH  |  |  |  |  |  |  |
| Ŕ      | 0                | 0  | 1  | 0  | 1  | 1  | OBH  |  |  |  |  |  |  |
| R      | 0                | 0  | 0  | 1  | 1  | 1  | 07H  |  |  |  |  |  |  |
| Ŕ      | 0                | 0  | 0  | 1  | 0  | 1  | 05H  |  |  |  |  |  |  |
|        | 0                | 0  | 0  | 0  | 1  | 1  | 03H  |  |  |  |  |  |  |
|        | 0                | 0  | 0  | 0  | 1  | 0  | 02H  |  |  |  |  |  |  |
|        | 0                | 0  | 0  | 0  | 0  | 1  | 01H  |  |  |  |  |  |  |

#### Table 10-3 Tone Length and Tone Length Code Correspondence

Tone lengths specified by the tone length code and the tempo data are expressed by the following:

 $\frac{64}{\text{TBCCLK}}$  × (TP+1) × (L+1) ms (where TP is an integer from 1 to 15, and L is an integer from 1 to 63)

TP is a value set in the tempo register (TEMPO), and has the following bit correspondence:

 $TP = 2^{3}TP3 + 2^{2}TP2 + 2^{1}TP1 + 2^{0}TP0$ 

L is set by the tone length code, and has a bit correspondence with the tone length code as:

 $L = 2^{5}L5 + 2^{4}L4 + 2^{3}L3 + 2^{2}L2 + 2^{1}L1 + 2^{0}L0$ 

#### (3) END bit

The END bit is set in bit 15 of the melody data. When the output of the last melody data is started (END bit is "1"), the melody circuit generates a melody end interrupt request, and stops the melody after the last melody data is output.

#### 10.4.3 Melody Circuit Application Example

An example melody is shown in Figure 10-4.

Table 10-4 lists the note codes for the melody shown in Figure 10-4.



Figure 10-4 Example Melody

|                         |     |    |    |    |    |    |    | Note | code |    |    |    |    |    |    |    |       |
|-------------------------|-----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|-------|
| Note                    | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |       |
|                         | END | *  | L5 | L4 | L3 | L2 | L1 | L0   | _*   | N6 | N5 | N4 | N3 | N2 | N1 | NO | Hex   |
| <b>.</b> G <sup>2</sup> | 0   | 0  | 1  | 0  | 1  | 1  | 1  | 1    | 0    | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 2F28H |
|                         | 0   | 0  | 0  | 0  | 1  | 1  | 1  | 1    | 0    | 0  | 1  | 1  | 0  | 1  | 0  | 1  | 0F35H |
| G2                      | 0   | 0  | 0  | 0  | 1  | 1  | 1  | 1    | 0    | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0F28H |
|                         | 0   | 0  | 0  | 0  | 0  | 1  | 1  | 1    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0700H |
|                         | 0   | 0  | 0  | 0  | 0  | 1  | 1  | 1    | 0    | 0  | 1  | 1  | 0  | 1  | 0  | 1  | 0735H |
| G <sup>2</sup>          | 0   | 0  | 0  | 0  | 1  | 1  | 1  | 1    | 0    | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0F28H |
|                         | 0   | 0  | 0  | 0  | 0  | 1  | 1  | 1    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0700H |
| A <sup>2</sup>          | 0   | 0  | 0  | 0  | 0  | 1  | 1  | 1    | 0    | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0723H |
| P B <sup>2</sup>        | 0   | 0  | 1  | 1  | 1  | 1  | 1  | 1    | 0    | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 3F1FH |
| G <sup>2</sup>          | 1   | 0  | 1  | 1  | 1  | 1  | 1  | 1    | 0    | 0  | 1  | 0  | 1  | 0  | 0  | 0  | BF28H |

#### Table 10-4 Note Code Table

\* Bits 14 and 7 may be "0" or "1", but in this example they are shown as "0".

#### 10.5 Buzzer Circuit Operation

When EMBD (bit 2 of MDCON) is set to "1", a buzzer driver signal is sent to the melody driver output pin (MD).

Four buzzer output modes can be selected by MBM1 (bit 1 of MDCON) and MBM0 (bit 0 of MDCON): two types of intermittent tones, a single tone, or a continuous tone output. The buzzer output frequency is 1/8 TBCCLK (4 kHz @ 32.768 kHz) and has a 50% duty ratio.

In the intermittent tone 1 mode, a waveform synchronized to the 1/4096 TBCCLK (8 Hz @ 32.768 kHz) output of the time base counter is output.

In the intermittent tone 2 mode, a waveform synchronized to the logical AND of 1/4096 TBCCLK (8 Hz @ 32.768 kHz) signal output and a "L" level of 1/32768 TBCCLK (1 Hz @ 32.768 kHz) signal of the time base counter is output.

In the single tone mode, output starts in synchronization with the rising edge of EMBD. At the second falling edge of the 1/1024 TBCCLK (32 Hz @ 32.768 kHz) output of the time base counter, EMBD is cleared to "0" and output is stopped.

In the continuous tone mode, output is continued while EMBD is "1".

While the melody is being output (MSF (bit 3 of MDCON) = "1"), the buzzer output is turned OFF. If melody output is started during buzzer output, EMBD is cleared to "0", the buzzer output is stopped, and melody output is given priority.

Figure 10-5 shows the output waveforms of each mode. Shaded sections indicate the 1/8 TBCCLK (4 kHz @ 32.768 kHz) output frequency.



Figure 10-5 Buzzer Driver Output Waveforms in Each Output Mode (Low-speed clock = 32.768 kHz)

## Chapter 11

11

# Level Detector

11

### Chapter 11 Level Detector

#### 11.1 Overview

The ML63512A and ML63514A have one built-in level detector circuit that converts the input voltage into a level in one of 12 stages.

The voltage applied to the input pin is compared with 12 reference voltages in the level detector, and the value in the range of 0 to 11 corresponding to the matching reference voltage is converted into a 4-bit code and output to the register LDOUT (level detector output register).

The measurable voltage range is the power supply voltage range (between  $V_{\text{DD}}$  and  $V_{\text{SS}}$ ) as indicated below.

Major Features:

Input voltage range: V<sub>DD</sub> to V<sub>SS</sub>

Conversion time: approx. 183 µs (@ 32.768 kHz)

#### **11.2 Level Detector Configuration**

The level detector consists of the input detecting section and the voltage comparing section. The level detector configuration is shown in Figure 11-1.



Figure 11-1 Level Detector Configuration

11

#### 11.3 Level Detector Registers

The following three registers are used for controlling the level detector.

- Level detector control register (LDCON)
- Level detector output register (LDOUT)
- Level detector operation register (LDSET)

Explanation of each register follows.

(1) Level detector control register (LDCON)

LDCON is a 4-bit special function register (SFR) that controls the starting and stopping of level detector operation. This register is reset to "0H" at the time of a system reset.

The following controls can be carried out using LDCON.

- It is possible to stop both the input level detecting section and the voltage comparing section when the level detector is not being used. This prevents unnecessary increase in supply current.
- It is possible to select bit 2 (P7.2/LDIN0) or bit 3 (P7.3/LDIN1) of Port 7 as the level input pin.

|                                                                                            | bit 3         | bit 2  | bit 1  | bit 0 |  |  |  |
|--------------------------------------------------------------------------------------------|---------------|--------|--------|-------|--|--|--|
| LDCON (04AH)<br>(R/W)                                                                      | LDSTART       | LDSAMP | LDPCHG | LDON  |  |  |  |
|                                                                                            |               |        |        |       |  |  |  |
| Voltage comparing section start flag<br>0: When stopped or the OFF level is in             |               |        |        |       |  |  |  |
| 1: When the ON level is input                                                              |               | /      |        |       |  |  |  |
|                                                                                            |               |        |        |       |  |  |  |
| Input level detection timing selection flag<br>0: Normally detect (initial value)          |               |        |        |       |  |  |  |
| 1: Detect at every 1/512 TBC (64 Hz @                                                      | 2 32.768 kHz) |        |        |       |  |  |  |
|                                                                                            |               |        |        |       |  |  |  |
| Input pin selection flag                                                                   | nction)       |        |        |       |  |  |  |
| 0: LDIN0 (input of P7.2 secondary function)<br>1: LDIN1 (input of P7.3 secondary function) |               |        |        |       |  |  |  |
|                                                                                            | ,             |        |        |       |  |  |  |
| Level detector activation flag                                                             |               |        |        |       |  |  |  |
| 0: Stop (initial value)<br>1: Start operation                                              |               |        |        |       |  |  |  |
|                                                                                            |               |        |        |       |  |  |  |

bit 3: LDSTART (Level Detector START)

This bit becomes "1" when an ON level is input to the selected level detector input pin if the input level detecting section of the level detector is operating, and becomes "0" when an OFF level is input. This LDSTART flag can be used by the user program as a status flag for sensing the start of operation of the voltage comparing section. This is a read-only flag.

#### bit 2: LDSAMP (Level Detector SAMPling clock)

This is the bit for selecting the sampling mode of the level detector input level detecting section. When LDSAMP is set to "1", the sampling mode will be the 1/ 512 TBC sampling mode in which the input level detection is made at every 512 time base clocks (64 Hz @ 32.768 kHz). When LDSAMP is set to "0", the input level detecting section enters the constant sampling mode.

#### bit 1: LDPCHG (Level Detector Port CHanGe)

This is the bit for selecting the input pin for the level detector. When LDPCHG is set to "0", bit 2 of the input port 7 (P7.2) is selected as the secondary function. When LDPCHG is set to "1", bit 3 of the input port 7 (P7.3) is selected as the secondary function.

#### bit 0: LDON (Level Detector ON)

This bit starts and stops the level detector operation. The level detector starts the operation when this bit is set to "1" and stops the operation when "0".

(2) Level detector output register (LDOUT)

This is a read-only special function register (SFR) used for storing the 4-bit code of the comparison result that corresponds to the input level. This register is initialized to "0FH" at the time of a system reset.



(3) Level detector operation register (LDSET)

LDSET is a register that writes the 4-bit code corresponding to the input level in LDOUT. The voltage comparison is started when the write instruction is executed when LDON is "1".

The value "0FH" is read out when a read instruction is executed.



#### 11.3.1 Input Levels and Output Codes

The level detector input levels and the corresponding LDOUT outputs are shown in Table 11.1.

#### Table 11-1 Input Levels and Output Codes

(V<sub>DD</sub> = 0.9 to 1.8 V: When backup is used, V<sub>DD</sub> = 1.8 to 3.5 V: When backup is not used ; V<sub>SS</sub> = 0 V, Ta = -20 to  $+70^{\circ}$ C)

| Input level [V]           |                          | Level detector  |       | LDOUT |       |       |  |
|---------------------------|--------------------------|-----------------|-------|-------|-------|-------|--|
| Min.                      | Max.                     | operation state | bit 3 | bit 2 | bit 1 | bit 0 |  |
| $1440/1500\times V_{DD}$  | V <sub>DD</sub>          | OFF state       | 1     | 1     | 1     | 1     |  |
| $1306/1500\times V_{DD}$  | $1366/1500\times V_{DD}$ | ON state        | 1     | 0     | 1     | 1     |  |
| $1190/1500\times V_{DD}$  | $1250/1500\times V_{DD}$ |                 | 1     | 0     | 1     | 0     |  |
| $1074/1500 \times V_{DD}$ | $1134/1500\times V_{DD}$ |                 | 1     | 0     | 0     | 1     |  |
| $958/1500\times V_{DD}$   | $1018/1500\times V_{DD}$ |                 | 1     | 0     | 0     | 0     |  |
| $842/1500 \times V_{DD}$  | $902/1500 \times V_{DD}$ |                 | 0     | 1     | 1     | 1     |  |
| $726/1500 \times V_{DD}$  | $786/1500 \times V_{DD}$ |                 | 0     | 1     | 1     | 0     |  |
| $610/1500 \times V_{DD}$  | $670/1500 \times V_{DD}$ |                 | 0     | 1     | 0     | 1     |  |
| $494/1500 \times V_{DD}$  | $554/1500 \times V_{DD}$ |                 | 0     | 1     | 0     | 0     |  |
| $378/1500 \times V_{DD}$  | $438/1500\times V_{DD}$  |                 | 0     | 0     | 1     | 1     |  |
| $262/1500 \times V_{DD}$  | $322/1500 \times V_{DD}$ |                 | 0     | 0     | 1     | 0     |  |
| $146/1500 \times V_{DD}$  | $206/1500 \times V_{DD}$ |                 | 0     | 0     | 0     | 1     |  |
| V <sub>SS</sub>           | $88/1500 \times V_{DD}$  |                 | 0     | 0     | 0     | 0     |  |

#### 11.4 Level Detector Operation

(1) Stopping the level detector (initial state after a system reset)

The level detector stops the operation and goes into the following statuses when LDON (bit 0 of LDCON) is set to "0".

- 1. The input level detecting section stops its operations.
- 2. LDSTART becomes "0". This isolates the ladder resistor generating the reference voltage in the voltage comparing section.
- 3. If LDOUT is read at this time, the value will be "0FH".

Also, if the input level is the OFF level immediately after starting the sampling in the input level detecting section, the operation of the voltage comparing section is stopped and the contents of LDOUT will be set forcibly to "0FH".

(2) Operation of the input level detecting section

To start the operation of the input level detecting section, set LDON (bit 0 of LDCON) to "1" after setting the input port (P7.2 or P7.3) and setting the sampling mode.

Setting the input port
 In order to use the level detector, specify the level detector analog input pin
 function by enabling the secondary function (LDIN0 or LDIN1) of bit 2 or bit 3 of
 port 7.

 In addition, set the selected port (P7 2 or P7 3) as a high impedance input

In addition, set the selected port (P7.2 or P7.3) as a high impedance input.

- Setting the sampling mode
- When LDSAMP = "0": Constant sampling mode When LDSAMP is set to "0", the input level detecting section goes into the constant sampling mode in which the sampling is constantly performed at a fixed rate (183 μs only during the first time and 214 μs during the second and subsequent samplings).
- When LDSAMP = "1": 1/512 TBC sampling mode When LDSAMP is set to "1", the input level detecting section starts sampling the level of the voltage input to the input pin in synchronization with the 1/512 TBC signal. (This becomes a 64 Hz sampling operation when the clock frequency is 32.768 kHz.)
- Starting the sampling The operation of the input level detecting section starts when LDON is set to "1".

Note:

Since all the three flags LDSAMP, LDPCHG, and LDON are present in the same register, care should be taken during programming.

When manipulating these flags individually using the set bit instruction or the reset bit instruction, always make sure to set the LDSAMP and LDPCHG first before setting LDON. In some cases, an OR instruction is used to set them at one time.

The input level detecting section carries out the operations a or b given below depending on the input level.

- a. When the input level is the OFF level: The operation of the voltage comparing section is stopped.
  - 1. LDSTART (bit 3 of LDCON) becomes "0".
  - 2. The ladder resistor generating the reference voltage in the voltage comparing section is isolated.
  - 3. The value "0FH" is read when the LDOUT register is read at this time.
- b. When the input level is the ON level: The voltage comparing section is operating.
  - 1. An interrupt request is generated when LDSTART becomes "1".
  - 2. The ladder resistor generating the reference voltage in the voltage comparing section is connected.
  - 3. The voltage comparing section goes into the standby state. However, the level detector does not output the detected value to LDOUT unless a write instruction (MOV instruction) is executed for LDSET. Therefore, the correct value cannot be read even if LDOUT is read unless a write instruction is executed first.

The operation timings of the input level detecting section are shown in Figures 11-2 and 11-3.

11





I

Input level detecting section output store signal

11-9

- (3) Operation of the voltage comparing section
- When the input level detecting section carries out the operations described in paragraph (2) above and LDSTART (bit 3 of LDCON) becomes "1", the voltage comparing section goes into the standby state.
- In this condition, if a write instruction (MOV instruction) is executed for LDSET, the voltage input via the input level detecting section is compared with the reference voltage. This operation requires approx. 183 µs (when the low-speed clock frequency is 32.768 kHz).
- 3. When the comparison operation is completed, the voltage comparing section writes the value (0 to 0BH) corresponding to the matched reference voltage in the register LDOUT.
- 4. Next, the detection result can be obtained by reading the LDOUT register by the program.



In the above procedure, a waiting period of approx. 183  $\mu$ s is required between step 2 and step 3 (when the low-speed clock frequency is 32.768 kHz). Therefore, make an appropriate wait time setting by the program.

Figure 11-4 shows the operation timing of the voltage comparing section.



Figure 11-4 Voltage Comparing Section Operation Timing

11

#### (4) On programming

The level detector control program contains two wait time factors:

- 1. The time after LDON is set to "1" until the input level detecting section detects whether the input level is an ON level or an OFF level.
  - Constant sampling mode: First time = approx. 183 μs, second and subsequent times = approx. 214 μs
  - 1/512 TBC mode: approx. 183 μs
- 2. The time after writing the LDSET flag until the processing by the voltage comparing section is completed and the result is written to LDOUT.
  - approx. 183 μs

The sequence of operations of processing by the program is as follows.

- a. Based on the appropriate port setting and sampling mode setting, the operation of the input level detecting section is started.
- b. The timer processing described in item 1 above is made, and the program waits until the input level detecting section completes making the judgment of the input level.
- c. The check of whether or not LDSTART has been set to "1" is made. If LDSTART is "0", an OFF level input is judged to have been made and the processing is terminated.
- d. If LDSTART is "1", an instruction for writing the appropriate value in LDSET is executed, thereby starting the processing by the voltage comparing section.
- e. The timer processing described in item 2 above is made, and the program waits for the voltage comparing section operation to end.
- f. The detection result is obtained by reading LDOUT.

Note:

The following attention should be given to the timer operations in step b and step e above.

The level detector uses the low-speed clock TBCCLK as the basic operating clock. Irrespective of whether the system clock is a high-speed clock or a low-speed clock, the level detector operates at the low-speed clock TBCCLK. Therefore, care should be taken because the parameters such as the number of NOP operations or the loop count in software timer operations using multiple NOP operations or loop counting of instructions can be completely different depending on whether the system clock is a high-speed clock or a low-speed clock.

An example of a recommended program is shown below.

• When the system clock is a low-speed clock

| MOV A, #0001B<br>MOV LDCON, A<br>NOP<br>NOP<br>NOP | ; Select LDIN0. Make this value "0010B" when selecting LDIN1.<br>; Start input level detecting section operation.<br>; |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| MOV LDSET, A<br>NOP                                | ; Start input level detecting section operation.<br>; 61 $\mu$ s × 4 = 244 $\mu$ s                                     |
| NOP                                                | ,                                                                                                                      |
| NOP                                                | •                                                                                                                      |
| MOV A, LDOUT                                       | ,                                                                                                                      |

• When the system clock is a high-speed clock

| MOV A, #0001B | ; Select LDIN0. Make this value "0010B" when selecting LDIN1. |
|---------------|---------------------------------------------------------------|
| MOV LDCON, A  | ; Start input level detecting section operation.              |
| MOV A, #1000B |                                                               |

LEVEL\_INPUT\_00:

MTSTLDCON, A BNE LEVEL\_INPUT\_00 MOV LDSET, A ; Start input level detecting section operation. CAL WAIT\_183US ; 183 μs WAIT MOV A, LDOUT ;

\*\*\*\*\*\*\*\*\*\*\*

During a 1 MHz high-speed clock operation

1 MC = 2 μs

The time duration becomes longer than  $183\,\mu s$  if an interrupt input is made during this waiting period; however, it does not affect the input.

\*\*\*\*\*

WAIT\_183US:

MOV H, #0DH MOV L, #2H ; Use the register L as a counter.

WAIT\_183US\_1:

INCB HL BGT WAIT\_183US\_1; 2\*9 + 16\*2\*2 = 82 MC/2 μs\*82 = 164 μs RT

# Chapter 12

# Comparator (CMP)

12

## Chapter 12 Comparator (CMP)

#### 12.1 Overview

The ML63512A and ML63514A have one built-in comparator circuit. This comparator takes the input at the pin CMPREF (secondary function of P7.1) as the reference voltage and carries out voltage comparison of that voltage and the input voltage at the pin CMPIN (secondary function of P7.0), and stores the result of comparison in CMPOUT (bit 0 of CMPCON).

Major Features:

Input voltage range:  $V_{DD}$  to  $V_{SS}$ Offset voltage: 50 mV max. ( $V_{DD}$  = 1.5 V) Comparison time: approx. 183 µs (@ 32.768 kHz)

#### **12.2 Comparator Configuration**

The comparator configuration is shown in Figure 12-1.



Figure 12-1 Comparator Configuration

#### 12.3 Comparator Register

The following register is used for controlling the comparator.

(1) Comparator control register (CMPCON)

Explanation of this register follows.

#### (1) Comparator control register (CMPCON)

CMPCON is a 4-bit special function register (SFR) used for controlling the comparator and reading the result of comparison. This register is reset to "0EH" at the time of a system reset.



#### bit 0: CMPOUT (CoMPare data OUTput bit)

CMPOUT is the bit for reading the result of comparison.

The comparator starts the comparison operation when data is written to the CMPCON register.

#### 12.4 Comparator Operation

(1) Stopping the comparator

The comparator stops the comparison operation at the same time that it stores the result of comparison in CMPOUT.

(2) Starting the comparator and comparison operations

To start the comparator operation, make first the setting of the input port (P7.0 and P7.1) and then write to CMPCON.

- Setting the input port In order to use the comparator, specify the comparator analog input pin and the reference voltage input pin by enabling the secondary functions (CMPIN and CMPREF) of bit 0 and bit 1. In addition, set each of these ports (P7.0 and P7.1) as high impedance inputs.
- Writing to CMPCON (starting the comparator) When any value in the range of 0 to 0FH is written to the register CMPCON, the comparator starts the operation of comparing the voltages input at the CMPREF pin (secondary function of P7.1) and at the CMPIN pin (secondary function of P7.0).
- Comparison operation and storage of the result of comparison The result of comparison is stored automatically in the flag CMPOUT at the end of the comparison operation.

When CMPIN < CMPREF, CMPOUT will be "0".

When CMPIN > CMPREF, CMPOUT will be "1".

A time duration equal to 6 TBCCLK (approx. 183  $\mu s$  @ 32.768 kHz) will be required from starting the comparison operation until the comparison result is stored in CMPOUT.

Figure 12-2 shows the operation timing of the comparator.



Figure 12-2 Comparator Operation Timing



A waiting period of 6 TBCCLK (approx. 183  $\mu$ s @ 32.768 kHz) is required after executing a CMPCON register write operation before the comparison result is read from CMPOUT. Therefore, make an appropriate wait time setting by the program. If the wait time is not sufficient or if CMPOUT is read without writing to CMPCON, the previous comparison content of CMPOUT will be read.

The value of CMPOUT will be "0" when read for the first time after a system reset.

#### (3) On programming

The control program for the comparator contains the following wait time factor:

• Time taken from writing to CMPCON until the voltage comparison operation is completed and the comparison result is stored in CMPOUT:

6 TBCCLK (approx. 183 µs @ 32.768 kHz)

An example of a recommended program is shown below.

#### • When the system clock is a low-speed clock

|                | ; Comparator operation started                          |
|----------------|---------------------------------------------------------|
| NOP<br>NOP     | Comparator operation duration: approx. 183 μs           |
| MOV A, 0001B   |                                                         |
| MTST CMPCON, A | ; Verification of comparison result from the comparator |
| BNE xxx        | ; CMPOUT = 1 CMPIN > CMPREF                             |
|                | ; CMPOUT = 0 CMPIN < CMPREF                             |

• When the system clock is a high-speed clock

| MOV CMPCON, A             | ; Comparator operation started                                                                                        |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------|
|                           | Comparator operation duration: approx. 183 $\mu$ s                                                                    |
| MTST CMPCON, A<br>BNE xxx | ; Verification of comparison result from the comparator<br>; CMPOUT = 1 CMPIN > CMPREF<br>; CMPOUT = 0 CMPIN < CMPREF |

# Chapter 13

# Backup Circuit (BACKUP)

13

13

# Chapter 13 Backup Circuit (BACKUP)

#### 13.1 Overview

The ML63512A and ML63514A contain a voltage backup circuit that doubles the power supply voltage. The backup circuit is used when the power supply voltage is 1.8 V or less.

By operating the backup circuit, the CPU can be run even when the power supply voltage is 0.9 V.

The voltage boosted by the backup circuit is supplied as  $V_{\text{DDH}}$  to the constant voltage circuit and to the high-speed oscillation circuit.

The constant voltage circuit generates V<sub>DDL</sub> (voltage for internal logic).

Depending upon whether the backup circuit is ON or OFF, the following voltages are supplied to  $V_{DDH}$  (voltage supplied to the constant voltage circuit and high-speed oscillation circuit).

• When backup circuit is ON

Voltage that is doubled by the backup circuit

• When backup circuit is OFF

Power supply voltage

Power supply specifications are determined depending upon whether the backup circuit is used.

| When backup circuit is used     | • • • V <sub>DD</sub> = | 0.9 to 1.8 V                                              |
|---------------------------------|-------------------------|-----------------------------------------------------------|
| When backup circuit is not used | • • • V <sub>DD</sub> = | 1.8 to 3.5 V (When Level detector or Comparator is used.) |
|                                 | $V_{DD} =$              | 1.8 to 5.5 V (When Level detector and                     |

Comparator are not used.)

#### 13.2 Power Supply Circuit Configuration

#### 13.2.1 Power Supply Circuit Configuration When Backup Circuit is Used

Figure 13-1 shows the power supply circuit configuration when the backup circuit is used.

To use the backup circuit, connect a capacitor ( $C_{b12}$ ) between the CB1 and CB2 pins, or connect a capacitor ( $C_h$ ) between  $V_{DDH}$  and  $V_{SS}$ .

In addition, at the beginning of the program, set the backup select bit BACKUP (bit 0 of BUPCON) to "1". The backup select bit is described in a later section.



#### Figure 13-1 Power Supply Circuit Configuration When Backup Circuit is Used



- In systems that use the backup circuit, connect an external capacitor (C<sub>b12</sub>) between the CB1 and CB2 pins.
- The backup circuit cannot be switched ON/OFF once operation has begun. Design peripheral circuits such as external capacitor C<sub>b12</sub> to meet the ON/OFF specification of the backup circuit.

#### 13.2.2 Power Supply Circuit Configuration When Backup Circuit is Not Used

Figure 13-2 shows the power supply circuit configuration when the backup circuit is not used.

When the backup circuit is not used, leave pins CB1 and CB2 unconnected (open) and connect  $V_{\text{DDH}}$  to  $V_{\text{DD}}.$ 

In addition, at the beginning of the program, set the later described backup select bit (BACKUP) to "0". (At system reset BACKUP is "1".)

If BACKUP is "1", the backup circuit will operate and supply current will increase.



#### Figure 13-2 Power Supply Circuit Configuration When Backup Circuit is Not Used



 The backup circuit cannot be switched ON/OFF once operation has begun. Design peripheral circuits such as external capacitor C<sub>b12</sub> to meet the ON/OFF specification of the backup circuit. 13

#### 13.3 Backup Circuit Register

• Backup control register (BUPCON)

BUPCON is a 4-bit special function register (SFR) that sets the backup circuit ON or OFF.

|                                                               | bit 3 | bit 2 | bit 1 | bit 0  |
|---------------------------------------------------------------|-------|-------|-------|--------|
| BUPCON (095H)<br>(R/W)                                        | —     |       | _     | BACKUP |
| Backup release —                                              |       |       |       |        |
| 0: Backup circuit OFF<br>1: Backup circuit ON (initial value) |       |       |       |        |

bit 0: BACKUP

At system reset, BACKUP is set to "1" and the backup function is turned ON.

To release (turn OFF) the backup circuit, clear the BACKUP bit to "0" to stop the switching operation for boosting the voltage.

#### 13.4 Power Supply Circuit Operation

When the backup circuit is used, the V<sub>DDH</sub> output is forcibly switched to the V<sub>DD</sub> level while the time base counter is reset (RESET0 = "1"). Approximately 62.5 ms after system reset is released, the backup circuit is turned ON, and the V<sub>DDH</sub> output is boosted to twice the V<sub>DD</sub> level. When the backup circuit is turned OFF, the V<sub>DDH</sub> output immediately returns to the V<sub>DD</sub> level.

When the backup circuit is not used, externally connect the  $V_{DDH}$  output to the  $V_{DD}$  pin.

The V<sub>DDL</sub> output is forcibly switched to the V<sub>DD</sub> level while the time base counter is reset, and changes to approximately 1.5 V immediately after reset is released. If ENOSC (bit 1 of FCON) is set to "1", the V<sub>DDL</sub> output switches to the V<sub>DDH</sub> level. If ENOSC is cleared to "0", the V<sub>DDL</sub> output returns to approximately 1.5 V.



Figure 13-3 Power Supply Circuit Operation Waveforms (When a 32.768 kHz crystal is used for low-speed clock oscillation)



## Appendix A List of Special Function Registers

The Special Function Registers of the ML63512A and ML63514A are listed in Table A.

| Register name             | Symbol | Address            | bit 3  | bit 2  | bit 1  | bit 0  | R/W | Initial value<br>at system<br>reset |
|---------------------------|--------|--------------------|--------|--------|--------|--------|-----|-------------------------------------|
| Port 0 data register      | P0D    | 000H               | P03    | P02    | P01    | P00    | R   | Undefined                           |
| Port 1 data register      | P1D    | 001H               | P13    | P12    | P11    | P10    | R   | Undefined                           |
| Port 2 data register      | P2D    | 002H               | P23    | P22    | P21    | P20    | R/W | Undefined                           |
| Port 3 data register      | P3D    | 003H               | P33    | P32    | P31    | P30    | R/W | Undefined                           |
| Port 4 data register      | P4D    | 004H               | P43    | P42    | P41    | P40    | R/W | Undefined                           |
| Port 5 data register      | P5D    | 005H               | P53    | P52    | P51    | P50    | R/W | Undefined                           |
| Port 6 data register      | P6D    | 006H               | P63    | P62    | P61    | P60    | R/W | Undefined                           |
| Port 7 data register      | P7D    | 007H               | P73    | P72    | P71    | P70    | R   | Undefined                           |
| Port 8 data register      | P8D    | 008H               | P83    | P82    | P81    | P80    | R/W | 0FH                                 |
| Port 0 direction register | PODIR  | 009H               | P03DIR | P02DIR | P01DIR | P00DIR | R/W | 0H                                  |
| Port 1 direction register | P1DIR  | 00AH               | P13DIR | P12DIR | P11DIR | P10DIR | R/W | 0H                                  |
| Port 1 mode register      | P1M0D  | 00BH               | _      | _      | P11M0D | P10M0D | R/W | 0CH                                 |
| Port 2 direction register | P2DIR  | 00CH               | P23DIR | P22DIR | P21DIR | P20DIR | R/W | OH                                  |
| Port 2 mode register      | P2M0D  | 00DH               | _      | _      | P21M0D | P20M0D | R/W | 0CH                                 |
| Port 3 direction register | P3DIR  | 00EH               | P33DIR | P32DIR | P31DIR | P30DIR | R/W | 0H                                  |
| Port 3 mode register      | P3M0D  | 00FH               | P33M0D | P32MOD | P31M0D | P30M0D | R/W | 0H                                  |
| Port 4 direction register | P4DIR  | 010H               | P43DIR | P42DIR | P41DIR | P40DIR | R/W | 0H                                  |
| Port 5 direction register | P5DIR  | 011H               | P53DIR | P52DIR | P51DIR | P50DIR | R/W | 0H                                  |
| Port 6 direction register | P6DIR  | 012H               | P63DIR | P62DIR | P61DIR | P60DIR | R/W | 0H                                  |
| Port 0 control register   | POCON  | 013H               | P03CN  | P02CN  | P01CN  | POOCN  | R/W | 0H                                  |
| Port 1 control register   | P1CON  | 014H               | P13CN  | P12CN  | P11CN  | P10CN  | R/W | 0H                                  |
| Port 2 control register   | P2CON  | 015H               | P23CN  | P22CN  | P21CN  | P20CN  | R/W | 0H                                  |
| Port 3 control register   | P3CON  | 016H               | P33CN  | P32CN  | P31CN  | P30CN  | R/W | OH                                  |
| Port 4 control register   | P4CON  | 017H               | P43CN  | P42CN  | P41CN  | P40CN  | R/W | OH                                  |
| Port 5 control register   | P5CON  | 018H               | P53CN  | P52CN  | P51CN  | P50CN  | R/W | 0H                                  |
| Port 6 control register   | P6CON  | 019H               | P63CN  | P62CN  | P61CN  | P60CN  | R/W | 0H                                  |
| Port 7 control register   | P7CON  | 01AH               | P73CN  | P72CN  | P71CN  | P70CN  | R/W | 0H                                  |
| Reserved                  |        | 01BH               |        |        |        |        |     |                                     |
| Port 9 data register      | P9D    | 01CH               | P93    | P92    | P91    | P90    | R/W | Undefined                           |
| Port A data register      | PAD    | 01DH               | PA3    | PA2    | PA1    | PA0    | R/W | Undefined                           |
| Port 9 direction register | P9DIR  | 01EH               | P93DIR | P92DIR | P91DIR | P90DIR | R/W | 0H                                  |
| Port A direction register | PADIR  | 01FH               | PA3DIR | PA2DIR | PA1DIR | PA0DIR | R/W | 0H                                  |
| Port 9 control register   | P9CON  | 020H               | P93CN  | P92CN  | P91CN  | P90CN  | R/W | 0H                                  |
| Port A control register   | PACON  | 021H               | PA3CN  | PA2CN  | PA1CN  | PAOCN  | R/W | 0H                                  |
| Reserved                  |        | 022H<br>to<br>02FH |        |        |        |        |     |                                     |

#### Table A Special Function Register List

| Register name                     | Symbol  | Address            | bit 3   | bit 2  | bit 1   | bit 0  | R/W | Initial value<br>at system<br>reset |
|-----------------------------------|---------|--------------------|---------|--------|---------|--------|-----|-------------------------------------|
| Reserved                          |         | 030H<br>to<br>047H |         |        |         |        |     |                                     |
| Level detector output register    | LDOUT   | 048H               | LD03    | LD02   | LD01    | LD00   | R   | 0FH                                 |
| Level detector operation register | LDSET   | 049H               | _       | _      | _       | _      | W   | _                                   |
| Level detector control register   | LDCON   | 04AH               | LDSTART | LDSAMP | LDPCHG  | LDON   | R/W | 0H                                  |
| Reserved                          |         | 04BH               |         |        |         |        |     |                                     |
| Comparator control register       | CMPCON  | 04CH               | _       | _      | _       | CMPOUT | R/W | 0EH                                 |
| Reserved                          |         | 04DH<br>to<br>04FH |         |        |         |        |     |                                     |
| Interrupt enable register 0       | IE0     | 050H               | EXI3    | EXI2   | EXI1    | EXI0   | R/W | 0H                                  |
| Interrupt enable register 1       | IE1     | 051H               | EST     | ESR    | ETM1    | ETM0   | R/W | 0H                                  |
| Interrupt enable register 2       | IE2     | 052H               | ETBC14  | ETBC13 | ETBC11  | ETBC10 | R/W | 0H                                  |
| Interrupt enable register 3       | IE3     | 053H               | _       | _      | ELD     | EMD    | R/W | OCH                                 |
| Reserved                          |         | 054H               |         |        |         |        |     |                                     |
| Interrupt request register 0      | IRQ0    | 055H               | QXI3    | QXI2   | QXI1    | QXIO   | R/W | 0H                                  |
| Interrupt request register 1      | IRQ1    | 056H               | QST     | QSR    | QTM1    | QTM0   | R/W | 0H                                  |
| Interrupt request register 2      | IRQ2    | 057H               | QTBC14  | QTBC13 | QTBC11  | QTBC10 | R/W | 0H                                  |
| Interrupt request register 3      | IRQ3    | 058H               | _       | _      | QLD     | QMD    | R/W | 0CH                                 |
| Reserved                          |         | 059H<br>to<br>05FH |         |        |         |        |     |                                     |
| Time base counter register 0      | TBCR0   | 060H               | TBC7    | TBC6   | TBC5    | TBC4   | R/W | 0H                                  |
| Time base counter register 1      | TBCR1   | 061H               | TBC11   | TBC10  | TBC9    | TBC8   | R/W | 0H                                  |
| Time base counter register 2      | TBCR2   | 062H               | TBC15   | TBC14  | TBC13   | TBC12  | R/W | 0H                                  |
| Frequency control register        | FCON    | 063H               | _       | _      | ENOSC   | CPUCLK | R/W | 0CH                                 |
| Reserved                          |         | 064H<br>to<br>067H |         |        |         |        |     |                                     |
| Timer 0 data register L           | TMODL   | 068H               | T0D3    | T0D2   | T0D1    | TODO   | R/W | 0H                                  |
| Timer 0 data register H           | TMODH   | 069H               | T0D7    | T0D6   | T0D5    | T0D4   | R/W | 0H                                  |
| Timer 1 data register L           | TM1DL   | 06AH               | T1D3    | T1D2   | T1D1    | T1D0   | R/W | 0H                                  |
| Timer 1 data register H           | TM1DH   | 06BH               | T1D7    | T1D6   | T1D5    | T1D4   | R/W | 0H                                  |
| Timer 0 counter register L        | TMOCL   | 06CH               | T0C3    | T0C2   | T0C1    | тосо   | R/W | OH                                  |
| Timer 0 counter register H        | TMOCH   | 06DH               | T0C7    | T0C6   | T0C5    | T0C4   | R/W | 0H                                  |
| Timer 1 counter register L        | TM1CL   | 06EH               | T1C3    | T1C2   | T1C1    | T1C0   | R/W | 0H                                  |
| Timer 1 counter register H        | TM1CH   | 06FH               | T1C7    | T1C6   | T1C5    | T1C4   | R/W | 0H                                  |
| Timer 0 control register 0        | TMOCONO | 070H               |         | FMEAS0 | TM0ECAP | TMORUN | R/W | 8H                                  |
| Timer 0 control register 1        | TM0CON1 | 071H               | —       | TM0CL2 | TM0CL1  | TMOCLO | R/W | 8H                                  |
| Timer 1 control register 0        | TM1CON0 | 072H               | _       | _      | TM1ECAP | TM1RUN | R/W | 0CH                                 |
| Timer 1 control register 1        | TM1CON1 | 073H               | _       | TM1CL2 | TM1CL1  | TM1CL0 | R/W | 8H                                  |
| Timer 0 status register           | TMOSTAT | 074H               |         |        | TM0CAP  | TM00VF | R   | 0CH                                 |
| Timer 1 status register           | TM1STAT | 075H               | _       | _      | TM1CAP  | TM10VF | R   | 0CH                                 |

#### Table A Special Function Register List (continued)

| Register name                          | Symbol | Address            | bit 3   | bit 2   | bit 1   | bit 0   | R/W | Initial value<br>at system<br>reset |
|----------------------------------------|--------|--------------------|---------|---------|---------|---------|-----|-------------------------------------|
| External interrupt control register 0  | XICONO | 076H               | XI1SEL1 | XI1SEL0 | XI0SEL1 | XI0SEL0 | R/W | ОН                                  |
| External interrupt control register 1  | XICON1 | 077H               | XI3SEL1 | XI3SEL0 | XI2SEL1 | XI2SEL0 | R/W | OH                                  |
| Reserved                               |        | 078H<br>to<br>094H |         |         |         |         |     |                                     |
| Backup control register                | BUPCON | 095H               | _       | —       | —       | BACKUP  | R/W | 0FH                                 |
| Tempo register                         | TEMPO  | 096H               | TMP3    | TMP2    | TMP1    | TMP0    | R/W | OH                                  |
| Melody driver control register         | MDCON  | 097H               | MSF     | EMBD    | MBM1    | MBM0    | R/W | OH                                  |
| Reserved                               |        | 098H<br>to<br>0A3H |         |         |         |         |     |                                     |
| Serial port send buffer L              | STBUFL | 0A4H               | TB3     | TB2     | TB1     | TB0     | R/W | OH                                  |
| Serial port send buffer H              | STBUFH | 0A5H               | TB7     | TB6     | TB5     | TB4     | R/W | ОН                                  |
| Serial port send control register 0    | STCONO | 0A6H               | STSTB   | STL1    | STL0    | STMOD   | R/W | ОН                                  |
| Serial port send control register 1    | STCON1 | 0A7H               | STLMB   | STPOE   | STPEN   | STCLK   | R/W | OH                                  |
| Serial port receive buffer L           | SRBUFL | 0A8H               | RB3     | RB2     | RB1     | RB0     | R   | OH                                  |
| Serial port receive buffer H           | SRBUFH | 0A9H               | RB7     | RB6     | RB5     | RB4     | R   | OH                                  |
| Serial port receive control register 0 | SRCONO | 0AAH               | SREN    | SRL1    | SRL0    | SRMOD   | R/W | OH                                  |
| Serial port receive control register 1 | SRCON1 | 0ABH               | SRLMB   | SRPOE   | SRPEN   | SRCLK   | R/W | OH                                  |
| Serial port receive control register   | SRBRT  | 0ACH               | _       | —       | BRT1    | BRT0    | R/W | 0CH                                 |
| Serial port stauts register            | SSTAT  | 0ADH               | BFULL   | PERR    | OERR    | FERR    | R   | OH                                  |
| Reserved                               |        | 0AEH<br>to<br>0F1H |         |         |         |         |     |                                     |
| RA register 0                          | RA0    | 0F2H               | a3      | a2      | a1      | a0      | R/W | OH                                  |
| RA register 1                          | RA1    | 0F3H               | a7      | a6      | a5      | a4      | R/W | OH                                  |
| RA register 2                          | RA2    | 0F4H               | a11     | a10     | a9      | a8      | R/W | OH                                  |
| RA register 3                          | RA3    | 0F5H               | a15     | a14     | a13     | a12     | R/W | OH                                  |
| Register stack pointer                 | RSP    | 0F6H               | rsp3    | rsp2    | rsp1    | rsp0    | R/W | OH                                  |
| Stack pointer                          | SP     | 0F7H               | sp3     | sp2     | sp1     | sp0     | R   | OH                                  |
| Reserved                               |        | 0F8H               |         |         |         |         |     |                                     |
| Y register                             | Y      | 0F9H               | y3      | y2      | y1      | y0      | R/W | OH                                  |
| X register                             | Х      | 0FAH               | x3      | x2      | x1      | ×0      | R/W | OH                                  |
| L register                             | L      | 0FBH               | 13      | 12      | 11      | 10      | R/W | ОН                                  |
| H register                             | Н      | 0FCH               | h3      | h2      | h1      | h0      | R/W | ОН                                  |
| Current bank register                  | CBR    | 0FDH               | c3      | c2      | c1      | c0      | R/W | OH                                  |
| Extra bank register                    | EBR    | OFEH               | e3      | e2      | e1      | eO      | R/W | OH                                  |
| Master interrupt enable flag register  | MIEF   | 0FFH               | _       | _       | _       | MIE     | R   | 0EH                                 |

## Appendix B Package Dimensions

ML63512A-xxxTB ML63514A-xxxTB

(Unit : mm)



Figure B-1 48-Pin TQFP (TQFP48-P-0707-0.50-K)

Notes for Mounting the Surface Mount Type Package

The SOP, QFP, TSOP, TQFP, LQFP, SOJ, QFJ (PLCC), SHP, and BGA are surface mount type packages, which are very susceptible to heat in reflow mounting and humidity absorbed in storage. Therefore, before you perform reflow mounting, contact Oki's responsible sales person on the product name, package name, pin number, package code and desired mounting conditions (reflow method, temperature, and times).

#### ML63512A-xxxTP ML63514A-xxxTP

(Unit : mm)



Figure B-2 64-Pin TQFP (TQFP64-P-1010-0.50-K)

Notes for Mounting the Surface Mount Type Package

The SOP, QFP, TSOP, TQFP, LQFP, SOJ, QFJ (PLCC), SHP, and BGA are surface mount type packages, which are very susceptible to heat in reflow mounting and humidity absorbed in storage. Therefore, before you perform reflow mounting, contact Oki's responsible sales person on the product name, package name, pin number, package code and desired mounting conditions (reflow method, temperature, and times).

# Appendix C Electrical Characteristics

#### **Absolute Maximum Ratings**

|                        | •                 |                                    |                                | $(V_{SS} = 0 V)$ |
|------------------------|-------------------|------------------------------------|--------------------------------|------------------|
| Parameter              | Symbol            | Condition                          | Rating                         | Unit             |
| Power Supply Voltage 1 | V <sub>DD</sub>   | Ta = 25°C                          | -0.3 to +5.8                   | V                |
| Power Supply Voltage 2 | V <sub>DDI</sub>  | Ta = 25°C                          | -0.3 to +5.8                   | V                |
| Power Supply Voltage 3 | V <sub>DDH</sub>  | Ta = 25°C                          | -0.3 to +5.8                   | V                |
| Power Supply Voltage 4 | V <sub>DDL</sub>  | Ta = 25°C                          | -0.3 to +5.8                   | V                |
| Input Voltage 1        | V <sub>IN1</sub>  | V <sub>DD</sub> Input, Ta = 25°C   | -0.3 to V <sub>DD</sub> + 0.3  | V                |
| Input Voltage 2        | V <sub>IN2</sub>  | V <sub>DDI</sub> Input, Ta = 25°C  | -0.3 to V <sub>DDI</sub> + 0.3 | V                |
| Output Voltage 1       | V <sub>OUT1</sub> | V <sub>DD</sub> Output, Ta = 25°C  | -0.3 to V <sub>DD</sub> + 0.3  | V                |
| Output Voltage 2       | V <sub>OUT2</sub> | V <sub>DDI</sub> Output, Ta = 25°C | -0.3 to V <sub>DDI</sub> + 0.3 | V                |
| Output Voltage 3       | V <sub>OUT3</sub> | V <sub>DDH</sub> Output, Ta = 25°C | -0.3 to V <sub>DDH</sub> + 0.3 | V                |
| Storage Temperature    | T <sub>STG</sub>  | —                                  | -55 to +150                    | °C               |
| Power Dissipation      | PD                | Ta = 25°C                          | 15                             | mW               |

#### **Recommended Operating Conditions**

• When backup is used

|                               |                  |                                |            | $(V_{SS} = 0 V)$ |
|-------------------------------|------------------|--------------------------------|------------|------------------|
| Parameter                     | Symbol           | Condition                      | Range      | Unit             |
| Operating Temperature         | T <sub>op</sub>  | _                              | -20 to +70 | °C               |
| Operating Voltage             | V <sub>DD</sub>  | —                              | 0.9 to 1.8 | V                |
| Operating Voltage             | V <sub>DDI</sub> | —                              | 0.9 to 3.5 | V                |
| Crystal Oscillation Frequency | f <sub>XT</sub>  | _                              | 30 to 80   | kHz              |
| Low-Speed RC Oscillator       | f.               | D. 15 MO                       | 32 ±30%    | kHz              |
| Frequency                     | f <sub>CRL</sub> | R <sub>CRL</sub> = 1.5 MΩ      | 32 ±30%    | КПZ              |
| External High-Speed RC        | D                |                                | 100 to 200 | ko               |
| Oscillator Resistance         | R <sub>CRH</sub> | V <sub>DD</sub> = 0.9 to 1.8 V | 100 to 300 | kΩ               |

#### • When backup is not used

|                               |                  |                                | (\         | ( <sub>SS</sub> = 0 V) |
|-------------------------------|------------------|--------------------------------|------------|------------------------|
| Parameter                     | Symbol           | Condition                      | Range      | Unit                   |
| Operating Temperature         | T <sub>op</sub>  | _                              | -20 to +70 | °C                     |
|                               |                  | —                              | 1.8 to 3.5 |                        |
| Operating Voltage             | V <sub>DD</sub>  | When Level detector and        | 1 0 to 5 5 |                        |
| Operating Voltage             |                  | Comparator are not used        | 1.8 to 5.5 | V                      |
|                               | V <sub>DDI</sub> |                                | 1.8 to 5.5 |                        |
| Crystal Oscillation Frequency | f <sub>XT</sub>  | _                              | 30 to 80   | kHz                    |
| Low-Speed RC Oscillator       | <b>f</b> .       | D. 15 MO                       | 32 ±30%    | kHz                    |
| Frequency                     | f <sub>CRL</sub> | $R_{CRL} = 1.5 M\Omega$        | 32 ±30%    | KITZ                   |
| External High-Speed RC        | P                |                                | 00 to 000  | L-O                    |
| Oscillator Resistance         | R <sub>CRH</sub> | V <sub>DD</sub> = 1.8 to 5.5 V | 30 to 300  | kΩ                     |
| Coromia Oppillation Fraguenov | f.               | V <sub>DD</sub> = 2.2 to 5.5 V | 300k to 1M | 11-                    |
| Ceramic Oscillation Frequency | f <sub>CM</sub>  | V <sub>DD</sub> = 2.7 to 5.5 V | 200k to 2M | Hz                     |

#### **DC Characteristics**

• When backup is used

| Parameter                         | Symbol           | Conditio                                                                                                            | Min.                                       | Тур. | Max. | Unit | Mea-<br>suring<br>Circuit |   |
|-----------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------|------|------|---------------------------|---|
|                                   |                  | CPU is in HALT state                                                                                                | Ta = 25°C                                  | 4.8  | 5.3  | 5.8  |                           |   |
| Supply Current 1                  | I <sub>DD1</sub> | High-speed oscillation stop                                                                                         | Ta = -20 to +50°C                          | —    | 5.3  | 9.0  | μA                        |   |
|                                   |                  | Level detector stop                                                                                                 | $Ta = -20 \text{ to } +70^{\circ}\text{C}$ | —    | 5.3  | 15.0 |                           |   |
| Supply Current 2 I <sub>DD2</sub> |                  | High-speed oscillation stop                                                                                         | Ta = 25°C                                  | 12   | 13   | 14   | μA                        |   |
|                                   | I <sub>DD2</sub> |                                                                                                                     | Ta = -20 to +50°C                          | _    | 13   | 16   |                           |   |
|                                   |                  |                                                                                                                     | Ta = -20 to +70°C                          | _    | 13   | 24   |                           |   |
| Supply Current 3                  | I <sub>DD3</sub> | CPU operating at low speed<br>High-speed oscillation stop<br>Level detector active<br>(for a soft duty of about 3%) |                                            | _    | 10   | 35   | μA                        | 1 |
| Supply Current 4                  | I <sub>DD4</sub> | CPU operating at H<br>High-speed RC o<br>R <sub>CRH</sub> = 100                                                     | scillation                                 |      | 550  | 750  | μA                        |   |

|                    | V 0.V.T 00.1 7000 1                      |                      |
|--------------------|------------------------------------------|----------------------|
| (V 1.5 V, = 1.5 V) | $V_{SS} = 0$ V, Ta = -20 to +70°C unless | otherwise specified) |

#### • When backup is not used

| Parameter        | Symbol           | Conditio                                                                                                            | Min.                                       | Тур. | Max. | Unit | Mea-<br>suring<br>Circuit |   |
|------------------|------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------|------|------|---------------------------|---|
|                  |                  | CPU is in HALT state                                                                                                | Ta = 25°C                                  | 2.1  | 2.4  | 2.7  |                           |   |
| Supply Current 1 | I <sub>DD1</sub> | High-speed oscillation stop                                                                                         | $Ta = -20 \text{ to } +50^{\circ}\text{C}$ | —    | 2.4  | 7.0  | μA                        |   |
|                  |                  | Level detector stop                                                                                                 | Ta = -20 to +70°C                          | —    | 2.4  | 10.0 |                           |   |
|                  |                  | CPU operating                                                                                                       | Ta = 25°C                                  | 5    | 6    | 7    |                           |   |
| Supply Current 2 | I <sub>DD2</sub> | High-speed oscillation stop T                                                                                       | Ta = -20 to +50°C                          | _    | 6    | 9    | μA                        |   |
|                  |                  |                                                                                                                     | Ta = -20 to +70°C                          | —    | 6    | 15   |                           |   |
| Supply Current 3 | I <sub>DD3</sub> | CPU operating at low speed<br>High-speed oscillation stop<br>Level detector active<br>(for a soft duty of about 3%) |                                            | _    | 6    | 25   | μA                        | 1 |
| Supply Current 4 | I <sub>DD4</sub> | CPU operating at high speed High-speed RC oscillation $R_{CRH} = 100 \ k\Omega$                                     |                                            | _    | 410  | 550  | μA                        |   |
| Supply Current 5 | I <sub>DD5</sub> | CPU operating at h<br>High-speed ceramic<br>(ceramic oscillatio                                                     | oscillation                                | _    | 850  | 1000 | μA                        |   |

| (Volume Volume 3.0 V. Vss = | $= 0 \text{ V}, \text{ Ta} = -20 \text{ to } +70^{\circ}\text{C} \text{ unless otherwise specified})$ |
|-----------------------------|-------------------------------------------------------------------------------------------------------|
|                             |                                                                                                       |

| Parameter<br>(Pin Name)                                                                            | Symbol            | Condition                                                                   | Min. | Тур. | Max. | Unit | Mea-<br>suring |
|----------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------|------|------|------|------|----------------|
| (* ************************************                                                            |                   | High-speed clock stop                                                       | 2.8  | _    | 3.0  | v    | Circuit        |
| V <sub>DDH</sub> Voltage                                                                           | V <sub>DDH</sub>  | V <sub>DD</sub> = 1.5 V<br>High-speed clock oscillation                     | 2    | _    |      | v    |                |
|                                                                                                    |                   | (RC oscillation, $R_{CRH} = 100 \text{ k}\Omega$ )<br>High-speed clock stop | 1.0  | 1.5  | 2.0  | V    |                |
| V <sub>DDL</sub> Voltage                                                                           | V <sub>DDL</sub>  | High-speed clock scop                                                       | 2.0  | 1.J  | 2.0  | V    |                |
| Crystal Oscillation Start<br>Voltage                                                               | V <sub>STA</sub>  | Oscillation start time: within 5 seconds                                    | 1.2  | _    | -    | V    |                |
| Crystal Oscillation Hold<br>Voltage                                                                | V <sub>HOLD</sub> | _                                                                           | 0.9  | _    | _    | V    |                |
| External Crystal Oscillator<br>Capacitance                                                         | C <sub>G</sub>    | _                                                                           | 5    | _    | 25   | pF   |                |
| Internal Crystal Oscillator<br>Capacitance                                                         | CD                | _                                                                           | 20   | 25   | 30   | рF   | 1              |
| Internal Low-Speed RC<br>Oscillator Capacitance                                                    | C <sub>XT</sub>   | _                                                                           | 10   | 15   | 20   | pF   |                |
| Internal High-Speed RC<br>Oscillator Capacitance                                                   | C <sub>OS</sub>   | _                                                                           | 8    | 12   | 16   | pF   |                |
| Input Pin Capacitance<br>(P0.0 to P0.3)<br>(P1.0 to P1.3)<br>:<br>(P7.0 to P7.3)<br>(P9.0 to P9.3) | Cin               | _                                                                           |      |      | 5    | pF   |                |
| (PA.0 to PA.3)                                                                                     |                   |                                                                             |      |      |      |      |                |

(V\_DD = V\_DDI = 1.5 V, V\_SS = 0 V, Ta = -20 to +70  $^\circ\text{C}$  unless otherwise specified)

### DC Characteristics (continued)

| Parameter<br>(Pin Name)                                              | Symbol            | Cond                                         | lition                             | Min. | Тур. | Max. | Unit | Mea-<br>suring<br>Circuit                    |
|----------------------------------------------------------------------|-------------------|----------------------------------------------|------------------------------------|------|------|------|------|----------------------------------------------|
| Output Current 1                                                     |                   |                                              | V <sub>DD</sub> = 1.5 V            | -2.5 | -1.3 | -0.2 | mA   |                                              |
| (P0.0 to P0.3)<br>(P1.0 to P1.3)                                     | I <sub>OH1</sub>  | V <sub>OH1</sub> = V <sub>DD</sub> - 0.5 V   | V <sub>DD</sub> = 3.0 V            | -6.0 | -3.5 | -1.0 | mA   | ]                                            |
| (F1.0 t0 F1.3)<br>E                                                  |                   |                                              | V <sub>DD</sub> = 5.0 V            | -8.5 | -5.0 | -1.5 | mA   |                                              |
| (P6.0 to P6.3)                                                       |                   |                                              | V <sub>DD</sub> = 1.5 V            | 0.2  | 1.3  | 2.5  | mA   |                                              |
| (P9.0 to P9.3)<br>(PA.0 to PA.3)                                     | I <sub>OL1</sub>  | V <sub>0L1</sub> = 0.5 V                     | V <sub>DD</sub> = 3.0 V            | 1    | 3    | 6    | mA   |                                              |
| (MD)                                                                 |                   |                                              | V <sub>DD</sub> = 5.0 V            | 1.5  | 3.7  | 8.5  | mA   |                                              |
| Output Current 2                                                     | I <sub>0H2Z</sub> | $V_{OH2} = V_{DD}$                           |                                    | _    | _    | 1    | μA   |                                              |
| (P8.0 to P8.3)                                                       |                   |                                              | V <sub>DDI</sub> = 1.5 V           | 3.0  | 7.5  | 14.0 | mA   |                                              |
|                                                                      | I <sub>OL2</sub>  | V <sub>0L2</sub> = 0.5 V                     | V <sub>DDI</sub> = 3.0 V           | 6    | 12   | 20   | mA   | mA<br>mA<br>mA<br>mA<br>mA<br>μA<br>μA<br>μA |
|                                                                      |                   |                                              | V <sub>DDI</sub> = 5.0 V           | 8    | 15   | 28   | mA   |                                              |
| Output Current 3                                                     | I <sub>OH3R</sub> | V <sub>OH3R</sub> = V <sub>DDH</sub> - 0.5 V | $V_{DD} = V_{DDH} = 3.0 V$         | -2.5 | -1.5 | -0.2 | mA   |                                              |
| (0SC1)                                                               |                   |                                              | $V_{DD} = V_{DDH} = 5.0 V$         | -3.5 | -1.8 | -0.5 | mA   |                                              |
|                                                                      | I <sub>OL3R</sub> | V <sub>OL3R</sub> = 0.5 V                    | $V_{DD} = V_{DDH} = 3.0 V$         | 0.2  | 1.5  | 2.5  | mA   |                                              |
|                                                                      |                   |                                              | $V_{DD} = V_{DDH} = 5.0 V$         | 0.5  | 1.8  | 3.5  | mA   |                                              |
|                                                                      |                   | $V_{OH3C} = V_{DDH} - 0.5 V$                 | $V_{DD} = V_{DDH} = 3.0 \text{ V}$ | -300 | -160 | -60  | μA   |                                              |
|                                                                      | IOH3C             |                                              | $V_{DD} = V_{DDH} = 5.0 V$         | -400 | -240 | -100 | μA   |                                              |
|                                                                      |                   | V <sub>OL3C</sub> = 0.5 V                    | $V_{DD} = V_{DDH} = 3.0 V$         | 60   | 170  | 300  | μA   |                                              |
|                                                                      | IOL3C             |                                              | $V_{DD} = V_{DDH} = 5.0 V$         | 100  | 210  | 400  | μA   |                                              |
| Output Leakage<br>(P0.0 to P0.3)<br>(P1.0 to P1.3)<br>:              | I <sub>ООН</sub>  | V <sub>OH</sub> = V <sub>DD</sub>            |                                    |      |      | 1    | μA   |                                              |
| (P6.0 to P6.3)<br>(P8.0 to P8.3)<br>(P9.0 to P9.3)<br>(PA.0 to PA.3) | I <sub>OOL</sub>  | V <sub>OL</sub> = V <sub>SS</sub>            |                                    | -1   |      |      | μA   |                                              |

#### DC Characteristics (continued)

| Parameter<br>(Pin Name)          | Symbol            | Condition                                              |                            |       | Тур. | Max. | Unit | Mea-<br>suring<br>Circuit |
|----------------------------------|-------------------|--------------------------------------------------------|----------------------------|-------|------|------|------|---------------------------|
| Input Current 1                  | I <sub>IH1U</sub> | $V_{IH1} = V_{DD}$ (when pu                            | lled up)                   | _     | —    | 1    | μA   | μΑ                        |
| (P0.0 to P0.3)<br>(P1.0 to P1.3) |                   | M Maa                                                  | V <sub>DD</sub> = 1.5 V    | -8    | -4   | -1   | μA   |                           |
| (F1.0 (0 F1.3)<br>E              | I <sub>IL1U</sub> | V <sub>IL1</sub> = V <sub>SS</sub><br>(when pulled up) | V <sub>DD</sub> = 3.0 V    | -60   | -30  | -10  | μA   |                           |
| (P7.0 to P7.3)                   |                   | (when pulled up)                                       | V <sub>DD</sub> = 5.0 V    | -150  | -90  | -23  | μA   |                           |
| (P9.0 to P9.3)<br>(PA.0 to PA.3) | I <sub>IH1Z</sub> | V <sub>IH1</sub> = V <sub>DD</sub> (in a high          | -impedance state)          |       |      | 1    | μA   | -                         |
| (1 A.0 10 1 A.3)                 | I <sub>IL1Z</sub> | V <sub>IL1</sub> = V <sub>SS</sub> (in a high          | -impedance state)          | -1    | _    |      | μA   | -                         |
| Input Current 2                  | I <sub>IH2</sub>  | V <sub>IH2</sub> = V <sub>DD</sub>                     |                            |       | _    | 1    | μA   | -                         |
| (RESETB)                         |                   | V <sub>IL2</sub> = V <sub>SS</sub><br>(when pulled up) | V <sub>DD</sub> = 1.5 V    | -45   | -20  | -2   | μA   | -                         |
|                                  | I <sub>IL2</sub>  |                                                        | V <sub>DD</sub> = 3.0 V    | -260  | -120 | -30  | μA   | 3                         |
|                                  |                   | (when pulled up)                                       | V <sub>DD</sub> = 5.0 V    | -870  | -300 | -70  | μA   | 5                         |
| Input Current 3                  |                   | V <sub>IL3</sub> = V <sub>SS</sub>                     | $V_{DD} = V_{DDH} = 3.0 V$ | -350  | -170 | -30  | μA   | -                         |
| (OSC0)                           | I <sub>IL3</sub>  | (when pulled up)                                       | $V_{DD} = V_{DDH} = 5.0 V$ | -750  | -450 | -200 | μA   | -                         |
|                                  | I <sub>IH3R</sub> | V <sub>IH3</sub> = V <sub>DDH</sub>                    |                            | _     | _    | 1    | μA   | -                         |
|                                  | I <sub>IL3R</sub> | $V_{IL3} = V_{SS}$                                     |                            | -1    | _    | _    | μA   | -                         |
| Input Current 4                  | I <sub>IH4</sub>  | V <sub>IH4</sub> = V <sub>DD</sub>                     |                            | _     | _    | 0.1  | μA   | -                         |
| (TST1B, TST2B)                   |                   | $V_{IL4} = V_{SS}$                                     | V <sub>DD</sub> = 1.5 V    | -120  | -60  | -10  | μA   | -                         |
|                                  | I <sub>IL4</sub>  |                                                        | V <sub>DD</sub> = 3.0 V    | -600  | -350 | -100 | μA   | -                         |
|                                  |                   | (when pulled up)                                       | V <sub>DD</sub> = 5.0 V    | -1320 | -770 | -220 | μA   |                           |

(V<sub>DD</sub> = V<sub>DDI</sub> = 1.5 V, V<sub>SS</sub> = 0 V, Ta = -20 to  $+70^{\circ}$ C unless otherwise specified)

#### **DC Characteristics (continued)**

| Parameter<br>(Pin Name)                                                               | Symbol           | Condition                  | Min. | Тур. | Max. | Unit | Mea-<br>suring<br>Circuit |
|---------------------------------------------------------------------------------------|------------------|----------------------------|------|------|------|------|---------------------------|
| Input Voltage 1                                                                       |                  | V <sub>DD</sub> = 1.5 V    | 1.2  | —    | 1.5  | V    |                           |
| (P0.0 to P0.3)<br>(P1.0 to P1.3)                                                      | V <sub>IH1</sub> | $V_{DD} = 3.0 V$           | 2.4  | —    | 3.0  | V    |                           |
| (F1.0 t0 F1.3)<br>E                                                                   |                  | V <sub>DD</sub> = 5.0 V    | 4    | —    | 5    | V    |                           |
| (P7.0 to P7.3)                                                                        |                  | V <sub>DD</sub> = 1.5 V    | 0    | —    | 0.3  | V    |                           |
| (P9.0 to P9.3)<br>(PA.0 to PA.3)                                                      | V <sub>IL1</sub> | V <sub>DD</sub> = 3.0 V    | 0    | —    | 0.6  | V    |                           |
| (1 A.0 to 1 A.3)                                                                      |                  | V <sub>DD</sub> = 5.0 V    | 0    | —    | 1    | V    |                           |
| Input Voltage 2                                                                       |                  | $V_{DD} = V_{DDH} = 3.0 V$ | 2.4  | _    | 3.0  | V    | -                         |
| (OSCO)                                                                                | V <sub>IH2</sub> | $V_{DD} = V_{DDH} = 5.0 V$ | 4    | _    | 5    | V    | -                         |
|                                                                                       |                  | $V_{DD} = V_{DDH} = 3.0 V$ | 0    | _    | 0.6  | V    | -                         |
|                                                                                       | V <sub>IL2</sub> | $V_{DD} = V_{DDH} = 5.0 V$ | 0    | _    | 1    | V    |                           |
| Input Voltage 3                                                                       |                  | V <sub>DD</sub> = 1.5 V    | 1.35 | _    | 1.50 | V    |                           |
| (RESETB)                                                                              | V <sub>IH3</sub> | V <sub>DD</sub> = 3.0 V    | 2.4  | _    | 3.0  | V    | 4                         |
| (TST1B, TST2B)                                                                        |                  | V <sub>DD</sub> = 5.0 V    | 4    | _    | 5    | V    |                           |
|                                                                                       |                  | V <sub>DD</sub> = 1.5 V    | 0    | _    | 0.15 | V    | -                         |
|                                                                                       | V <sub>IL3</sub> | V <sub>DD</sub> = 3.0 V    | 0    | —    | 0.6  | V    |                           |
|                                                                                       |                  | V <sub>DD</sub> = 5.0 V    | 0    | _    | 1    | V    | -                         |
| Hysteresis Width<br>(P0.0 to P0.3)<br>(P1.0 to P1.3)                                  |                  | V <sub>DD</sub> = 1.5 V    | 0.05 | 0.10 | 0.30 | v    |                           |
| :<br>(P7.0 to P7.3)<br>(P9.0 to P9.3)<br>(PA.0 to PA.3)<br>(RESETB)<br>(TST1B, TST2B) | ΔV <sub>T</sub>  | V <sub>DD</sub> = 3.0 V    | 0.2  | 0.5  | 1.0  | v    |                           |
|                                                                                       |                  | V <sub>DD</sub> = 5.0 V    | 0.25 | 1.00 | 1.50 | v    |                           |

(V\_{DD} = V\_{DDI} = 1.5 V, V\_{SS} = 0 V, Ta = –20 to +70°C unless otherwise specified)

#### Hysteresis width



#### Measuring circuit 1



Crystal oscillator



Ceramic oscillator



## Measuring circuit 2



\*3 Input logic circuit to determine the specified measuring conditions.\*4 Measured at the specified output pins.

## Measuring circuit 3



## Measuring circuit 4



\*5 Measured at the specified input pins.

#### AC Characteristics (Serial Interface, Serial Port)

(V<sub>DD</sub> = 0.9 to 5.5 V, V<sub>DDH</sub> = 1.8 to 5.5 V, V<sub>SS</sub> = 0 V, V<sub>DDI</sub> = 0.9 to 5.5 V, Ta = -20 to  $+70^{\circ}$ C unless otherwise specified)

#### (1) Synchronous Communication

| Parameter                              | Symbol              | Condition                     | Min. | Тур. | Max. | Unit |
|----------------------------------------|---------------------|-------------------------------|------|------|------|------|
| TXC/RXC Input Fall Time                | t <sub>f</sub>      |                               | _    |      | 1    | μs   |
| TXC/RXC Input Rise Time                | tr                  | —                             |      |      | 1    | μs   |
| TXC/RXC Input "L" Level<br>Pulse Width | t <sub>CWL</sub>    | —                             | 0.8  | _    |      | μs   |
| TXC/RXC Input "H" Level<br>Pulse Width | t <sub>CWH</sub>    | —                             | 0.8  | _    |      | μs   |
| TXC/RXC Input Cycle Time               | t <sub>CYC</sub>    | —                             | 2    |      |      | μs   |
| TXC/RXC Output Cycle Time              | t <sub>CYC(0)</sub> | CPU operating at 32.768 kHz   | —    | 30.5 | —    | μs   |
| TXD Output Delay Time                  | t <sub>DDR</sub>    | Output load capacitance 10 pF |      |      | 0.4  | μs   |
| RXD Input Setup Time                   | t <sub>DS</sub>     | —                             | 0.5  |      |      | μs   |
| RXD Input Hold Time                    | t <sub>DH</sub>     | —                             | 0.8  | _    | —    | μs   |

Synchronous communication timing ("H" level = 4.0 V, "L" level = 1.0 V)



## (2) UART Communication

| Parameter          | Symbol           | Condition                                                                     | Min.                              | Тур.             | Max.                              | Unit |
|--------------------|------------------|-------------------------------------------------------------------------------|-----------------------------------|------------------|-----------------------------------|------|
| Transmit Baud Rate | T <sub>BRT</sub> | T <sub>BRT</sub> = 1/f <sub>BRT</sub><br>T <sub>CR</sub> = 1/f <sub>OSC</sub> | T <sub>BRT</sub> -T <sub>CR</sub> | T <sub>BRT</sub> | T <sub>BRT</sub> +T <sub>CR</sub> | S    |
| Receive Baud Rate  | R <sub>BRT</sub> | $R_{BRT} = 1/f_{BRT}$                                                         | R <sub>BRT</sub> ×0.97            | R <sub>BRT</sub> | R <sub>BRT</sub> ×1.03            | S    |

f<sub>BRT</sub>: Baud rates (2TBCCLK, TBCCLK, 1/2TBCCLK, Timer 0/1 overflow)

UART communication timing ("H" level = 4.0 V, "L" level = 1.0 V)



#### **AC Characteristics**

| (\                                                      | V <sub>DD</sub> = V <sub>DDI</sub> = | = 0.9 to 5.5 V, V <sub>SS</sub> = 0 V, Ta = -                                                       | 20 to + 70° | C unless otl | nerwise sp | ecified) |
|---------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------|-------------|--------------|------------|----------|
| Parameter                                               | Symbol                               | Condition                                                                                           | Min.        | Тур.         | Max.       | Unit     |
| External Interrupt Enable<br>Pulse Width (Rising Edge)  | t <sub>WH</sub>                      | _                                                                                                   | 20          | _            | _          | ns       |
| External Interrupt Enable<br>Pulse Width (Falling Edge) | t <sub>WL</sub>                      | —                                                                                                   | 20          | _            |            | ns       |
| External Interrupt Disable<br>Time                      | t <sub>NUL</sub>                     | Interrupt enable, MIE = 1<br>CPU operating under<br>the NOP instruction<br>System clock: 32.768 kHz | 13.0        | _            | 65.1       | μs       |

AC characteristics timing ("H" level = 4.0 V, "L" level = 1.0 V)



 $(V_{DD} = 0.9 \text{ V}, \text{ V}_{SS} = 0 \text{ V}, \text{ Ta} = -20 \text{ to } +70^{\circ}\text{C})$ 

| Parameter             | Symbol | Condition                    | Min.            | Тур. | Max.            | Unit | Remarks |
|-----------------------|--------|------------------------------|-----------------|------|-----------------|------|---------|
| Comparator Offset     | Vert   |                              |                 |      | 20              | mV   |         |
| Voltage               | Vcoff  |                              | _               | _    | 30              |      |         |
| Comparator Input      |        |                              | Max             |      | V               | N    |         |
| Voltage               | Vcin   |                              | V <sub>SS</sub> | _    | V <sub>DD</sub> | V    | CMPIN   |
| Comparator Conversion | - T    | Custom ala alu: 00.700 kilis |                 | 100  |                 |      | CMPREF  |
| Time                  | TC     | System clock: 32.768 kHz     | _               | 183  |                 | μs   |         |
| Comparator Supply     | IDDCMP | Comparator operating         | _               | 30   | 90              | μA   |         |
| Current               | IDSCMP | Comparator stopped           | _               |      | 0.1             | μA   |         |

### **Comparator Electrical Characteristics**

Conceptual diagram of comparator supply current

The conceptual diagram of the comparator supply current  $I_{\text{DDCMP}}$  and  $I_{\text{DSCMP}}$  is shown below.



#### Level Detector Electrical Characteristics

|                           |                   |                            | (V <sub>D</sub> | <sub>D</sub> = 0.9 V | , V <sub>SS</sub> = 0 | V, Ta = - | -20 to +70°C) |
|---------------------------|-------------------|----------------------------|-----------------|----------------------|-----------------------|-----------|---------------|
| Parameter                 | Symbol            | Condition                  | Min.            | Тур.                 | Max.                  | Unit      | Remarks       |
| Level Detector Input      | V                 |                            | Max             |                      | V                     | V         |               |
| Voltage                   | V <sub>LD</sub>   |                            | V <sub>SS</sub> | _                    | V <sub>DD</sub>       | V         |               |
| Level Detector Conversion | т.                | Custom alaaki. 20 760 kila |                 | 100                  |                       |           | LDINO, 1      |
| Time                      | TC                | System clock: 32.768 kHz   | _               | 183                  | _                     | μs        |               |
| Level Dtector Supply      | I <sub>DDLD</sub> | Level detector operating   | _               | 80                   | 130                   | μA        |               |
| Current                   | I <sub>DSLD</sub> | Level detector stopped     |                 | _                    | 0.1                   | μA        |               |

Conceptual diagram of level detector supply current

The conceptual diagram of the level detector supply current  $I_{DDLD}$  and  $I_{DSLD}$  is shown below.



## Level Detector Input Levels and Output Codes

(V<sub>DD</sub> = 0.9 to 1.8 V: when backup is used, V<sub>DD</sub> = 1.8 to 3.5 V: when backup is not used; V<sub>SS</sub> = 0 V, Ta = –20 to +70°C)

| Input L                   | evel [V]                  | Level Detector  |       | LDC   | JUT   |       |
|---------------------------|---------------------------|-----------------|-------|-------|-------|-------|
| Min.                      | Max.                      | Operation State | bit 3 | bit 2 | bit 1 | bit 0 |
| $1440/1500 \times V_{DD}$ | V <sub>DD</sub>           | OFF state       | 1     | 1     | 1     | 1     |
| $1306/1500 \times V_{DD}$ | $1366/1500\times V_{DD}$  |                 | 1     | 0     | 1     | 1     |
| $1190/1500 \times V_{DD}$ | $1250/1500\times V_{DD}$  |                 | 1     | 0     | 1     | 0     |
| $1074/1500 \times V_{DD}$ | $1134/1500 \times V_{DD}$ |                 | 1     | 0     | 0     | 1     |
| $958/1500 	imes V_{DD}$   | $1018/1500 \times V_{DD}$ |                 | 1     | 0     | 0     | 0     |
| $842/1500 \times V_{DD}$  | $902/1500 \times V_{DD}$  |                 | 0     | 1     | 1     | 1     |
| $726/1500 \times V_{DD}$  | $786/1500 \times V_{DD}$  | ON state        | 0     | 1     | 1     | 0     |
| $610/1500 \times V_{DD}$  | $670/1500 \times V_{DD}$  | ON state        | 0     | 1     | 0     | 1     |
| $494/1500 \times V_{DD}$  | $554/1500 	imes V_{DD}$   |                 | 0     | 1     | 0     | 0     |
| $378/1500 \times V_{DD}$  | $438/1500\times V_{DD}$   |                 | 0     | 0     | 1     | 1     |
| $262/1500\times V_{DD}$   | $322/1500 \times V_{DD}$  |                 | 0     | 0     | 1     | 0     |
| $146/1500 \times V_{DD}$  | $206/1500 \times V_{DD}$  |                 | 0     | 0     | 0     | 1     |
| V <sub>SS</sub>           | $88/1500 	imes V_{DD}$    |                 | 0     | 0     | 0     | 0     |

## Appendix D Instruction List

The format used in the list of instructions is indicated below.

|      |                     | -                   |                 |         |        |      | _          |                               |           |            |                         |                               | I                                | INS                                | STF                     | RU                        | ст                  | 101           | N C                 | o   | DE           |      |                          |                            | F                           | LA               | G         |
|------|---------------------|---------------------|-----------------|---------|--------|------|------------|-------------------------------|-----------|------------|-------------------------|-------------------------------|----------------------------------|------------------------------------|-------------------------|---------------------------|---------------------|---------------|---------------------|-----|--------------|------|--------------------------|----------------------------|-----------------------------|------------------|-----------|
| MNEM | ONIC                | OF                  | PER/            | ATION   |        | w    | C          | 15                            | 514       | 4 1:       | 31                      | 2                             | 11                               | 10                                 | 9                       | 8                         | 7                   | 6             | 5                   | 4   | 3            | 2    | 1                        | 0                          | z                           | С                | G         |
|      |                     |                     |                 |         |        |      |            |                               |           |            |                         |                               |                                  |                                    |                         |                           |                     |               |                     |     |              |      |                          |                            |                             |                  |           |
|      |                     | м                   |                 |         | ndica  | tes  | cyc<br>nst | icat<br>iles<br>truc<br>e ins | tes<br>ne | ede<br>on. | a 2<br>sh<br>ond<br>e n | 2-w<br>lov<br>d r<br>um<br>to | vore<br>vs 1<br>ow<br>nbe<br>exe | d lo<br>the<br>the<br>r of<br>ecut | ng<br>firs<br>se<br>f m | ins<br>st w<br>cor<br>ach | tru<br>vorc<br>nd v | ctio<br>I. ai | ar<br>de c<br>on, f | e n | ot a<br>tent | ffec | d w<br>inst<br>nd<br>ted | vith<br>ruc<br>tho<br>I wi | (√)<br>tior<br>se t<br>th a | arc<br>hat<br>da | e<br>tsh. |
|      |                     |                     | cates<br>ction. | the ins | struct | tion | l          |                               |           |            |                         |                               |                                  |                                    |                         |                           |                     |               |                     |     |              |      |                          |                            |                             |                  |           |
|      | ates the ne instruc | short-for<br>ction. | m na            | ıme     |        |      |            |                               |           |            |                         |                               |                                  |                                    |                         |                           |                     |               |                     |     |              |      |                          |                            |                             |                  |           |

## **Transfer Instructions**

|                 |                     |   |   |    |    |    |    |                 | INS             | TR | UC             | TIC            | лс             | СС             | DE             |                |                |                |                | F            | LA | G            |
|-----------------|---------------------|---|---|----|----|----|----|-----------------|-----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC        | OPERATION           | w | С | 15 | 14 | 13 | 12 | 11              | 10              | 9  | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| MOV direct,A    | direct←A            | 1 | 1 | 1  | 1  | 0  | 0  | r <sub>11</sub> | r <sub>10</sub> | rg | r <sub>8</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             | _            | _  | —            |
| MOV [HL],A      | [HL]←A              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | —            | —  | —            |
| MOV [XY],A      | [XY]←A              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 0              | —            | —  | —            |
| MOV E:[HL],A    | E:[HL]←A            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | —            | —  | —            |
| MOV E:[XY],A    | E:[XY]←A            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | _            | —  | —            |
| MOV [HL+],A     | [HL]←A,HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              | 0              |              | —  |              |
| MOV [XY+],A     | [XY]←A,XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 0              | —            | —  | $\checkmark$ |
| MOV E:[HL+],A   | E:[HL]←A,HL←HL+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | —            | —  | $\checkmark$ |
| MOV E:[XY+],A   | E:[XY]←A,XY←XY+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | —            | —  | $\checkmark$ |
| MOV ¥cur,#i4    | cur,A←i4            | 1 | 1 | 0  | 1  | 0  | 0  | İз              | İ2              | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | —  | —            |
| MOV [HL],#i4    | [HL],A←i4           | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 0              | 0              | 1              | 1              | 0              | İз             | i2             | i1             | i <sub>0</sub> | $\checkmark$ | —  | —            |
| MOV [XY],#i4    | [XY],A←i4           | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 0              | 0              | 1              | 1              | 1              | İз             | i2             | i1             | i <sub>0</sub> | $\checkmark$ | —  | —            |
| MOV E:[HL],#i4  | E:[HL],A←i4         | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 0              | 0              | 1              | 0              | 0              | İз             | i2             | i1             | i <sub>0</sub> |              | —  | —            |
| MOV E:[XY],#i4  | E:[XY],A←i4         | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 0              | 0              | 1              | 0              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> |              | —  | —            |
| MOV [HL+],#i4   | [HL],A←i4,HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 1              | 0              | 1              | 1              | 0              | İз             | i2             | i1             | i <sub>0</sub> | $\checkmark$ | —  | $\checkmark$ |
| MOV [XY+],#i4   | [XY],A←i4,XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 1              | 0              | 1              | 1              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> |              | —  |              |
| MOV E:[HL+],#i4 | E:[HL],A←i4,HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 1              | 0              | 1              | 0              | 0              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> |              | —  |              |
| MOV E:[XY+],#i4 | E:[XY],A←i4,XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 1               | 1  | 1              | 0              | 1              | 0              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> |              | —  |              |
| MOV A,#i4       | A←i4                | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 0  | 1              | 1              | 1              | 0              | 0              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> |              | —  | —            |
| MOV A, direct   | A←direct            | 1 | 1 | 1  | 1  | 0  | 1  | r <sub>11</sub> | r <sub>10</sub> | ٢g | r <sub>8</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | —  | —            |
| MOV A,[HL]      | A←[HL]              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | $\checkmark$ | —  | —            |
| MOV A,[XY]      | A←[XY]              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 0              | $\checkmark$ | —  | —            |
| MOV A,E:[HL]    | A←E:[HL]            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | $\checkmark$ | —  | —            |
| MOV A,E:[XY]    | A←E:[XY]            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | $\checkmark$ | —  | —            |
| MOV A,[HL+]     | A←[HL],HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 0              | 1              | 0              | 0              | 0              | $\checkmark$ | —  | $\checkmark$ |
| MOV A,[XY+]     | A←[XY],XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 0              | $\checkmark$ | —  | $\checkmark$ |
| MOV A,E:[HL+]   | A←E:[HL],HL←HL+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | $\checkmark$ | —  | $\checkmark$ |
| MOV A,E:[XY+]   | A←E:[XY],XY←XY+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | $\checkmark$ | —  | $\checkmark$ |
| XCH A,sfr       | A⇔sfr               | 1 | 1 | 0  | 0  | 1  | 0  | 1               | 1               | 1  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | —            | —  | —            |
| XCH A,¥cur      | A⇔cur               | 1 | 1 | 0  | 0  | 1  | 1  | 1               | 1               | 1  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | _            | _  | —            |
| XCH A,[HL]      | A⇔[HL]              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1              |              | —  | —            |
| XCH A,[XY]      | A⇔[XY]              | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 1              |              | —  | —            |
| XCH A,E:[HL]    | A⇔E:[HL]            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |              | —  | —            |
| XCH A,E:[XY]    | A⇔E:[XY]            | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              |              | —  | —            |
| XCH A,[HL+]     | A↔[HL],HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 0              | 1              | 0              | 0              | 1              | _            | —  |              |
| XCH A,[XY+]     | A⇔[XY],XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 1              | _            | _  |              |
| XCH A,E:[HL+]   | A⇔E:[HL],HL←HL+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1              |              | —  |              |
| XCH A,E:[XY+]   | A⇔E:[XY],XY←XY+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0               | 0               | 1  | 1              | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | _            | _  |              |

## ML63512A/514A User's Manual Appendix D

## **Rotate Instructions**

|             |                                                                                  |   |   |    |    |    |    |    | INS | TR | UC | ті             | лс             | СС             | DE             |                |                |                |                | F            | LA           | G            |
|-------------|----------------------------------------------------------------------------------|---|---|----|----|----|----|----|-----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC    | OPERATION                                                                        | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С            | G            |
| ROL sfr     | C←{₃sfr₀}←C,A←sfr                                                                | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 0   | 1  | 0  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |              | —            |
| ROL ¥cur    | C←{₃cur₀}←C,A←cur                                                                | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 0   | 1  | 0  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |              | —            |
| ROL [HL]    | $C \leftarrow \{3[HL]_0\} \leftarrow C, A \leftarrow [HL]$                       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 0              |              | $\checkmark$ | —            |
| ROL [XY]    | $C \leftarrow \{3[XY]_0\} \leftarrow C, A \leftarrow [XY]$                       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | —            |
| ROL E:[HL]  | C←{3E:[HL]0}←C,A←E:[HL]                                                          | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | —            |
| ROL E:[XY]  | C←{₃E:[XY]₀}←C,A←E:[XY]                                                          | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0              |              | $\checkmark$ | —            |
| ROL [HL+]   | C←{₃[HL]₀}←C,A←[HL],<br>HL←HL+1                                                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 0              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROL [XY+]   | C←{₃[XY]₀}←C,A←[XY],<br>XY←XY+1                                                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 1              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROL E:[HL+] | C{3E:[HL]₀}C,<br>AE:[HL],HLHL+1                                                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROL E:[XY+] | C{₃E:[XY]₀}C,<br>AE:[XY],XYXY+1                                                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROR sfr     | $C \rightarrow \{3sfr_0\} \rightarrow C, A \leftarrow sfr$                       | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 0   | 1  | 1  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | $\checkmark$ | —            |
| ROR ¥cur    | C→{₃cur₀}→C,A←cur                                                                | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 0   | 1  | 1  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r3             | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | $\checkmark$ | —            |
| ROR [HL]    | $C \rightarrow \{3[HL]_0\} \rightarrow C, A \leftarrow [HL]$                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | _            |
| ROR [XY]    | $C \rightarrow \{3[XY]_0\} \rightarrow C, A \leftarrow [XY]$                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | _            |
| ROR E:[HL]  | $C \rightarrow \{3E: [HL]_0\} \rightarrow C, A \leftarrow E: [HL]$               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | -            |
| ROR E:[XY]  | $C \rightarrow \{3E: [XY]_0\} \rightarrow C, A \leftarrow E: [XY]$               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | —            |
| ROR [HL+]   | C→{₃[HL]₀}→C,A←[HL],<br>HL←HL+1                                                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 0              | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROR [XY+]   | $C \rightarrow \{3[XY]_0\} \rightarrow C, A \leftarrow [XY], XY \leftarrow XY+1$ | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 1              | 1              | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROR E:[HL+] | C-→{₃E:[HL]₀}-→C,<br>A←E:[HL],HL←HL+1                                            | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ROR E:[XY+] | C→{₃E:[XY]₀}→C,<br>A←E:[XY],XY←XY+1                                              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |

|             |                               |   |   |    |    |    |    |    | INS | TR | UC | ті             | ON             | СС             | DE             | =              |                |                |                | F            | LA           | G            |
|-------------|-------------------------------|---|---|----|----|----|----|----|-----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC    | OPERATION                     | W | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С            | G            |
| INC sfr     | sfr,A←sfr+1                   | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 0   | 0  | 0  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| INC ¥cur    | cur,A←cur+1                   | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 0   | 0  | 0  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| INC [HL]    | [HL],A←[HL]+1                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              |              | $\checkmark$ | —            |
| INC [XY]    | [XY],A←[XY]+1                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ | —            |
| INC E:[HL]  | E:[HL],A←E:[HL]+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ | —            |
| INC E:[XY]  | E:[XY],A←E:[XY]+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ | —            |
| INC [HL+]   | [HL],A←[HL]+1,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 0              | 1              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| INC [XY+]   | [XY],A←[XY]+1,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| INC E:[HL+] | E:[HL],A←E:[HL]+1,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| INC E:[XY+] | E:[XY],A←E:[XY]+1,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| DEC sfr     | sfr,A←sfr−1                   | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 0   | 0  | 1  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r3             | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | $\checkmark$ |              |
| DEC ¥cur    | cur,A←cur−1                   | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 0   | 0  | 1  | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r3             | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | $\checkmark$ |              |
| DEC [HL]    | [HL],A←[HL]−1                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | —            |
| DEC [XY]    | [XY],A←[XY]−1                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | —            |
| DEC E:[HL]  | E:[HL],A←E:[HL]−1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | —            |
| DEC E:[XY]  | E:[XY],A←E:[XY]−1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | —            |
| DEC [HL+]   | [HL],A←[HL]−1,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 0              | 1              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| DEC [XY+]   | [XY],A←[XY]−1,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ |              |
| DEC E:[HL+] | E:[HL],A←E:[HL]−1,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| DEC E:[XY+] | E:[XY],A←E:[XY]−1,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1  | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |

## Increment/Decrement Instructions

## ML63512A/514A User's Manual Appendix D

## **Arithmetic Instructions**

|                 |                                 |   |   |    |    |    |    |    | INS | TR | UC             | ті             | лс             | СС             | DDE            | =              |                |                |                | F            | LA           | G            |
|-----------------|---------------------------------|---|---|----|----|----|----|----|-----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC        | OPERATION                       | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С            | G            |
| ADD sfr,A       | sfr,A←sfr+A                     | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 1   | 0  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ |              | —            |
| ADD ¥cur,A      | cur,A←cur+A                     | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 1   | 0  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |              | _            |
| ADD [HL],A      | [HL],A←[HL]+A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 0              | $\checkmark$ |              | _            |
| ADD [XY],A      | [XY],A←[XY]+A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | 0              | $\checkmark$ |              | _            |
| ADD E:[HL],A    | E:[HL],A←E:[HL]+A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | $\checkmark$ |              | —            |
| ADD E:[XY],A    | E:[XY],A←E:[XY]+A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 0              | $\checkmark$ |              | —            |
| ADD [HL+],A     | [HL],A←[HL]+A,<br>HL←HL+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 0              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD [XY+],A     | [XY],A←[XY]+A,<br>XY←XY+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 1              | 0              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD E:[HL+],A   | E:[HL],A←E:[HL]+A,<br>HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD E:[XY+],A   | E:[XY],A←E:[XY]+A,<br>XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD ¥cur,#i4    | cur,A←cur+i4                    | 1 | 1 | 1  | 0  | 0  | 0  | İз | İ2  | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | $\checkmark$ |              |
| ADD [HL],#i4    | [HL],A←[HL]+i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0              | 1              | 0              | 1              | 0              | i3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADD [XY],#i4    | [XY],A←[XY]+i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0              | 1              | 0              | 1              | 1              | i3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADD E:[HL],#i4  | E:[HL],A←E:[HL]+i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0              | 1              | 0              | 0              | 0              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADD E:[XY],#i4  | E:[XY],A←E:[XY]+i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0              | 1              | 0              | 0              | 1              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADD [HL+],#i4   | [HL],A←[HL]+i4,<br>HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 1              | 1              | 0              | 1              | 0              | İз             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD [XY+],#i4   | [XY],A←[XY]+i4,<br>XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 1              | 1              | 0              | 1              | 1              | i <sub>3</sub> | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD E:[HL+],#i4 | E:[HL],A←E:[HL]+i4,<br>HL←HL+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 1              | 1              | 0              | 0              | 0              | İ3             | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD E:[XY+],#i4 | E:[XY],A←E:[XY]+i4,<br>XY←XY+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 1              | 1              | 0              | 0              | 1              | i <sub>3</sub> | i <sub>2</sub> | i1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADC sfr,A       | sfr,A←sfr+A+C                   | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 1   | 0  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |              | —            |
| ADC ¥cur,A      | cur,A←cur+A+C                   | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 1   | 0  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |              | —            |
| ADC [HL],A      | [HL],A←[HL]+A+C                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 1              | $\checkmark$ |              | —            |
| ADC [XY],A      | [XY],A←[XY]+A+C                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | 1              | $\checkmark$ | $\checkmark$ |              |
| ADC E:[HL],A    | E:[HL],A←E:[HL]+A+C             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | $\checkmark$ |              | —            |
| ADC E:[XY],A    | E:[XY],A←E:[XY]+A+C             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 1              | $\checkmark$ |              | —            |
| ADC [HL+],A     | [HL],A←[HL]+A+C,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 0              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADC [XY+],A     | [XY],A←[XY]+A+C,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 1              | 0              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADC E:[HL+],A   | E:[HL],A←E:[HL]+A+C,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADC E:[XY+],A   | E:[XY],A←E:[XY]+A+C,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |

|                |                                                         |   | _ |    |    |    |    |    | INS            | TR             | UC             | TIC            | ЗN             | СС             | DE | =              |                |                |                | F            | LA           | G            |
|----------------|---------------------------------------------------------|---|---|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC       | OPERATION                                               | w | С | 15 | 14 | 13 | 12 | 11 | 10             | 9              | 8              | 7              | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z            | С            | G            |
| ADCD sfr,A     | sfr,A←decimal adjustment<br>{sfr+A+C}                   | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 1              | 1              | 0              | r7             | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCD ¥cur,A    | cur,A←decimal adjustment<br>{cur+A+C}                   | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 1              | 1              | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCD [HL],A    | [HL],A←decimal adjustment<br>{[HL]+A+C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 0  | 0              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| ADCD [XY],A    | [XY],A←decimal adjustment<br>{[XY]+A+C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 1  | 0              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| ADCD E:[HL],A  | E:[HL],A←decimal<br>adjustment {E:[HL]+A+C}             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 0  | 0              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| ADCD E:[XY],A  | E:[XY],A←decimal<br>adjustment {E:[XY]+A+C}             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 1  | 0              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ |              |
| ADCD [HL+],A   | [HL],A←decimal<br>adjustment {[HL]+A+C},<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 0  | 1              | 1              | 0              | 0              | $\checkmark$ | V            | $\checkmark$ |
| ADCD [XY+],A   | [XY],A←decimal<br>adjustment {[XY]+A+C},<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 1  | 1              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADCD E:[HL+],A | E:[HL],A←decimal<br>adjustment {E:[HL]+A+C},<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 0  | 1              | 1              | 0              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADCD E:[XY+],A | E:[XY],A←decimal<br>adjustment {E:[XY]+A+C},<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 1  | 1              | 1              | 0              | 0              | $\checkmark$ | V            | $\checkmark$ |
| ADCJ ¥cur,n    | cur,A←n-ary adjustment<br>{cur+C}                       | 1 | 1 | 0  | 0  | 0  | 1  | 0  | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r7             | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ [HL],n    | [HL],A←n-ary adjustment<br>{[HL]+C}                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 1              | 0  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ [XY],n    | [XY],A←n-ary adjustment<br>{[XY]+C}                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 1              | 1  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ E:[HL],n  | E:[HL],A←n-ary adjustment<br>{E:[HL]+C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 0              | 0  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ E:[XY],n  | E:[XY],A←n-ary adjustment<br>{E:[XY]+C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 0              | 1  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ [HL+],n   | [HL],A←n-ary adjustment<br>{[HL]+C},HL←HL+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 1              | 0  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ [XY+],n   | [XY],A←n-ary adjustment<br>{[XY]+C},XY←XY+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 1              | 1  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ |              |
| ADCJ E:[HL+],n | E:[HL],A←n-ary adjustment<br>{E:[HL]+C},HL←HL+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 0              | 0  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADCJ E:[XY+],n | E:[XY],A←n-ary adjustment<br>{E:[XY]+C},XY←XY+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 0              | 1  | 0              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |

## Arithmetic Instructions (continued)

## Arithmetic Instructions (continued)

|                 |                                 |   |   |    |    |    |    |    | INS | TR | UC             | TIC            | ЭN             | СС             | DDE            | Ξ              |                |                |                | F            | LA           | G            |
|-----------------|---------------------------------|---|---|----|----|----|----|----|-----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC        | OPERATION                       | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С            | G            |
| SUB sfr,A       | sfr,A←sfr–A                     | 1 | 1 | 0  | 0  | 1  | 0  | 0  | 1   | 1  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> |              |              | _            |
| SUB ¥cur,A      | cur,A←cur–A                     | 1 | 1 | 0  | 0  | 1  | 1  | 0  | 1   | 1  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> |              |              | —            |
| SUB [HL],A      | [HL],A←[HL]–A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1              |              | $\checkmark$ | —            |
| SUB [XY],A      | [XY],A←[XY]–A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 1              |              | $\checkmark$ | —            |
| SUB E:[HL],A    | E:[HL],A←E:[HL]–A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              |              |              | _            |
| SUB E:[XY],A    | E:[XY],A←E:[XY]–A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 1              |              |              | _            |
| SUB [HL+],A     | [HL],A←[HL]–A,<br>HL←HL+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 1              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB [XY+],A     | [XY],A←[XY]–A,<br>XY←XY+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 1              | 1              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB E:[HL+],A   | E:[HL],A←E:[HL]–A,<br>HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB E:[XY+],A   | E:[XY],A←E:[XY]–A,<br>XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 1              | 1              | 0              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB ¥cur,#i4    | cur,A←cur–i4                    | 1 | 1 | 1  | 0  | 0  | 1  | İз | i2  | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SUB [HL],#i4    | [HL],A←[HL]−i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 0              | 1              | 0              | 1              | 0              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SUB [XY],#i4    | [XY],A←[XY]−i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 0              | 1              | 0              | 1              | 1              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SUB E:[HL],#i4  | E:[HL],A←E:[HL]–i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 0              | 1              | 0              | 0              | 0              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SUB E:[XY],#i4  | E:[XY],A←E:[XY]–i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 0              | 1              | 0              | 0              | 1              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SUB [HL+],#i4   | [HL],A←[HL]–i4,<br>HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 1              | 1              | 0              | 1              | 0              | i <sub>3</sub> | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB [XY+],#i4   | [XY],A←[XY]–i4,<br>XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 1              | 1              | 0              | 1              | 1              | İз             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB E:[HL+],#i4 | E:[HL],A←E:[HL]–i4,<br>HL←HL+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 1              | 1              | 0              | 0              | 0              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB E:[XY+],#i4 | E:[XY],A←E:[XY]–i4,<br>XY←XY+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 1  | 1              | 1              | 0              | 0              | 1              | İ3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBC sfr,A       | sfr,A←sfr–A–C                   | 1 | 1 | 0  | 0  | 1  | 0  | 1  | 0   | 0  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SBC ¥cur,A      | cur,A←cur–A–C                   | 1 | 1 | 0  | 0  | 1  | 1  | 1  | 0   | 0  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SBC [HL],A      | [HL],A←[HL]–A–C                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | —            |
| SBC [XY],A      | [XY],A←[XY]–A–C                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | —            |
| SBC E:[HL],A    | E:[HL],A←E:[HL]–A–C             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | —            |
| SBC E:[XY],A    | E:[XY],A←E:[XY]–A–C             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | _            |
| SBC [HL+],A     | [HL],A←[HL]–A–C,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBC [XY+],A     | [XY],A←[XY]–A–C,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 1              | 1              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBC E:[HL+],A   | E:[HL],A←E:[HL]–A–C,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBC E:[XY+],A   | E:[XY],A←E:[XY]–A–C,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1   | 0  | 1              | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 0              | $\checkmark$ | $\checkmark$ | $\checkmark$ |

|                |                                                         |   | _ |    |    |    |    |    | INS            | TR             | UC             | TIC            | лс             | СС             | DE | =              |                |                |                | F            | LA           | G            |
|----------------|---------------------------------------------------------|---|---|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|--------------|--------------|--------------|
| MNEMONIC       | OPERATION                                               | W | С | 15 | 14 | 13 | 12 | 11 | 10             | 9              | 8              | 7              | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z            | С            | G            |
| SBCD sfr,A     | sfr,A←decimal adjustment<br>{sfr–A–C}                   | 1 | 1 | 0  | 0  | 1  | 0  | 1  | 0              | 0              | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SBCD ¥cur,A    | cur,A←decimal adjustment<br>{cur–A–C}                   | 1 | 1 | 0  | 0  | 1  | 1  | 1  | 0              | 0              | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SBCD [HL],A    | [HL],A←decimal adjustment<br>{[HL]–A–C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 0  | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | _            |
| SBCD [XY],A    | [XY],A←decimal adjustment<br>{[XY]–A–C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 1  | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | —            |
| SBCD E:[HL],A  | E:[HL],A←decimal<br>adjustment {E:[HL]–A–C}             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 0  | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | —            |
| SBCD E:[XY],A  | E:[XY],A←decimal<br>adjustment {E:[XY]–A–C}             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 1  | 0              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | _            |
| SBCD [HL+],A   | [HL],A←decimal<br>adjustment {[HL]–A–C},<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 0  | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCD [XY+],A   | [XY],A←decimal<br>adjustment {[XY]–A–C},<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 1              | 1  | 1              | 1              | 1              | 1              | $\checkmark$ | V            | $\checkmark$ |
| SBCD E:[HL+],A | E:[HL],A←decimal<br>adjustment {E:[HL]–A–C},<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 0  | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCD E:[XY+],A | E:[XY],A←decimal<br>adjustment {E:[XY]–A–C},<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 0              | 0              | 0              | 1  | 1              | 1              | 1              | 1              | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCJ ¥cur,n    | cur,A←n-ary adjustment<br>{cur–C}                       | 1 | 1 | 0  | 0  | 0  | 1  | 1  | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SBCJ [HL],n    | [HL],A←n-ary adjustment<br>{[HL]–C}                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 1              | 0  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | —            |
| SBCJ [XY],n    | [XY],A←n-ary adjustment<br>{[XY]–C}                     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 1              | 1  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SBCJ E:[HL],n  | E:[HL],A←n-ary adjustment<br>{E:[HL]–C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 0              | 0  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SBCJ E:[XY],n  | E:[XY],A←n-ary adjustment<br>{E:[XY]–C}                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 0              | 0              | 0              | 0              | 1  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | _            |
| SBCJ [HL+],n   | [HL],A←n-ary adjustment<br>{[HL]–C},HL←HL+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 1              | 0  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCJ [XY+],n   | [XY],A←n-ary adjustment<br>{[XY]–C},XY←XY+1             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 1              | 1  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCJ E:[HL+],n | E:[HL],A←n-ary adjustment<br>{E:[HL]–C},HL←HL+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 0              | 0  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SBCJ E:[XY+],n | E:[XY],A—n-ary adjustment<br>{E:[XY]–C},XY—XY+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1              | 1              | 0              | 0              | 0              | 1  | 1              | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | $\checkmark$ | $\checkmark$ |

## Arithmetic Instructions (continued)

## **Compare Instructions**

|                 |                   |   |   |    |    |    |    |    | INS            | TR | UC             | тіс            | DN             | СС             | DE             | Ξ              |                |                |                | F            | LA | G            |
|-----------------|-------------------|---|---|----|----|----|----|----|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC        | OPERATION         | w | С | 15 | 14 | 13 | 12 | 11 | 10             | 9  | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| CMP sfr,A       | sfr–A             | 1 | 1 | 0  | 0  | 1  | 0  | 1  | 0              | 1  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    | _            |
| CMP ¥cur,A      | cur–A             | 1 | 1 | 0  | 0  | 1  | 1  | 1  | 0              | 1  | 0              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    | _            |
| CMP [HL],A      | [HL]–A            | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 0              | $\checkmark$ |    | _            |
| CMP [XY],A      | [XY]–A            | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 0              | $\checkmark$ |    | _            |
| CMP E:[HL],A    | E:[HL]–A          | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | $\checkmark$ |    | —            |
| CMP E:[XY],A    | E:[XY]–A          | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              | $\checkmark$ |    | —            |
| CMP [HL+],A     | [XY]–A,HL←HL+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0              | 0              | $\checkmark$ |    | $\checkmark$ |
| CMP [XY+],A     | [XY]−A,XY←XY+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 0              | 0              | $\checkmark$ |    | $\checkmark$ |
| CMP E:[HL+],A   | E:[HL]−A,HL←HL+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 0              | $\checkmark$ |    | $\checkmark$ |
| CMP E:[XY+],A   | E:[XY]−A,XY←XY+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 0              | 0              | $\checkmark$ |    | $\checkmark$ |
| CMP ¥cur,#i4    | cur—i4            | 1 | 1 | 1  | 0  | 1  | 0  | İз | i <sub>2</sub> | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    | —            |
| CMP [HL],#i4    | [HL]-i4           | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 0              | 1              | 0              | 1              | 0              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | —            |
| CMP [XY],#i4    | [XY]-i4           | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 0              | 1              | 0              | 1              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | —            |
| CMP E:[HL],#i4  | E:[HL]—i4         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 0              | 1              | 0              | 0              | 0              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | —            |
| CMP E:[XY],#i4  | E:[XY]–i4         | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 0              | 1              | 0              | 0              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | —            |
| CMP [HL+],#i4   | [HL]−i4,HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 1              | 1              | 0              | 1              | 0              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| CMP [XY+],#i4   | [XY]−i4,XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 1              | 1              | 0              | 1              | 1              | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| CMP E:[HL+],#i4 | E:[HL]−i4,HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 1              | 1              | 0              | 0              | 0              | İз             | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| CMP E:[XY+],#i4 | E:[XY]−i4,XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 1  | 1              | 1              | 0              | 0              | 1              | İз             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |

#### FLAG INSTRUCTION CODE **MNEMONIC** OPERATION w С z CG 15 14 13 12 11 10 AND sfr.A sfr,A←sfr ∧ A $\sqrt{}$ r<sub>7</sub> r<sub>6</sub> r<sub>5</sub> r4 r<sub>3</sub> r<sub>2</sub> r<sub>1</sub> ro $\sqrt{}$ AND ¥cur.A cur,A←cur∧A r<sub>7</sub> r<sub>6</sub> r<sub>5</sub> r4 r<sub>3</sub> r<sub>2</sub> r<sub>1</sub> ro $\sqrt{}$ AND [HL],A $[HL],A \leftarrow [HL] \land A$ $\sqrt{}$ AND [XY],A $[XY], A \leftarrow [XY] \land A$ $\sqrt{}$ AND E:[HL],A E:[HL],A←E:[HL] ∧ A E:[XY],A←E:[XY] ∧ A $\sqrt{}$ AND E:[XY],A $[HL],A \leftarrow [HL] \land A,$ $\sqrt{}$ $\sqrt{}$ AND [HL+],A HL←HL+1 $[XY], A \leftarrow [XY] \land A,$ AND [XY+],A $\sqrt{}$ $\sqrt{}$ XY←XY+1 E:[HL],A $\leftarrow$ E:[HL] $\land$ A, $\sqrt{}$ $\sqrt{}$ AND E:[HL+],A HL←HL+1 |E:[XY],A←E:[XY] ^ A, $\sqrt{}$ $\sqrt{}$ AND E:[XY+],A XY←XY+1 AND ¥cur,#i4 cur,A←cur ∧i4 $\sqrt{}$ İз İ2 İ1 İ0 r<sub>7</sub> r<sub>6</sub> r5 r4 r<sub>3</sub> r<sub>2</sub> r<sub>1</sub> r<sub>0</sub> AND [HL],#i4 [HL],A←[HL] ∧ i4 $\sqrt{}$ İ2 İ1 İз İ0 [XY],A←[XY] ∧ i4 $\sqrt{}$ AND [XY],#i4 İ2 İз İ1 İ0 $\sqrt{}$ AND E:[HL],#i4 E:[HL],A←E:[HL] ∧i4 İз İ2 İ1 İ0 $\sqrt{}$ AND E:[XY],#i4 E:[XY],A←E:[XY] ∧i4 İз İ2 İ1 İ0 $[HL],A \leftarrow [HL] \land i4,$ $\sqrt{}$ $\sqrt{}$ AND [HL+],#i4 İз İ2 İ1 İ0 HL←HL+1 $[XY], A \leftarrow [XY] \land i4,$ $\sqrt{}$ AND [XY+],#i4 $\sqrt{}$ İз İ2 İ1 İ0 XY←XY+1 E:[HL],A $\leftarrow$ E:[HL] $\land$ i4, $\sqrt{}$ AND E:[HL+],#i4 İ2 İ1 $\sqrt{}$ İз İ0 HL←HL+1 E:[XY],A $\leftarrow$ E:[XY] $\land$ i4, $\sqrt{}$ $\sqrt{}$ AND E:[XY+],#i4 İ1 İз İ2 İ0 XY←XY+1 OR sfr.A sfr,A←sfr∨A $\sqrt{}$ r<sub>7</sub> r<sub>6</sub> r<sub>5</sub> $r_4$ rз r<sub>2</sub> r<sub>1</sub> r<sub>0</sub> $\sqrt{}$ OR ¥cur,A cur,A←cur∨A r<sub>7</sub> r<sub>6</sub> r<sub>5</sub> r4 r<sub>3</sub> r<sub>2</sub> r<sub>1</sub> ro $\sqrt{}$ OR [HL],A $[HL],A \leftarrow [HL] \lor A$ $\sqrt{}$ $[XY],A \leftarrow [XY] \lor A$ OR [XY],A $\sqrt{}$ OR E:[HL],A E:[HL],A←E:[HL] ∨A $\sqrt{}$ OR E:[XY],A |E:[XY],A←E:[XY] ∨A $[HL],A \leftarrow [HL] \lor A,$ $\sqrt{}$ $\sqrt{}$ OR [HL+],A HL←HL+1 $[XY], A \leftarrow [XY] \lor A,$ $\sqrt{}$ $\sqrt{}$ OR [XY+],A XY←XY+1 E:[HL],A $\leftarrow$ E:[HL] $\lor$ A, $\sqrt{}$ $\sqrt{}$ OR E:[HL+],A HL←HL+1 E:[XY],A $\leftarrow$ E:[XY] $\lor$ A, $\sqrt{}$ $\sqrt{}$ OR E:[XY+],A XY←XY+1

#### Logic Instructions

## ML63512A/514A User's Manual Appendix D

## Logic Instructions (continued)

|                 |                                 |   |   |    |    |    |    |    | INS            | TR | UC             | TIC            | ЭN             | СС             | DE             | =              |                |                |                | F            | LA | G            |
|-----------------|---------------------------------|---|---|----|----|----|----|----|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC        | OPERATION                       | w | С | 15 | 14 | 13 | 12 | 11 | 10             | 9  | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| OR ¥cur,#i4     | cur,A←cur∨i4                    | 1 | 1 | 0  | 1  | 1  | 0  | İз | i <sub>2</sub> | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> |              | _  | _            |
| OR [HL],#i4     | [HL],A←[HL] ∨ i4                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 0              | 0              | 1              | 1              | 0              | i3             | i2             | İ1             | i <sub>0</sub> |              | _  | _            |
| OR [XY],#i4     | [XY],A←[XY] ∨ i4                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 0              | 0              | 1              | 1              | 1              | İ3             | i2             | İ1             | i <sub>0</sub> |              | _  | _            |
| OR E:[HL],#i4   | E:[HL],A←E:[HL] ∨i4             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 0              | 0              | 1              | 0              | 0              | İ3             | i2             | İ1             | i <sub>0</sub> |              | _  | _            |
| OR E:[XY],#i4   | E:[XY],A←E:[XY] ∨i4             | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 0              | 0              | 1              | 0              | 1              | i <sub>3</sub> | i <sub>2</sub> | İ1             | i <sub>0</sub> | $\checkmark$ | _  | —            |
| OR [HL+],#i4    | [HL],A←[HL] ∨i4,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 1              | 0              | 1              | 1              | 0              | i3             | i2             | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |
| OR [XY+],#i4    | [XY],A←[XY] ∀i4,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 1              | 0              | 1              | 1              | 1              | i3             | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| OR E:[HL+],#i4  | E:[HL],A←E:[HL] ∀i4,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 1              | 0              | 1              | 0              | 0              | i3             | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| OR E:[XY+],#i4  | E:[XY],A←E:[XY] ∨i4,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 1  | 1              | 0              | 1              | 0              | 1              | i3             | i <sub>2</sub> | i <sub>1</sub> | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| XOR sfr,A       | sfr,A←sfr∀A                     | 1 | 1 | 0  | 0  | 1  | 0  | 1  | 1              | 0  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | —  | —            |
| XOR ¥cur,A      | cur,A←cur∀A                     | 1 | 1 | 0  | 0  | 1  | 1  | 1  | 1              | 0  | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    | —            |
| XOR [HL],A      | [HL],A←[HL]∀A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 1              | $\checkmark$ |    | —            |
| XOR [XY],A      | [XY],A←[XY]∀A                   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | 1              | $\checkmark$ | —  | —            |
| XOR E:[HL],A    | E:[HL],A←E:[HL]∀A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | $\checkmark$ |    | —            |
| XOR E:[XY],A    | E:[XY],A←E:[XY]∀A               | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 1              | $\checkmark$ |    | _            |
| XOR [HL+],A     | [HL],A←[HL]∀A,HL←<br>HL+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 1              | 1              | $\checkmark$ |    | $\checkmark$ |
| XOR [XY+],A     | [XY],A←[XY]∀A,XY←<br>XY+1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 0              | 1              | 1              | $\checkmark$ |    | $\checkmark$ |
| XOR E:[HL+],A   | E:[HL],A←E:[HL]∀A,<br>HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 1              | $\checkmark$ |    | $\checkmark$ |
| XOR E:[XY+],A   | E:[XY],A←E:[XY]∀A,<br>XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 1              | $\checkmark$ |    | $\checkmark$ |
| XOR ¥cur,#i4    | cur,A←cur∀i4                    | 1 | 1 | 0  | 1  | 1  | 1  | İз | İ2             | İ1 | i <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r3             | r <sub>2</sub> | r <sub>1</sub> | ro             |              | _  | _            |
| XOR [HL],#i4    | [HL],A←[HL]∀i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0              | 0              | 1              | 1              | 0              | İз             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | —  | —            |
| XOR [XY],#i4    | [XY],A←[XY]∀i4                  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0              | 0              | 1              | 1              | 1              | İз             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ |    | —            |
| XOR E:[HL],#i4  | E:[HL],A←E:[HL]∀i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0              | 0              | 1              | 0              | 0              | i <sub>3</sub> | i2             | İ1             | i <sub>0</sub> | $\checkmark$ | _  | —            |
| XOR E:[XY],#i4  | E:[XY],A←E:[XY]∀i4              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0              | 0              | 1              | 0              | 1              | i <sub>3</sub> | i2             | i <sub>1</sub> | i <sub>0</sub> |              | _  | —            |
| XOR [HL+],#i4   | [HL],A←[HL]∀i4,<br>HL←HL+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 1              | 0              | 1              | 1              | 0              | i3             | i2             | İ1             | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| XOR [XY+],#i4   | [XY],A←[XY]∀i4,<br>XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 1              | 0              | 1              | 1              | 1              | İ3             | i2             | i1             | i <sub>0</sub> |              | _  |              |
| XOR E:[HL+],#i4 | E:[HL],A←E:[HL]∀i4,<br>HL←HL+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 1              | 0              | 1              | 0              | 0              | İ3             | i2             | i1             | i <sub>0</sub> |              |    |              |
| XOR E:[XY+],#i4 | E:[XY],A←E:[XY]∀i4,<br>XY←XY+1  | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 1              | 0              | 1              | 0              | 1              | i3             | i2             | i1             | i <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |

## Mask Operation Instructions

|                     |                                                                |   |   |    |    |    |    |    | INS            | TR             | UC             | TIC            | лс             | СС             | D  | =              |                |                |                | F            | LA | G            |
|---------------------|----------------------------------------------------------------|---|---|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC            | OPERATION                                                      | W | С | 15 | 14 | 13 | 12 | 11 | 10             | 9              | 8              | 7              | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z            | С  | G            |
| MTST sfr,A          | Testing of all bits in sfr<br>not masked by A                  | 1 | 1 | 0  | 0  | 1  | 0  | 1  | 1              | 1              | 1              | r7             | r <sub>6</sub> | r <sub>5</sub> | r4 | r3             | r2             | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | _  | _            |
| MTST ¥cur,A         | Testing of all bits in cur<br>not masked by A                  | 1 | 1 | 0  | 0  | 1  | 1  | 1  | 1              | 1              | 1              | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    |              |
| MTST [HL],A         | Testing of all bits in [HL]<br>not masked by A                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 0  | 0              | 1              | 0              | 1              | $\checkmark$ |    |              |
| MTST [XY],A         | Testing of all bits in [XY]<br>not masked by A                 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 1  | 0              | 1              | 0              | 1              | $\checkmark$ | _  | —            |
| MTST E:[HL],A       | Testing of all bits in<br>E:[HL]not masked by A                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 0  | 0              | 1              | 0              | 1              | $\checkmark$ |    |              |
| MTST E:[XY],A       | Testing of all bits in<br>E:[XY]not masked by A                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 1  | 0              | 1              | 0              | 1              | $\checkmark$ | _  | _            |
| MTST [HL+],A        | Testing of all bits in [HL]<br>not masked by A,<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 0  | 1              | 1              | 0              | 1              | $\checkmark$ |    | $\checkmark$ |
| MTST [XY+],A        | Testing of all bits in [XY]<br>not masked by A,<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 1              | 1  | 1              | 1              | 0              | 1              | $\checkmark$ |    | $\checkmark$ |
| MTST E:[HL+],A      | Testing of all bits in<br>E:[HL] not masked by A,<br>HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 0  | 1              | 1              | 0              | 1              | $\checkmark$ |    | $\checkmark$ |
| MTST E:[XY+],A      | Testing of all bits in<br>E:[XY] not masked by A,<br>XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 0              | 0              | 0              | 1  | 1              | 1              | 0              | 1              | $\checkmark$ |    | $\checkmark$ |
| MTST ¥cur,#m        | Testing of bits in cur not<br>masked by #m                     | 1 | 1 | 1  | 0  | 1  | 1  | m3 | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | r7             | r <sub>6</sub> | r <sub>5</sub> | r4 | rз             | r <sub>2</sub> | r1             | r <sub>0</sub> | $\checkmark$ |    |              |
| MTST [HL],#m        | Testing of all bits in [HL]<br>not masked by #m                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MTST [XY],#m        | Testing of all bits in [XY]<br>not masked by #m                | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 1              | 0              | 1              | 1  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MTST E:[HL],#m      | Testing of all bits in<br>E:[HL] not masked by #m              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MTST E:[XY],#m      | Testing of all bits in<br>E:[XY] not masked by #m              | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 0              | 1              | 0              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MTST [HL+],#m       | Testing of all bits in [HL]<br>not masked by #m,<br>HL←HL+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 1              | 0              | 1              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| MTST [XY+],#m       | Testing of all bits in [XY]<br>not masked by #m,<br>XY←XY+1    | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 1              | 0              | 1              | 1  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| MTST E:[HL+],<br>#m | Testing of all bits in E:<br>[HL] not masked by #m,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 1              | 0              | 0              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| MTST E:[XY+],<br>#m | Testing of all bits in E:<br>[XY] not masked by #m,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 1              | 0              | 1              | 1              | 0              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |

## Mask Operation Instructions (continued)

|                     |                                                                        |   |   |    |    |    |    |                | INS            | TR             | UC             | ті             | ЗN             | СС             | D              | =              |                |                |                | F            | LA | G            |
|---------------------|------------------------------------------------------------------------|---|---|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC            | OPERATION                                                              | w | C | 15 | 14 | 13 | 12 | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| MCLR ¥cur,#m        | Clearing of all bits in cur<br>not masked by #m,<br>A←cur              | 1 | 1 | 0  | 1  | 0  | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    | _            |
| MCLR [HL],#m        | Clearing of all bits in<br>[HL] not masked by<br>#m, A←[HL]            | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 1              | 0              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MCLR [XY],#m        | Clearing of all bits in<br>[XY] not masked by<br>#m, A←[XY]            | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MCLR E:[HL],#m      | Clearing of all bits in<br>E:[HL] not masked by<br>#m, A←E:[HL]        | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MCLR E:[XY],#m      | Clearing of all bits in<br>E:[XY] not masked by<br>#m, A←E:[XY]        | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 1              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MCLR [HL+],#m       | Clearing of all bits in<br>[HL] not masked by<br>#m,A←[HL],HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 1              | 0              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MCLR [XY+],#m       | Clearing of all bits in<br>[XY] not masked by<br>#m,A←[XY],XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 1              | 1              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MCLR E:[HL+],<br>#m | Clearing of all bits in<br>E:[HL] not masked by<br>#m,A←E:[HL],HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 0              | 0              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MCLR E:[XY+],<br>#m | Clearing of all bits in<br>E:[XY] not masked by<br>#m,A←E:[XY],XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 0              | 1              | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |

|                     |                                                                         |   | _ |    |    |    |    |                | INS            | TR             | UC             | TIC            | ЭN             | СС             | DE | =              |                |                |                | F            | LA | G            |
|---------------------|-------------------------------------------------------------------------|---|---|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC            | OPERATION                                                               | w | С | 15 | 14 | 13 | 12 | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z            | С  | G            |
| MSET ¥cur,#m        | Setting of all bits in cur<br>not masked by #m,<br>A←cur                | 1 | 1 | 0  | 1  | 1  | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    |              |
| MSET [HL],#m        | Setting of all bits in [HL]<br>not masked by #m,<br>A[HL]               | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | _            |
| MSET [XY],#m        | Setting of all bits in [XY]<br>not masked by #m,<br>A[XY]               | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | _            |
| MSET E:[HL],#m      | Setting of all bits in E:<br>[HL] not masked by #m,<br>A—E:[HL]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MSET E:[XY],#m      | Setting of all bits in E:<br>[XY] not masked by #m,<br>A—E:[XY]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | _            |
| MSET [HL+],#m       | Setting of all bits in [HL]<br>not masked by #m,<br>A[HL],HLHL+1        | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | V            |
| MSET [XY+],#m       | Setting of all bits in [XY]<br>not masked by #m,<br>A[XY],XYXY+1        | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | V            |
| MSET E:[HL+],<br>#m | Setting of all bits in E:<br>[HL] not masked by #m,<br>A-E:[HL],HL-HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | V            |
| MSET E:[XY+],<br>#m | Setting of all bits in E:<br>[XY] not masked by #m,<br>A-E:[XY],XY-XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |

## Mask Operation Instructions (continued)

## Mask Operation Instructions (continued)

|                     |                                                                           |   |   |    |    |    |    |                | INS            | TR             | UC             | TI             | ЭN             | СС             | DE | =              |                |                |                | F            | LA | G            |
|---------------------|---------------------------------------------------------------------------|---|---|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC            | OPERATION                                                                 | W | С | 15 | 14 | 13 | 12 | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z            | С  | G            |
| MNOT ¥cur,#m        | Inverting of all bits in<br>cur not masked by #m,<br>A←cur                | 1 | 1 | 0  | 1  | 1  | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ |    |              |
| MNOT [HL],#m        | Inverting of all bits in<br>[HL] not masked by #m,<br>A[HL]               | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MNOT [XY],#m        | Inverting of all bits in<br>[XY] not masked by #m,<br>A—[XY]              | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  |              |
| MNOT E:[HL],#m      | Inverting of all bits in E:<br>[HL] not masked by #m,<br>A—E:[HL]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0  | m3             | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MNOT E:[XY],#m      | Inverting of all bits in E:<br>[XY] not masked by #m,<br>A—E:[XY]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    |              |
| MNOT [HL+],#m       | Inverting of all bits in<br>[HL] not masked by #m,<br>A[HL],HLHL+1        | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ | _  | 1            |
| MNOT [XY+],#m       | Inverting of all bits in<br>[XY] not masked by #m,<br>A←[XY],XY←XY+1      | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| MNOT E:[HL+],<br>#m | Inverting of all bits in E:<br>[HL] not masked by #m,<br>A-E:[HL],HL-HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> |              |    | $\checkmark$ |
| MNOT E:[XY+],<br>#m | Inverting of all bits in E:<br>[XY] not masked by #m,<br>A-E:[XY],XY-XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 1  | m <sub>3</sub> | m <sub>2</sub> | m <sub>1</sub> | m <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |

|                |                                     |   |   |    |    |    |    |                | INS            | TR             | UC             | TIC            | ЭN             | СС             | DE             | =              |                |                |                | F            | LA | G            |
|----------------|-------------------------------------|---|---|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC       | OPERATION                           | w | С | 15 | 14 | 13 | 12 | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| BTST ¥cur.n    | Bit testing of cur.n                | 1 | 1 | 1  | 0  | 1  | 1  | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             |              | _  | —            |
| BTST [HL].n    | Bit testing of [HL].n               | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 1              | 0              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | —            |
| BTST [XY].n    | Bit testing of [XY].n               | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 1              | 0              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | —            |
| BTST E:[HL].n  | Bit testing of E:[HL].n             | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 1              | 0              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | —            |
| BTST E:[XY].n  | Bit testing of E:[XY].n             | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 1              | 0              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BTST [HL+].n   | Bit testing of [HL].n,<br>HL←HL+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 1              | 0              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BTST [XY+].n   | Bit testing of [XY].n,<br>XY←XY+1   | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 1              | 0              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |
| BTST E:[HL+].n | Bit testing of E:[HL].n,<br>HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 1              | 0              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BTST E:[XY+].n | Bit testing of E:[XY].n,<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 1              | 0              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BCLR ¥cur.n    | cur.n←0,A←cur                       | 1 | 1 | 0  | 1  | 0  | 1  | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | —  | _            |
| BCLR [HL].n    | [HL].n←0,A←[HL]                     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  |              |
| BCLR [XY].n    | [XY].n←0,A←[XY]                     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | —  | —            |
| BCLR E:[HL].n  | E:[HL].n←0,A←E:[HL]                 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BCLR E:[XY].n  | E:[XY].n←0,A←E:[XY]                 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BCLR [HL+].n   | [HL].n←0,A←[HL],<br>HL←HL+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |
| BCLR [XY+].n   | [XY].n←0,A←[XY],<br>XY←XY+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | $\checkmark$ |
| BCLR E:[HL+].n | E:[HL].n←0,A←E:[HL],<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BCLR E:[XY+].n | E:[XY].n←0,A←E:[XY],<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 1              | 0              | 1              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BSET ¥cur.n    | cur.n←1,A←cur                       | 1 | 1 | 0  | 1  | 1  | 0  | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r4             | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | ro             | $\checkmark$ | —  | —            |
| BSET [HL].n    | [HL].n←1,A←[HL]                     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | —  | —            |
| BSET [XY].n    | [XY].n←1,A←[XY]                     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BSET E:[HL].n  | E:[HL].n←1,A←E:[HL]                 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BSET E:[XY].n  | E:[XY].n←1,A←E:[XY]                 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | _  | —            |
| BSET [HL+].n   | [HL].n←1,A←[HL],<br>HL←HL+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BSET [XY+].n   | [XY].n←1,A←[XY],<br>XY←XY+1         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BSET E:[HL+].n | E:[HL].n←1,A←E:[HL],<br>HL←HL+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |
| BSET E:[XY+].n | E:[XY].n←1,A←E:[XY],<br>XY←XY+1     | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ |    | $\checkmark$ |

|                |                                                 |   |   |    |    |    |    |                | INS            | TR             | UC             | TIC            | лс             | СС             | DE             |                |                |                |                | F            | LA | G            |
|----------------|-------------------------------------------------|---|---|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----|--------------|
| MNEMONIC       | OPERATION                                       | w | С | 15 | 14 | 13 | 12 | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | z            | С  | G            |
| BNOT ¥cur.n    | cur.n←cur.n,A←cur                               | 1 | 1 | 0  | 1  | 1  | 1  | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | r <sub>7</sub> | r <sub>6</sub> | r <sub>5</sub> | r <sub>4</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | $\checkmark$ | —  | _            |
| BNOT [HL].n    | [HL].n←[HL].n,A←[HL]                            | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | —  | —            |
| BNOT [XY].n    | [XY].n←[XY].n,A←[XY]                            | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | —  | —            |
| BNOT E:[HL].n  | E:[HL].n← <u>E:[HL].n</u> ,A←<br>E:[HL]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> | $\checkmark$ | —  | _            |
| BNOT E:[XY].n  | E:[XY].n← <u>E:[XY].n</u> ,A←<br>E:[XY]         | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | _            |
| BNOT [HL+].n   | [HL].n←[HL].n,A←[HL],<br>HL←HL+1                | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | $\checkmark$ |
| BNOT [XY+].n   | [XY].n← <mark>[XY].n</mark> ,A←[XY],<br>XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | $\checkmark$ |
| BNOT E:[HL+].n | E:[HL].n← <u>E:[HL].n</u> ,A←<br>E:[HL],HL←HL+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | $\checkmark$ |
| BNOT E:[XY+].n | E:[XY].n← <u>E:[XY].n</u> ,A←<br>E:[XY],XY←XY+1 | 1 | 1 | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 1              | n <sub>3</sub> | n <sub>2</sub> | n <sub>1</sub> | n <sub>0</sub> |              | _  | $\checkmark$ |

## Bit Operation Instructions (continued)

|                          |                                                          |   |   |                      |                      |                      |                      |                 | INS                  | TR      | UC                  | TIC                 | лс                  | СС                  | DE                  | =                   |                     |                     |                     | F | LA | G            |
|--------------------------|----------------------------------------------------------|---|---|----------------------|----------------------|----------------------|----------------------|-----------------|----------------------|---------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---|----|--------------|
| MNEMONIC                 | OPERATION                                                | w | С | 15                   | 14                   | 13                   | 12                   | 11              | 10                   | 9       | 8                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   | z | С  | G            |
| MOVHB [HL],<br>[RA]      | [HL],[HL+1]←(RA) <sub>15-8</sub>                         | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0                   | 0                   | 0                   | 1                   | 0                   |   | _  |              |
| MOVHB [XY],<br>[RA]      | [XY],[XY+1]←(RA) <sub>15-8</sub>                         | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1                   | 0                   | 0                   | 1                   | 0                   | _ | _  | _            |
| MOVHB E:[HL],<br>[RA]    | E:[HL],E:[HL+1]←<br>(RA) <sub>15-8</sub>                 | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 1                   | 0                   |   |    | _            |
| MOVHB E:[XY],<br>[RA]    | E:[XY],E:[XY+1]←<br>(RA) <sub>15-8</sub>                 | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1                   | 0                   | 0                   | 1                   | 0                   |   | _  | _            |
| MOVHB [HL+],<br>[RA]     | [HL],[HL+1]←(RA) <sub>15-8</sub> ,<br>HL←HL+2            | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0                   | 1                   | 0                   | 1                   | 0                   |   |    | $\checkmark$ |
| MOVHB [XY+],<br>[RA]     | [XY],[XY+1]←(RA) <sub>15-8</sub> ,<br>XY←XY+2            | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1                   | 1                   | 0                   | 1                   | 0                   |   | _  | $\checkmark$ |
| MOVHB E:[HL+],<br>[RA]   | E:[HL],E:[HL+1]←<br>(RA) <sub>15-8</sub> ,HL←HL+2        | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0                   | 1                   | 0                   | 1                   | 0                   |   | _  | $\checkmark$ |
| MOVHB E:[XY+],<br>[RA]   | E:[XY],E:[XY+1]←<br>(RA) <sub>15-8</sub> ,XY←XY+2        | 1 | 2 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1                   | 1                   | 0                   | 1                   | 0                   |   | _  | $\checkmark$ |
| MOVHB [HL],<br>cadr16    | [HL],[HL+1]←<br>(cadr16) <sub>15-8</sub>                 | 2 | 3 | 0<br>a15             | 0<br>a14             | 0<br>a13             | 0<br>a12             | 0<br>a11        | 0<br>a <sub>10</sub> | 1<br>ao | 1<br>a <sub>8</sub> | 0<br>a7             | 0<br>a <sub>6</sub> | 1<br>a <sub>5</sub> | 0<br>a4             | 0<br>a <sub>3</sub> | 1<br>a <sub>2</sub> | 0<br>a <sub>1</sub> | 0<br>a <sub>0</sub> |   | _  | _            |
| MOVHB [XY],              | [XY],[XY+1]←                                             | 2 | 3 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1                   | 0                   | 1                   | 0                   | 0                   |   | _  |              |
| cadr16                   | (cadr16) <sub>15-8</sub>                                 |   |   |                      |                      |                      |                      | -               | a <sub>10</sub>      |         | a <sub>8</sub>      | a <sub>7</sub>      | a <sub>6</sub>      | a <sub>5</sub>      | a4                  | a <sub>3</sub>      | a <sub>2</sub>      |                     | a <sub>0</sub>      |   |    |              |
| MOVHB E:[HL],<br>cadr16  | E:[HL],E:[HL+1] $\leftarrow$<br>(cadr16) <sub>15-8</sub> | 2 | 3 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0                   | 0                   | 1                   | 0                   | 0                   | _ | _  |              |
|                          |                                                          |   |   | a <sub>15</sub><br>0 | a <sub>14</sub><br>0 | a <sub>13</sub><br>0 | a <sub>12</sub><br>0 | a11<br>0        | a <sub>10</sub><br>0 | ag<br>1 | a <sub>8</sub><br>1 | a <sub>7</sub><br>0 | a <sub>6</sub><br>0 | a <sub>5</sub><br>0 | a <sub>4</sub><br>1 | a <sub>3</sub><br>0 | a <sub>2</sub><br>1 | a <sub>1</sub><br>0 | a <sub>0</sub><br>0 |   |    |              |
| MOVHB E:[XY],<br>cadr16  | $E:[XY], E:[XY+1] \leftarrow (cadr16)_{15-8}$            | 2 | 3 | -                    | -                    | -                    | -                    | -               | 0<br>a <sub>10</sub> |         | · ·                 | 0<br>a7             | 0<br>a <sub>6</sub> | 0<br>a <sub>5</sub> | а <sub>4</sub>      | 0<br>a3             | a <sub>2</sub>      | -                   | a <sub>0</sub>      | — | —  | —            |
| MOVHB [HL+],             | (HL],[HL+1]←                                             |   |   | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0                   | 1                   | 1                   | 0                   | 0                   |   |    |              |
| cadr16                   | $(cadr16)_{15-8},HL \leftarrow HL+2$                     | 2 | 3 | a <sub>15</sub>      | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub> | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a <sub>7</sub>      | a <sub>6</sub>      | a <sub>5</sub>      | a <sub>4</sub>      | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | ao                  | - | —  | $\checkmark$ |
| MOVHB [XY+],             | [XY],[XY+1]←                                             |   | _ | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1                   | 1                   | 1                   | 0                   | 0                   |   |    | 1            |
| cadr16                   | (cadr16) <sub>15-8</sub> ,XY←XY+2                        | 2 | 3 | a <sub>15</sub>      | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub> | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a <sub>7</sub>      | a <sub>6</sub>      | a <sub>5</sub>      | a4                  | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      |   |    | N            |
|                          | E:[HL],E:[HL+1]←                                         | 2 | 3 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0                   | 1                   | 1                   | 0                   | 0                   |   |    |              |
| cadr16                   | (cadr16) <sub>15-8</sub> ,HL←HL+2                        |   | 5 | a <sub>15</sub>      | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub> | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a4                  | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      |   |    | Ì            |
| MOVHB E:[XY+],<br>cadr16 | E:[XY],E:[XY+1]←<br>(cadr16) <sub>15-8</sub> ,XY←XY+2    | 2 | 3 | 0                    | 0                    | 0                    | 0                    | 0               | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1                   | 1                   | 1                   | 0                   | 0                   |   | _  |              |
|                          | (taui 10)15-8,∧1 ←∧1+2                                   |   |   | a <sub>15</sub>      | $a_{14}$             | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub> | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a <sub>4</sub>      | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      |   |    |              |

## **ROM Table Reference Instructions**

|                        |                                                  |   |   |                 |                      |                      |                      |                      | INS                  | TR      | UC                  | ті                  | лс                  | СС                  | DDE            | =                   |                     |                     |                     | F | LA       | G            |
|------------------------|--------------------------------------------------|---|---|-----------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------|---------------------|---------------------|---------------------|---------------------|----------------|---------------------|---------------------|---------------------|---------------------|---|----------|--------------|
| MNEMONIC               | OPERATION                                        | w | С | 15              | 14                   | 13                   | 12                   | 11                   | 10                   | 9       | 8                   | 7                   | 6                   | 5                   | 4              | 3                   | 2                   | 1                   | 0                   | z | С        | G            |
| MOVLB [HL],<br>[RA]    | [HL],[HL+1]←(RA) <sub>7-0</sub>                  | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0              | 0                   | 0                   | 1                   | 1                   | _ | _        | -            |
| MOVLB [XY],<br>[RA]    | [XY],[XY+1]←(RA) <sub>7-0</sub>                  | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1              | 0                   | 0                   | 1                   | 1                   |   |          | _            |
| MOVLB E:[HL],<br>[RA]  | E:[HL],E:[HL+1]←<br>(RA) <sub>7-0</sub>          | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0              | 0                   | 0                   | 1                   | 1                   |   |          | _            |
| MOVLB E:[XY],<br>[RA]  | E:[XY],E:[XY+1]←<br>(RA) <sub>7-0</sub>          | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1              | 0                   | 0                   | 1                   | 1                   | _ | —        | _            |
| MOVLB [HL+],<br>[RA]   | [HL],[HL+1]←(RA) <sub>7-0</sub> ,<br>HL←HL+2     | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0              | 1                   | 0                   | 1                   | 1                   | — |          | $\checkmark$ |
| MOVLB [XY+],<br>[RA]   | [XY],[XY+1]←(RA) <sub>7-0</sub> ,<br>XY←XY+2     | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 1              | 1                   | 0                   | 1                   | 1                   |   |          | $\checkmark$ |
| MOVLB E:[HL+],<br>[RA] | E:[HL],E:[HL+1]←<br>(RA) <sub>7-0</sub> ,HL←HL+2 | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 0              | 1                   | 0                   | 1                   | 1                   |   | _        |              |
| MOVLB E:[XY+],<br>[RA] | E:[XY],E:[XY+1]←<br>(RA) <sub>7-0</sub> ,XY←XY+2 | 1 | 2 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1              | 1                   | 0                   | 1                   | 1                   |   | _        | $\checkmark$ |
| MOVLB [HL],<br>cadr16  | [HL],[HL+1]←<br>(cadr16) <sub>7-0</sub>          | 2 | 3 | 0<br>a15        | 0<br>a14             | 0<br>a13             | 0<br>a12             | 0<br>a11             | 0<br>a <sub>10</sub> | 1<br>a9 | 1<br>a <sub>8</sub> | 0<br>a7             | 0<br>a <sub>6</sub> | 1<br>a <sub>5</sub> | 0<br>a4        | 0<br>a <sub>3</sub> | 1<br>a <sub>2</sub> | 0<br>a <sub>1</sub> | 1<br>a <sub>0</sub> |   |          | _            |
| MOVLB [XY],<br>cadr16  | [XY],[XY+1]←<br>(cadr16) <sub>7-0</sub>          | 2 | 3 | 0               | 0                    | 0                    | 0                    | 0                    | 0<br>a <sub>10</sub> | 1       | 1                   | 0                   | 0<br>a <sub>6</sub> | 1<br>a <sub>5</sub> | 1<br>a4        | 0<br>a <sub>3</sub> | 1                   | 0                   | 1<br>a <sub>0</sub> |   |          | _            |
|                        | E:[HL],E:[HL+1]←                                 |   |   | α <sub>15</sub> | α <sub>14</sub><br>0 | α <sub>13</sub><br>0 | α <sub>12</sub><br>0 | α <sub>11</sub><br>0 | α <sub>10</sub>      | ay<br>1 | a8                  | a <sub>7</sub><br>0 | α <sub>6</sub><br>Ο | α <sub>5</sub><br>0 | 0              | α <u>3</u><br>0     | a <sub>2</sub>      | 0                   | α <sub>0</sub>      |   |          | <u> </u>     |
| cadr16                 | (cadr16) <sub>7-0</sub>                          | 2 | 3 | a <sub>15</sub> | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub>      | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a <sub>4</sub> | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      | - | —        | -            |
|                        | E:[XY],E:[XY+1]←                                 | 2 | 3 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1              | 0                   | 1                   | 0                   | 1                   |   |          |              |
| cadr16                 | (cadr16) <sub>7-0</sub>                          | 2 | 5 | a <sub>15</sub> | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub>      | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a4             | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      |   |          |              |
| MOVLB [HL+],           | [HL],[HL+1]←                                     | 2 | 3 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 1                   | 0              | 1                   | 1                   | 0                   | 1                   | _ | _        |              |
| cadr16                 | (cadr16) <sub>7-0</sub> ,HL←HL+2                 | _ |   | a <sub>15</sub> | a <sub>14</sub>      |                      |                      |                      | a <sub>10</sub>      |         | -                   | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a4             | a <sub>3</sub>      | a <sub>2</sub>      |                     | a <sub>0</sub>      |   |          |              |
| MOVLB [XY+],<br>cadr16 | [XY],[XY+1]←<br>(cadr16) <sub>7-0</sub> ,XY←XY+2 | 2 | 3 | 0               | 0<br>24.4            | 0                    | 0                    | 0                    | 0<br>a <sub>10</sub> | 1<br>a9 | 1<br>a <sub>8</sub> | 0<br>a <sub>7</sub> | 0<br>a <sub>6</sub> | 1<br>a <sub>5</sub> | 1<br>a4        | 1<br>a <sub>3</sub> | 1<br>a <sub>2</sub> | 0<br>a <sub>1</sub> | 1<br>a <sub>0</sub> | _ | _        | $\checkmark$ |
|                        | E:[HL],E:[HL+1]←                                 |   |   | 0               | α <sub>14</sub><br>0 | u 13<br>0            | 0                    | 0                    | α <sub>10</sub>      | 1       | 1                   | 0                   | 0                   | 0                   | 0              | u3<br>1             | 1                   | 0                   | 1                   |   |          | $\vdash$     |
| cadr16                 | $(cadr16)_{7-0}, HL \leftarrow HL+2$             | 2 | 3 | -               | -                    | -                    | -                    |                      | a <sub>10</sub>      | -       |                     | a <sub>7</sub>      | a <sub>6</sub>      | a <sub>5</sub>      | a <sub>4</sub> | аз                  | a <sub>2</sub>      | -                   | a <sub>0</sub>      | — | <u> </u> | $\checkmark$ |
| MOVLB E:[XY+],         | E:[XY],E:[XY+1]←                                 | 2 | 3 | 0               | 0                    | 0                    | 0                    | 0                    | 0                    | 1       | 1                   | 0                   | 0                   | 0                   | 1              | 1                   | 1                   | 0                   | 1                   |   |          |              |
| cadr16                 | (cadr16) <sub>7-0</sub> ,XY←XY+2                 | 2 | 3 | a <sub>15</sub> | a <sub>14</sub>      | a <sub>13</sub>      | a <sub>12</sub>      | a <sub>11</sub>      | a <sub>10</sub>      | ag      | a <sub>8</sub>      | a7                  | a <sub>6</sub>      | a <sub>5</sub>      | a4             | a <sub>3</sub>      | a <sub>2</sub>      | a <sub>1</sub>      | a <sub>0</sub>      |   |          | V            |

|          |                                  |   |   |    |    |    |    | I  | INS | TR | UC | TIC | ΟN | СС | DDE |   |   |   |   | F            | LA           | G            |
|----------|----------------------------------|---|---|----|----|----|----|----|-----|----|----|-----|----|----|-----|---|---|---|---|--------------|--------------|--------------|
| MNEMONIC | OPERATION                        | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7   | 6  | 5  | 4   | 3 | 2 | 1 | 0 | z            | С            | G            |
| PUSH HL  | (RSP)←{FLAG,A,HL},<br>RSP←RSP+1  | 1 | 2 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 1   | 0 | 0 | 0 | 0 | _            | _            | _            |
| PUSH XY  | (RSP)←{CBR,EBR,XY},<br>RSP←RSP+1 | 1 | 2 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 1   | 0 | 0 | 0 | 1 |              | _            | _            |
| POP HL   | RSP←RSP−1,<br>{FLAG,A,HL}←(RSP)  | 1 | 2 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 1   | 0 | 0 | 1 | 0 | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| POP XY   | RSP←RSP-1,<br>{CBR,EBR,XY}←(RSP) | 1 | 2 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 1   | 0 | 0 | 1 | 1 |              | —            | _            |

## Stack Operation Instructions

## Flag Operation Instructions

|          |           |   |   |    |    |    |    | l  | INS | TR | UC | TIC | ΟN | СС | DE | • |   |   |   | F            | LA           | G            |
|----------|-----------|---|---|----|----|----|----|----|-----|----|----|-----|----|----|----|---|---|---|---|--------------|--------------|--------------|
| MNEMONIC | OPERATION | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7   | 6  | 5  | 4  | 3 | 2 | 1 | 0 | z            | С            | G            |
| FCLR G   | G←0       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0 | 0 | 1 | 0 | _            | —            | $\checkmark$ |
| FCLR C   | C←0       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0 | 0 | 1 | 1 | —            | $\checkmark$ | —            |
| FCLR Z   | Z←0       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0 | 1 | 0 | 0 | $\checkmark$ | —            | —            |
| FSET G   | G←1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0 | 1 | 1 | 0 | —            | —            |              |
| FSET C   | C←1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0 | 1 | 1 | 1 | —            | $\checkmark$ | —            |
| FSET Z   | Z←1       | 1 | 1 | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 1 | 0 | 0 | 0 |              | _            | -            |

## **Jump Instructions**

|               |                            |   | _ |    |                 |                 |                 |                 | INS             | TR | UC             | ті | ЛC             | СС             | DDE | Ξ  |    |                |    | F | LA | G |
|---------------|----------------------------|---|---|----|-----------------|-----------------|-----------------|-----------------|-----------------|----|----------------|----|----------------|----------------|-----|----|----|----------------|----|---|----|---|
| MNEMONIC      | OPERATION                  | w | С | 15 | 14              | 13              | 12              | 11              | 10              | 9  | 8              | 7  | 6              | 5              | 4   | 3  | 2  | 1              | 0  | z | С  | G |
| LJMP cadr15   | PC←cadr15                  | 2 | 2 | 0  | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0  | 0              | 0              | 1   | 0  | 1  | 0              | 0  |   |    |   |
| LJIVIF GAULTS |                            | 2 | 2 | 0  | a <sub>14</sub> | a <sub>13</sub> | a <sub>12</sub> | a <sub>11</sub> | a <sub>10</sub> | ag | a <sub>8</sub> | a7 | a <sub>6</sub> | a <sub>5</sub> | a4  | a3 | a2 | a <sub>1</sub> | ao |   | _  | _ |
| JMP cadr12    | PC <sub>11-0</sub> ←cadr12 | 1 | 1 | 1  | 1               | 1               | 0               | a <sub>11</sub> | a <sub>10</sub> | ag | a <sub>8</sub> | a7 | a <sub>6</sub> | a <sub>5</sub> | a4  | a3 | a2 | a <sub>1</sub> | ao | — | —  | — |
| SJMP radr8    | PC←Next PC+radr8           | 1 | 1 | 0  | 0               | 0               | 0               | 1               | 0               | 0  | a7             | 1  | a <sub>6</sub> | a <sub>5</sub> | a4  | a3 | a2 | a <sub>1</sub> | ao | — | —  | — |
| JMP PC+A      | PC←PC+A+1                  | 1 | 1 | 0  | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0  | 0              | 0              | 1   | 0  | 1  | 1              | 1  | — |    | _ |

|           |                                              |   |   |    |    |    |    |    | INS | TR | UC             | TIC | ЭN             | СС             | DE       | Ξ              |    |                |                | F | LA | G        |
|-----------|----------------------------------------------|---|---|----|----|----|----|----|-----|----|----------------|-----|----------------|----------------|----------|----------------|----|----------------|----------------|---|----|----------|
| MNEMONIC  | OPERATION                                    | w | С | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8              | 7   | 6              | 5              | 4        | 3              | 2  | 1              | 0              | z | С  | G        |
| BC radr8  | if C=1 then                                  | 4 | 1 | 0  | 0  | 0  | 0  | 1  | 0   | 1  | a7             | 0   | 2.             | 2-             | <u>.</u> | 2.5            | 2. | <b>a</b> .     | 2.             |   |    |          |
| BLT radr8 | PC←Next PC+radr8(<)                          |   | 1 |    |    |    |    | '  | 0   | 1  | a/             |     | а <sub>6</sub> | a <sub>5</sub> | aq       | ag             | a2 | aı             | aŋ             |   |    |          |
| BNC radr8 | if C=0 then                                  | 4 | 1 | 0  | 0  | 0  | 0  | 1  | 0   | 1  | 2-             | 1   | 2.             | 2-             | <u>.</u> | 2.5            | 2. | <b>a</b> .     | 2.             |   |    |          |
| BGE radr8 | PC←Next PC+radr8(≧)                          |   | 1 |    |    | 0  |    | 1  | 0   | 1  | a <sub>7</sub> |     | а <sub>6</sub> | a5             | a4       | a <sub>3</sub> | az | a1             | ao             |   | _  | <u> </u> |
| BZ radr8  | if Z=1 then                                  | 4 | 1 | 0  | 0  | 0  | 0  | 1  | 1   | 0  | 2-             | 0   | 2.             | 2-             | <u>.</u> | 2.5            | 2. | <b>a</b> .     | 2.             |   |    |          |
| BEQ radr8 | PC←Next PC+radr8(=)                          |   | 1 |    |    | 0  |    | 1  |     | U  | a <sub>7</sub> |     | a <sub>6</sub> | a5             | a4       | a <sub>3</sub> | a2 | a1             | a <sub>0</sub> |   | _  | <u> </u> |
| BNZ radr8 | if Z=0 then                                  | 4 | 1 | 0  | 0  | 0  | 0  | 1  | 1   | 0  |                | 4   | 0.             |                | 0.       | 0.             |    |                | 0.             |   |    |          |
| BNE radr8 | PC←Next PC+radr8(≠)                          |   | 1 |    |    | 0  |    | '  |     | U  | a <sub>7</sub> |     | a6             | a <sub>5</sub> | a4       | ag             | a2 | a1             | aŋ             |   | _  | _        |
| BLE radr8 | if (C=1)∨ (Z=1) then<br>PC←Next PC+radr8(≦)  | 1 | 1 | 0  | 0  | 0  | 0  | 1  | 1   | 1  | a7             | 0   | a <sub>6</sub> | a <sub>5</sub> | a4       | a3             | a2 | a1             | a <sub>0</sub> |   |    | _        |
| BGT radr8 | if (C=0) ∧ (Z=0) then<br>PC←Next PC+radr8(>) | 1 | 1 | 0  | 0  | 0  | 0  | 1  | 1   | 1  | a7             | 1   | a <sub>6</sub> | a <sub>5</sub> | a4       | a3             | a2 | a1             | a <sub>0</sub> |   |    | _        |
| BNG radr8 | if G=0 then<br>PC←Next PC+radr8              | 1 | 1 | 0  | 0  | 0  | 0  | 1  | 0   | 0  | a7             | 0   | a <sub>6</sub> | a <sub>5</sub> | a4       | a3             | a2 | a <sub>1</sub> | a <sub>0</sub> |   |    | _        |

### **Call/Return Instructions**

|             |                                                |   | _ |                 |                 |                 |                 |                 | INS             | TR | UC             | TIC | ΟN             | СС             | DE |                |                |                |                | F | LA | G |
|-------------|------------------------------------------------|---|---|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|----------------|-----|----------------|----------------|----|----------------|----------------|----------------|----------------|---|----|---|
| MNEMONIC    | OPERATION                                      | w | С | 15              | 14              | 13              | 12              | 11              | 10              | 9  | 8              | 7   | 6              | 5              | 4  | 3              | 2              | 1              | 0              | z | С  | G |
|             | (SP)←PC,PC←cadr14,                             | 2 | 2 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 1  | 0              | 1              | 0              | 1              |   |    |   |
| LCAL cadr14 | SP←SP+1                                        | 2 | _ | a <sub>15</sub> | a <sub>14</sub> | a <sub>13</sub> | a <sub>12</sub> | a <sub>11</sub> | a <sub>10</sub> | ag | a <sub>8</sub> | a7  | a <sub>6</sub> | a <sub>5</sub> | a4 | a <sub>3</sub> | a2             | a <sub>1</sub> | a <sub>0</sub> |   |    | _ |
|             | (SP)←PC,PC <sub>11-0</sub> ←<br>cadr12,SP←SP+1 | 1 | 1 | 1               | 1               | 1               | 1               | a <sub>11</sub> | a <sub>10</sub> | ag | a <sub>8</sub> | a7  | a <sub>6</sub> | a <sub>5</sub> | a4 | a <sub>3</sub> | a <sub>2</sub> | a <sub>1</sub> | a <sub>0</sub> |   | _  | _ |
| RT          | PC←(SP)+1,SP←SP−1                              | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0  | 1              | 0              | 1              | 1              |   | —  | — |
|             | PC←(SP)+1,SP←SP−1,<br>MIE←1                    | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0  | 1              | 1              | 0              | 0              |   |    | _ |

|              |                      |   |   |                 |                 |                 |                 |                 | INS             | TR | UC             | TIC | лс             | СС             | DDE |                |                |                |                | F | LA | G |
|--------------|----------------------|---|---|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|----------------|-----|----------------|----------------|-----|----------------|----------------|----------------|----------------|---|----|---|
| MNEMONIC     | OPERATION            | w | С | 15              | 14              | 13              | 12              | 11              | 10              | 9  | 8              | 7   | 6              | 5              | 4   | 3              | 2              | 1              | 0              | z | С  | G |
| NOP          | NO OPERATION         | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0   | 0              | 0              | 0              | 0              | — |    | _ |
| HALT         | HALT CPU             | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0   | 0              | 0              | 0              | 1              | — |    | — |
| EI           | MIE←1                | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0   | 1              | 1              | 1              | 0              | — |    | — |
| DI           | MIE←0                | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 0   | 1              | 1              | 1              | 1              | — | _  | — |
| INCB HL      | HL←HL+1              | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 1   | 1              | 0              | 0              | 0              | — |    |   |
| INCB XY      | XY←XY+1              | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 1   | 1              | 0              | 0              | 1              | — |    |   |
| INCW RA      | RA←RA+1              | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 1   | 1              | 0              | 1              | 0              | — |    |   |
| MOV CBR,#i4  | CBR←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 1              | 1   | İ3             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | — |
| MOV EBR,#i4  | EBR←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 1              | 0   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | _ |
| MOV RA0,#i4  | RA0←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 1  | 0              | 0   | 0              | 0              | 0   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | _ |
| MOV RA1,#i4  | RA1←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 1  | 0              | 0   | 0              | 0              | 1   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — | _  | — |
| MOV RA2,#i4  | RA2←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 1  | 0              | 0   | 0              | 1              | 0   | İ3             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | — |
| MOV RA3,#i4  | RA3←i4               | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 1  | 0              | 0   | 0              | 1              | 1   | İ3             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | — |
| MOV H,#i4    | H←i4                 | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 1              | 0   | 0              | 1              | 1   | İ3             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | — |
| MOV L,#i4    | L←i4                 | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 1              | 0   | 0              | 1              | 0   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | _ |
| MOV X,#i4    | X←i4                 | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 1              | 0   | 0              | 0              | 1   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | _ |
| MOV Y,#i4    | Y←i4                 | 1 | 1 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 1              | 0   | 0              | 0              | 0   | İз             | i <sub>2</sub> | İ1             | i <sub>0</sub> | — |    | _ |
| MSA cadr14   | Malady autout atarta | 2 | 3 | 0               | 0               | 0               | 0               | 0               | 0               | 0  | 0              | 0   | 0              | 0              | 1   | 0              | 1              | 1              | 0              |   |    |   |
| IVIOA GAULTA | Melody output starts | 2 | 3 | a <sub>15</sub> | a <sub>14</sub> | a <sub>13</sub> | a <sub>12</sub> | a <sub>11</sub> | a <sub>10</sub> | ag | a <sub>8</sub> | a7  | a <sub>6</sub> | a <sub>5</sub> | a4  | a <sub>3</sub> | a <sub>2</sub> | a <sub>1</sub> | ao             |   |    |   |

## **Control Instructions**

Note:

Although provided in the nX-4/250 CPU core, the external memory transfer instructions and the RTNMI instruction are not available in the ML63512A and ML63514A.

## Appendix E Mask Option

In the ML63512A and ML63514A, use the mask option to specify the following items:

- · Crystal oscillation or RC oscillation, for the low-speed clock oscillation circuit
- RC oscillation or ceramic oscillation, for the high-speed clock oscillation circuit
- Either the internal pull-up resistor is used or the external pull-up resistor is used, as the reset pin function

To use the mask option, assign mask option data in the application program in accordance with the formats below.

Because the data assignment area for the ML63512A (addresses 0FE0H through 0FE3H) and that for the ML63514A (addresses 1FE0H through 1FE3H) are out of the program memory area, assigning mask option data does not affect the application program execution area.

| Address | Function          | Contents                  | Da                        | ata                    |
|---------|-------------------|---------------------------|---------------------------|------------------------|
| 0FE0H   | Low-speed         | Crystal oscillation or    | 0: Crystal oscillation    | 1: RC oscillation      |
|         | oscillation clock | RC oscillation            |                           |                        |
| 0FE1H   | High-speed        | Internal capacitor        | Always set "0". ("1" is i | nvalid.)               |
|         | oscillation clock |                           |                           |                        |
| 0FE2H   | Reset             | Internal pull-up resistor | 0: Internal pull-up       | 1: External pull-up    |
|         |                   | or external pull-up       | resistor                  | resistor               |
|         |                   | resistor                  |                           |                        |
| 0FE3H   | High-speed        | RC oscillation or         | 0: RC oscillation         | 1: Ceramic oscillation |
|         | oscillation clock | ceramic oscillation       |                           |                        |

#### ML63512A Mask Option Data Assignment Format

#### ML63514A Mask Option Data Assignment Format

| Address | Function                        | Contents                                                     | Da                              | ata                          |
|---------|---------------------------------|--------------------------------------------------------------|---------------------------------|------------------------------|
| 1FE0H   | Low-speed                       | Crystal oscillation or                                       | 0: Crystal oscillation          | 1: RC oscillation            |
|         | oscillation clock               | RC oscillation                                               |                                 |                              |
| 1FE1H   | High-speed<br>oscillation clock | Internal capacitor                                           | Always set "0". ("1" is         | invalid.)                    |
| 1FE2H   | Reset                           | Internal pull-up resistor<br>or external pull-up<br>resistor | 0: Internal pull-up<br>resistor | 1: External pull-up resistor |
| 1FE3H   | High-speed<br>oscillation clock | RC oscillation or ceramic oscillation                        | 0: RC oscillation               | 1: Ceramic oscillation       |

Note:

The high-speed clock oscillation circuit has a built-in capacitor. When assigning the option data, set "0" as the data for addresses 0FE1H for the ML63512A and 1FE1H for the ML63514A. Setting "1" is invalid.

[Example of mask option data generation]

• When crystal oscillation and internal pull-up resistor are selected for the ML63512A:

| ORG   | 0FE0H        | ← Use an assembler pseudo-instruction to set the address of option data to 0FE0H. |
|-------|--------------|-----------------------------------------------------------------------------------|
| DW    | 0            | ; Low-speed oscillation clock, crystal oscillation                                |
| DW    | 0            | ; Fixed to "0".                                                                   |
| DW    | 0            | ; Internal pull-up resistor, for the reset pin                                    |
| DW    | 1            | ; High-speed oscillation clock, ceramic oscillation                               |
| • Whe | n RC oscilla | ation and external pull-up resistor are selected for the ML63514A:                |
| ORG   | 1FE0H        | ← Use an assembler pseudo-instruction to set the address of option data to 1FE0H. |
| DW    | 1            | ; Low-speed oscillation clock, RC oscillation                                     |
| DW    | 0            | ; Fixed to "0".                                                                   |
| DW    | 1            | ; External pull-up resistor, for the reset pin                                    |
| DW    | 0            | ; High-speed oscillation clock, RC oscillation                                    |

# Appendix F Differences between the ML63512/514 and the ML63512A/514A

The ML63512A/514A are the successors to the ML63512/514.

Table F-1 lists the differences between the ML63512/514 and the ML63512A/514A.

Table F-1 Differences between ML63512/514 and ML63512A/514A

| Item                              | ML63512/514                   | ML63512A/63514A            |
|-----------------------------------|-------------------------------|----------------------------|
| High-speed RC oscillation circuit | Internal capacitor/external   | Internal capacitor only    |
|                                   | capacitor selectable          |                            |
| Pin 32 of 48-pin TQFP             | OSCM                          | V <sub>SS</sub>            |
| Pin 42 of 64-pin TQFP             | OSCM                          | V <sub>SS</sub>            |
| Reset circuit                     | Sampling circuit not provided | Sampling circuit provided* |

\* System reset mode is entered by applying a "L" level (a pulse width of 1.25 seconds or more) to the RESETB pin.

## ML63512A/514A

User's Manual

First Edition: May 2000

© 2000 Oki Electric Industry Co., Ltd.

FEUL63512A-01