

# F<sup>2</sup>MC-8L FAMILY MICROCONTROLLERS

# **MB89630 SERIES**

HARDWARE MANUAL

F<sup>2</sup>MC-8L FAMILY MICROCONTROLLERS

### MB89630 SERIES HARDWARE MANUAL

Edition 3.0 September 1995

©1998 FUJITSU LIMITED

All Rights Reserved.

Circuit diagrams utilizing Fujitsu products are included as a mean of illustrating typical semiconductor applications. Complete information sufficient for construction proposes is not necessarily given.

The information contained in this document has been carefully checked and is believed to be reliable. However, Fujitsu assumes no responsibility for inaccuracies.

The information contained in this document does not convey any license under the copyrights, patent rights to trademarks claimed and owned by Fujitsu.

Fujitsu reserved the right to change products or specifications without notice.

No part of this publication may be copied or reproduced in any form or by any means, or transferred to any third party without prior written consent of Fujitsu.

The products described in this document are not intended for use in equipment requiring high reliability, such as marine relays and medical life-support systems. For such applications, contact your Fujitsu sales representative.

If the products and technologies described in this document are controlled by the Foreign Exchange and Foreign Trade Control Act established in Japan, their export is subject to prior approval based on the said act.

### PREFACE

The MB89630 series has been developed for application specific ICs (ASICs) and as a general-purpose, high-speed version of the  $F^2MC-8L$  (MB89600) family of 8-bit single-chip microcontrollers operating at low voltage.

This manual describes the functions and operation of the MB89630 series and should be read before use. For details of the instructions, refer to the MB89600 Series Programming Manual.

This manual consists of the following chapters:

Chapter 1 General

This chapter describes the MB89630 series' product lineup and product outline.

Chapter 2 Hardware Configuration

This chapter deals with the  $F^2MC-8L$  family's internal CPU configuration and operation modes, and the hardware specifications in the MB89630 series.

Chapter 3 Operation

This chapter explains the MB89630 series' use, reset sequence, interrupts, external bus operation, and low-power consumption modes.

Chapter 4 Instruction Overview

This chapter outlines the F<sup>2</sup>MC-8L family's instructions.

Chapter 5 List of Mask Options

This chapter discusses the MB89630 series' mask options.

Appendix 1 I/O Map

This lists the registers in the I/O area.

### Appendix 2 Write to MB89P637-based EPROM

This explains a write operation to an MB89P637-based EPROM.

### **Table of Contents**

| 1. | GE  | NERAL                                             | 1-1  |
|----|-----|---------------------------------------------------|------|
|    | 1.1 | FEATURES                                          | 1-3  |
|    | 1.2 | PRODUCT SERIES                                    | 1-4  |
|    | 1.3 | BLOCK DIAGRAM                                     | 1-5  |
|    | 1.4 | PIN ASSIGNMENT                                    | 1-6  |
|    |     | PACKAGE DIMENSIONS                                |      |
|    |     | PIN DESCRIPTION                                   |      |
|    | -   | HANDLING DEVICES                                  |      |
|    | 1.7 | HANDLING DEVICES                                  | 1-16 |
| 2. | HA  | RDWARE CONFIGURATION                              | 2-1  |
|    | 2.1 | CPU                                               | 2-3  |
|    |     | 2.1.1 Memory Space                                |      |
|    |     | 2.1.2 Arrangement of 16-bit Data in Memory        |      |
|    |     | 2.1.3 Internal Registers in CPU                   |      |
|    |     | 2.1.4 Operation Modes and External Bus Operation  |      |
|    |     | 2.1.5 Clock Control Block                         |      |
|    |     | 2.1.6 Interrupt Controller                        |      |
|    | 2.2 | RESOURCE FUNCTIONS                                | 2-27 |
|    |     | 2.2.1 I/O Ports                                   |      |
|    |     | 2.2.2 2-channel 8-bit PWM Timers (Timers 1 and 2) |      |
|    |     | 2.2.3 Pulse-width Count Timer (Timer 3)           |      |
|    |     | 2.2.4 16-bit Timer/Counter (Timer 3)              |      |
|    |     | 2.2.5 UART                                        |      |
|    |     | 2.2.6 8-bit Serial I/O 1                          |      |
|    |     | 2.2.7 10-bit A/D Converter                        |      |
|    |     | 2.2.8 External Interrupt Circuit                  |      |
|    |     | 2.2.9 Buzzer Output Circuit                       |      |
|    |     | 2.2.10 Watch Prescaler                            |      |
|    |     | 2.2.11 Time-base Timer                            |      |
|    |     | 2.2.12 Watchdog Timer Reset                       |      |
| 3. | OP  | ERATION                                           | 3-1  |
|    | 3.3 | CLOCK PULSE GENERATOR                             | 3-3  |
|    | 3.4 | RESET                                             | 3-4  |
|    |     | 3.4.1 Reset Operation                             |      |
|    |     | 3.4.2 Reset Sources                               |      |
|    | 3.5 | INTERRUPT                                         | 3-6  |
|    | 3.6 | MEMORY ACCESS MODE                                | 3-8  |

|    | 3.7 | READY AND HOLD FUNCTIONS                    |       |
|----|-----|---------------------------------------------|-------|
|    |     | 3.7.1 Ready Function                        | 3-10  |
|    |     | 3.7.2 Hold Function                         | 3-11  |
|    | 3.8 | LOW-POWER CONSUMPTION MODES                 | 3-12  |
|    | 3.9 | PIN STATES FOR SLEEP, STOP, HOLD, AND RESET | 3-13  |
| 4. | OP  | ERATION                                     | 4-1   |
|    | 4.1 | TRANSFER INSTRUCTIONS                       | 4-3   |
|    | 4.2 | OPERATION INSTRUCTIONS                      | 4-4   |
|    | 4.3 | BRANCH INSTRUCTIONS                         | 4-5   |
|    |     | OTHER INSTRUCTIONS                          |       |
|    | 4.5 | F <sup>2</sup> MC-8L INSTRUCTION MAP        | 4-7   |
| 5. | MA  | SK OPTIONS                                  | 5-1   |
| AP | PEN | NDIX                                        | Арр.1 |
|    | APF | PENDIX 1 I/O MAP                            | АррЗ  |
|    | APF | PENDIX 2WRITING TO EPROM OF MB89P637        | App5  |
|    | APF | PENDIX 3SETTING PROM OPTION                 | Арр6  |
|    |     |                                             |       |

## Figures

| Fig. 1.1  | Block Diagram (MB89635)                                              | 1-5  |
|-----------|----------------------------------------------------------------------|------|
| Fig. 1.2  | Pin Assignment (DIP-64P-M01 and MDP-64C-P02)                         | 1-6  |
| Fig. 1.3  | Pin Assignment (FPT-64P-M09)                                         | 1-6  |
| Fig. 1.4  | Pin Assignment (MQP-64C-P01 and FPT-64P-M06)                         | 1-7  |
| Fig. 1.5  | Package dimension                                                    | 1-8  |
| Fig. 1.6  | Package dimension (QFP)                                              | 1-9  |
| Fig. 1.7  | Package dimension (MB89PV630)                                        | 1-10 |
| Fig. 2.1  | Memory Space of MB89630 Series of Microcontrollers                   | 2-3  |
| Fig. 2.2  | Arrangement of 16-bit Data in Memory                                 | 2-5  |
| Fig. 2.3  | Arrangement of 16-bit Data during Execution of Instruction           | 2-5  |
| Fig. 2.4  | Structure of Program Status                                          | 2-6  |
| Fig. 2.5  | Rule for Translating Real Addresses at General-purpose Register Area | 2-7  |
| Fig. 2.6  | Register Bank Configuration                                          |      |
| Fig. 2.7  | Memory Maps in Various Modes                                         | 2-9  |
| Fig. 2.8  | Interrupt-processing Flowchart                                       | 2-26 |
| Fig. 2.9  | Ports 0 and 1 (in Single-chip Mode)                                  | 2-29 |
| Fig. 2.10 | Port 2 (in Single-chip Mode)                                         |      |
| Fig. 2.11 | Port 3                                                               | 2-32 |
| Fig. 2.12 | Port 4                                                               | 2-34 |
| Fig. 2.13 | Port 5                                                               | 2-35 |
| Fig. 2.14 | Port 6                                                               | 2-36 |
| Fig. 2.15 | Port 7                                                               | 2-37 |
| Fig. 2.16 | Timer Operation                                                      | 2-44 |
| Fig. 2.17 | PWM Pulse Output                                                     | 2-45 |
| Fig. 2.18 | PWM Wave Output at CH1-2 PWM Mode                                    | 2-46 |
| Fig. 2.9  | RDRF Flag Set Timing                                                 |      |
| Fig. 2.10 | ORFE Flag Set Timing                                                 |      |
| Fig. 2.11 | TDRE Flag Set Timing (Mode 0)                                        |      |
| Fig. 2.12 | Shift Start/Stop Timing                                              |      |
| Fig. 2.13 | Input/Output Shift Timing                                            |      |
| Fig. 2.14 | Block Diagram of Watchdog Timer                                      |      |
| Fig. 3.15 | Clock Pulse Generator                                                |      |
| Fig. 3.16 | Outline of Reset Operation                                           |      |
| Fig. 3.17 | Interrupt-processing Flowchart                                       |      |
| Fig. 3.18 | Memory Map in Various Modes                                          |      |
| Fig. 3.19 | External-access Timing Chart                                         |      |
| Fig. 3.20 | External Peripheral/Memory Connection                                |      |
| Fig. 3.21 | Ready Input Timing Chart (Write Cycle)                               | 3-10 |
| Fig. 3.22 | Ready Generation Circuit                                             | 3-10 |
| Fig. 3.23 | Hold Timing                                                          | 3-11 |

### Tables

| Table 1-1  | Types and Functions of MB89630 Series of Microcontrollers | 1-4  |
|------------|-----------------------------------------------------------|------|
| Table 1-2  | Pin Description                                           | 1-11 |
| Table 1-3  | Pins for External ROM                                     | 1-13 |
| Table 1-4  | Input/Output Circuit Configurations                       | 1-14 |
| Table 2-1  | Table of Reset and Interrupt Vectors                      | 2-4  |
| Table 2-2  | Operating State of Low-power Consumption Modes            | 2-17 |
| Table 2-3  | Sources of Reset                                          | 2-22 |
| Table 2-4  | List of Port Functions                                    | 2-27 |
| Table 2-5  | Port Registers                                            | 2-28 |
| Table 2-6  | PWM Cycle and Resolution                                  | 2-46 |
| Table 2-7  | Selection of Timer/Counter Operation Mode                 | 2-56 |
| Table 2-8  | Operation Modes of UART                                   | 2-67 |
| Table 2-9  | Clock Division Ratio                                      | 2-70 |
| Table 2-10 | Baud Rate Selection                                       | 2-70 |
| Table 2-11 | Buzzer Output Frequencies (at 10 MHz Oscillation)         | 2-90 |
| Table 3-1  | Reset Vector Structure                                    | 3-4  |
| Table 3-2  | Interrupt Sources and Interrupt Vectors                   | 3-7  |
| Table 3-3  | Low-power Consumption Mode at Each Clock Mode             | 3-12 |
| Table 5-1  | Mask Options                                              | 5-3  |

# 1.1 FEATURES 3 1.2 PRODUCT SERIES 4 1.3 BLOCK DIAGRAM. 5 1.4 PIN ASSIGNMENT 6 1.5 PACKAGE DIMENSIONS 8 1.6 PIN DESCRIPTION 11 1.7 HANDLING DEVICES 16



The MB89630 series of single-chip microcontrollers use the F<sup>2</sup>MC-8L CPU core for high-speed processing even at low voltages.

They contain resources such as timers, an UART, serial interfaces, an A/D converter, and an external-inter rupt input; they can be used widely in civil and industrial equipment, including portable equipment.

### **1.1 FEATURES**

- High-speed processing even at low voltages
   Minimum instruction execution time: 0.4 μs at 3.5 V, 0.8 μs at 2.7 V
- F<sup>2</sup>MC-8L CPU core

Instruction system most suited to controller

- Multiplication and division instructions
- 16-bit arithmetic operation
- Instruction test and branch instruction
- Bit manipulation instruction, etc.
- Five types of timers
  - 8-bit PWM timer1 (usable as both reload timer and PWM timer)
  - 8-bit PWM timer2 (usable as both reload timer and PWM timer)
  - 8-bit pulse-width count timer (applicable to continuous measurement and remote control)
  - 16-bit timer/counter
  - 20-bit time-based counter
- UART

Used for CLK synchronous and asynchronous data transfer (6, 7, and 8 bit length)

• Serial interface

The transfer direction can be selected to communicate with various equipments.

- A/D converter
  - 10-bit resolution
  - Starting by external input or continuous start by internal timer
- External-interrupt input
  - Four channels
  - Four channels can be used independently to cancel the low-power consumption modes.
  - An edge-detection function is provided.
- Low-power consumption modes
  - Stop mode (Oscillation stops to minimize the current consumption.)
  - Sleep mode (The CPU stops to reduce the current consumption to about 30% of normal.)
- Bus interface function

Supports Hold and Ready functions

### **1.2 PRODUCT SERIES**

Table 1-1 lists the types and functions of the MB89630 series of microcontrollers.

Table 1.1 Types and Functions of MB89630 Series of Microcontrollers

| Product Name                | MB89635 MB89636                       |                                                                                                                                                                                                                                                                                                                                                                                     | MB89637                                             | MB89T635                                                                                      | MB89P637/W637                                                                  | MB89PV630                                    |  |  |  |  |
|-----------------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|----------------------------------------------|--|--|--|--|
| Classification              |                                       | ss-produced prod<br>lask ROM produ                                                                                                                                                                                                                                                                                                                                                  |                                                     | External ROM<br>product                                                                       | Temporal prod-<br>uct/EPROM                                                    | Piggy back/<br>Evaluation and<br>development |  |  |  |  |
| ROM capacity                | 16K x 8 bits<br>(Internal ROM)        | 24K x 8 bits<br>(Internal ROM)                                                                                                                                                                                                                                                                                                                                                      | 32K x 8 bits<br>(Internal ROM)                      | External ROM only                                                                             | 32K x 8 bits<br>(internal PROM, writ-<br>able by general-pur-<br>pose writers) | 32K × 8 bits<br>(External ROM)               |  |  |  |  |
| RAM capacity                | 512 x 8bit                            | 768 x 8bit                                                                                                                                                                                                                                                                                                                                                                          | 1024 x 8bit                                         | 512 x 8bit                                                                                    | 1024 x 8bit                                                                    | 1024 x 8bit                                  |  |  |  |  |
| CPU function                | Instru<br>Data<br>Minin               | Number of basic instructions         136           Instruction bit length         8 bits           Instruction length         1 to 3 bytes           Data bit length         1, 8, 16 bits           Minimum instruction execution time         0.4 to 6.4 µs at 10 MHz and 61 µs at 32 kHz           Interrupt processing time         3.6 to 57.6 µs at 10 MHz and 562.5 µs at 32 |                                                     |                                                                                               |                                                                                |                                              |  |  |  |  |
| Number of ports             | I/O p<br>Outp                         | ut port (N-ch ope<br>ort (N-ch open dr<br>ut port (CMOS)<br>ort (CMOS)                                                                                                                                                                                                                                                                                                              |                                                     | 5 (5 also used<br>8 (8 also used<br>4 (4 also used<br>8 (8 also used<br>28 (27 also use<br>53 | as resources)                                                                  | and resources)                               |  |  |  |  |
| PWM timer                   | 8-bit reload tim<br>7/8-bit resolutio | er operation (tog<br>n PWM operatio                                                                                                                                                                                                                                                                                                                                                 | gle output possibi<br>n (conversion cyc             | e, operating cloc<br>ie: 51.2 μs to 83                                                        | k cycle: 0.4 μs to 3<br>9 ms) × 2 ch                                           | .3 ms) × 2 ch                                |  |  |  |  |
| Pulse-width<br>count timer  | 8-bit reload tim<br>8-bit pulse-widt  | er operation (tog<br>h measurement                                                                                                                                                                                                                                                                                                                                                  | gle output possible operation                       | e, operating cloc                                                                             | tile: 0.4 μs to 12.8 μ<br>k cycle: 0.4 μs to 1<br>om † to † and from           | 2.8 µs)                                      |  |  |  |  |
| Timer/counter               |                                       |                                                                                                                                                                                                                                                                                                                                                                                     | clock cycle: 0.4<br>selectable from ris             |                                                                                               | edge, or both edge                                                             | s)                                           |  |  |  |  |
| Serial I/O                  |                                       | least significant<br>external, 0.8 μs,                                                                                                                                                                                                                                                                                                                                              | bit (LSB) first or<br>3.2 μs, 12.8 μs)              | most significant t                                                                            | oit (MSB) first                                                                |                                              |  |  |  |  |
| UART                        | Transfer data le                      | ngth: 6, 7, 8 bits                                                                                                                                                                                                                                                                                                                                                                  | software switchin<br>at original oscilla            | •                                                                                             | 1                                                                              |                                              |  |  |  |  |
| A/D converter               | Sense mode (c                         | mode (conversion<br>onversion time:                                                                                                                                                                                                                                                                                                                                                 | on time: 13.2 μs)<br>7.2 μs)<br>tinuous start by ir |                                                                                               |                                                                                |                                              |  |  |  |  |
| External-interrupt<br>input | Selectable from                       | Four independent channels (edge selection, interrupt vector, factor flag)<br>Selectable from rising or falling edge<br>Used for clearing stop or sleep mode (The edge can be detected even in the stop mode.)                                                                                                                                                                       |                                                     |                                                                                               |                                                                                |                                              |  |  |  |  |
| Standby mode                |                                       | s                                                                                                                                                                                                                                                                                                                                                                                   | leep mode, stop                                     | mode, and watch                                                                               | mode                                                                           |                                              |  |  |  |  |
| Process                     |                                       |                                                                                                                                                                                                                                                                                                                                                                                     | c                                                   | MOS                                                                                           |                                                                                |                                              |  |  |  |  |
| Package                     |                                       | MDP-64C-P02<br>MQP-64C-P01                                                                                                                                                                                                                                                                                                                                                          |                                                     |                                                                                               |                                                                                |                                              |  |  |  |  |
| Operating voltage           |                                       | 2.2 V to 6.0 V* 2.7 V to 6.0 V*                                                                                                                                                                                                                                                                                                                                                     |                                                     |                                                                                               |                                                                                |                                              |  |  |  |  |
| EPROM used                  |                                       |                                                                                                                                                                                                                                                                                                                                                                                     |                                                     |                                                                                               |                                                                                | MBM27C256A-20                                |  |  |  |  |

\* Varies according to conditions such as frequency. (See Recommended Operating Conditions, page 14.)

### **1.3 BLOCK DIAGRAM**



Fig. 1.1 Block Diagram (MB89635)

### **1.4 PIN ASSIGNMENT**



\* When double clock module is selected.





\* When double clock module is selected.

Fig. 1.3 Pin Assignment (FPT-64P-M09)



\* When double clock module is selected.

| Pin No. | Pin Name |
|---------|----------|---------|----------|---------|----------|---------|----------|
| 65      | N.C.     | 73      | AD2      | 81      | N.C.     | 89      | ŌE       |
| 66      | Vpp      | 74      | AD1      | 82      | 04       | 90      | N.C.     |
| 67      | A12      | 75      | ADO      | 83      | 05       | 91      | A11      |
| 68      | AD7      | 76      | N.C.     | 84      | 06       | 92      | A9       |
| 69      | AD6      | 77      | 01       | 85      | 07       | 93      | A8       |
| 70      | AD5      | 78      | 02       | 86      | 08       | 94      | A13      |
| 71      | AD4      | 79      | 03       | 87      | CE       | 95      | A14      |
| 72      | AD3      | 80      | VSS      | 88      | A10      | 96      | Voc      |

Pin assignment on top of package (only for piggyback/evaluation type)

Note: N.C.: Non-connection pin

| Fig. 1.4 | Pin Assignment | (MQP-64C-P01 | and FPT-64P-M06) |
|----------|----------------|--------------|------------------|
|          | - J - 1        |              |                  |

### **1.5 PACKAGE DIMENSIONS**

Fig. 1.5 Package dimension



Fig. 1.6 Package dimension (QFP)

1-9

Fig. 1.7 Package dimension (MB89PV630)

### **1.6 PIN DESCRIPTION**

Tables 1-2 and 1-3 list the pin functions and Table 1-4 shows the input/output circuits.

| Pin No.         |                 |                          | Circuit |                                                                                                                                                                                                                       |  |
|-----------------|-----------------|--------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DIP-<br>64P-M01 | FPT-<br>64P-M09 | Pin Name                 | type    | Function                                                                                                                                                                                                              |  |
| 30              | 22              | X0                       |         | Crystal oscillator pins                                                                                                                                                                                               |  |
| 31              | 23              | X1                       | 1 ^     |                                                                                                                                                                                                                       |  |
| 28              | 20              | MOD0                     | c       | Operation-mode select pins                                                                                                                                                                                            |  |
| 29              | 21              | MOD1                     | 1 ັ     | These pins are connected directly to V <sub>CC</sub> or V <sub>SS</sub> .                                                                                                                                             |  |
| 27              | 19              | RST                      | в       | Reset I/O pin<br>This pin consists of an N-ch open-drain output with a pull-up resistor and hysteresis<br>input. A Low level is output from this pin. The internal circuit is initialized at input of<br>a Low level. |  |
| 56 to 49        | 48 to 41        | P00/AD0<br>to<br>P07/AD7 | E       | General-purpose I/O ports<br>When the external bus is used, these ports also serve as multiplex pins for output of<br>lower addresses and data input/output.                                                          |  |
| 48 to 41        | 40 to 33        | P10/A08<br>to<br>P17/A15 | E       | General-purpose I/O ports<br>When the external bus is used, these ports also serve as pins for output of upper<br>addresses.                                                                                          |  |
| 40              | 32              | P20/BUFC                 | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as a buffer-control output pin by<br>setting BCTR.                                                                           |  |
| 39              | 31              | P21/HAK                  | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as a hold-acknowledge pin by<br>setting BCTR.                                                                                |  |
| 38              | 30              | P22/HRQ                  | E       | General-purpose output-only port<br>When the external bus is used, this port also serves as a hold-request input pin by<br>setting BCTR.                                                                              |  |
| 37              | 29              | P23/RDY                  | E       | General-purpose output-only port<br>When the external bus is used, this port also serves as a ready-input                                                                                                             |  |
| 36              | 28              | P24/CLK                  | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as a clock-output pin.                                                                                                       |  |
| 35              | 27              | P25/WR                   | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as a write-signal output pin.                                                                                                |  |
| 34              | 26              | P26/RD                   | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as a read-signal output pin.                                                                                                 |  |
| 33              | 25              | P27/ALE                  | G       | General-purpose output-only port<br>When the external bus is used, this port also serves as an address-latch signal-<br>output pin.                                                                                   |  |
| 2               | 58              | P30/UCK1                 | F       | General-purpose I/O port<br>This port also serves as a clock I/O pin1 for the UART.<br>Input is hysteresis type.                                                                                                      |  |
| 1               | 57              | P31/UO1                  | E       | General-purpose I/O port<br>This port also serves as a data output pin1 for UART.                                                                                                                                     |  |

### Table 1.2 Pin Description

Table 1-2 Pin Description (Continued)

| Pin No.         |               |                                    | Girquit |                                                                                                                                                                                                |
|-----------------|---------------|------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIP-<br>64P-M01 | P-M01 64P-M09 |                                    | type    | Function                                                                                                                                                                                       |
| 63              | 55            | P32/UI1                            | F       | General-purpose I/O port<br>This port also serves as a data-input pin 1 for the UART. Input is hysteresis type.                                                                                |
| 62              | 54            | P33/SCK1                           | F       | General-purpose I/O port<br>This port also serves as a data-input pin for serial I/O. Input is hysteresis type.                                                                                |
| 61              | 53            | P34/SO1                            | E       | General-purpose I/O port<br>This port also serves as a data-output pin for serial I/O.                                                                                                         |
| 60              | 52            | P35/SI1                            | F       | General-purpose I/O port<br>This port also serves as a data-input pin for serial I/O. Input is hysteresis type.                                                                                |
| 59              | 51            | P36/PWC                            | F       | General-purpose I/O port<br>This port also serves as a measured-pulse input pin for the 8-bit pulse-width<br>counter. Input is hysteresis type.                                                |
| 58              | 50            | P37/WTO                            | E       | General-purpose I/O port<br>This port also serves as a toggle output pin for the 8-bit pulse-width counter.                                                                                    |
| 6               | 62            | P40/UCK2                           | F       | General-purpose I/O port<br>This port also serves as a clock I/O pin 2 for UART. Input is hysteresis type.                                                                                     |
| 5               | 61            | P41/UO2                            | E       | General-purpose I/O port<br>This port also serves as a data-output pin 2 for UART.                                                                                                             |
| 4               | 60            | P42/UI2                            | F       | General-purpose I/O port<br>This port also serves as a data-input pin 2 for UART. Input is hysteresis type.                                                                                    |
| 3               | 59            | P43/PT01                           | E       | General-purpose I/O port<br>This port also serves as a toggle output pin for the 8-bit PWM timer.                                                                                              |
| 10              | 2             | P50/ADST                           | J       | General-purpose I/O port<br>This port also serves as an external activation pin for the A/D converter. Input is<br>hysteresis type.                                                            |
| 9               | 1             | P51/8Z                             | 4       | General-purpose I/O port<br>This port also serves as a buzzer output pin.                                                                                                                      |
| 8               | 64            | P52                                | I       | General-purpose I/O port                                                                                                                                                                       |
| 7               | 63            | P53/PTO2                           | 1       | General-purpose I/O port<br>This port also serves as a toggle output pin for the 8-bit PWM timer.                                                                                              |
| 11 to 18        | 3 to 10       | P60/AN0 to<br>P67/AN7              | н       | N-ch open-drain output-only ports<br>These ports also serve as analog input pins for the A/D converter.                                                                                        |
| 26 to 25        | 18 to 17      | P70/INT0/X1A<br>to<br>P71/INT1/X0A | A/D     | Input-only ports<br>Input is hysteresis type. These ports also serve as input pins for external interrupt (at<br>single clock operation). Crystal oscillation pins (at double clock operation) |
| 24 to 23        | 16 to 15      | P72/INT2 to<br>P73/INT3            | D       | Input-only ports<br>These ports also serve as input pins for external interrupt. Input is hysteresis type.                                                                                     |
| 22              | 14            | P74/EC                             | D       | General-purpose input port<br>This port also serves as an external clock input pin for the 16-bit timer counter.<br>Input is hysteresis type.                                                  |
| 64              | 56            | Vcc                                | -       | Power pin                                                                                                                                                                                      |
| 32, 57          | 24, 49        | V <sub>SS</sub>                    |         | Power (GND) pins                                                                                                                                                                               |
| 19              | 11            | AV <sub>CC</sub>                   | -       | Power pin for A/D converter                                                                                                                                                                    |
| 20              | 12            | AVR                                | -       | Reference-voltage input pin for A/D converter                                                                                                                                                  |
| 21              | 13            | AV <sub>SS</sub>                   | -       | Power pin for A/D converter<br>It should be used at the same potential at V <sub>SS</sub> .                                                                                                    |

| Table 1.3 | Pins for | External | ROM |
|-----------|----------|----------|-----|
|-----------|----------|----------|-----|

| Pin No.                                            |                                              |                                                     | Circuit |                                                                                                        |  |
|----------------------------------------------------|----------------------------------------------|-----------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------|--|
| DIP-<br>64C-P02                                    | FPT-<br>64C-P01                              | Pin Name                                            | type    | Punction                                                                                               |  |
| 65                                                 | 66                                           | Vpp                                                 | Output  | High-level output pin                                                                                  |  |
| 66<br>67<br>68<br>69<br>70<br>71<br>72<br>73<br>74 | 67<br>68<br>70<br>71<br>72<br>73<br>74<br>75 | A12<br>A7<br>A6<br>A5<br>A4<br>A3<br>A2<br>A1<br>A0 | Output  | Address-output pins                                                                                    |  |
| 75<br>76<br>77                                     | 77<br>78<br>79                               | 01<br>02<br>03                                      | Input   | Data-input pins                                                                                        |  |
| 78                                                 | 80                                           | Vss                                                 | Output  | GND pin                                                                                                |  |
| 79<br>80<br>81<br>82<br>83                         | 82<br>83<br>84<br>85<br>86                   | 04<br>05<br>06<br>07<br>08                          | Input   | Data-input pins                                                                                        |  |
| 84                                                 | 87                                           | CE                                                  | Output  | Chip-enable pin for ROM<br>A High level is output in the standby mode.                                 |  |
| 85                                                 | 88                                           | A10                                                 | Output  | Address-output pin                                                                                     |  |
| 86                                                 | 89                                           | OE                                                  | Output  | Output-enable pin for ROM<br>A Low level is always output.                                             |  |
| 87<br>88<br>89                                     | 91<br>92<br>93                               | A11<br>A9<br>A8                                     | Output  | Address-output pins                                                                                    |  |
| 90                                                 | 94                                           | A13                                                 | Output  | Address-output pins                                                                                    |  |
| 91                                                 | 95                                           | A14                                                 | Output  | Address-output pins                                                                                    |  |
| 92                                                 | 96                                           | Voc                                                 | Output  | Power pin for EPROM                                                                                    |  |
|                                                    | 65<br>76<br>81<br>90                         | N.C.                                                | -       | Non-connection pins which have internal-connection<br>These pins must be open when the device is used. |  |

| Classification | Circuit                                                                          | Remarks                                                                                                        |
|----------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| A              | X1<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0<br>X0 | Oscillation feedback resistor: About 2 MΩ     ŢMain clock side)                                                |
| в              |                                                                                  | <ul> <li>Output pull-up resistor (P-ch): About 50 kΩ (5 V)</li> <li>Hysteresis input</li> </ul>                |
| С              |                                                                                  | CMOS input                                                                                                     |
| D              |                                                                                  | <ul> <li>Hysteresis input</li> <li>The pull-up resistor is optional.<br/>(P70 and P71 are excluded)</li> </ul> |
| E              |                                                                                  | CMOS output     CMOS input     The pull-up resistor is optional.     (P22 and P23 are excluded)                |
| F              |                                                                                  | CMOS output     Hysteresis input     The pull-up resistor is optional.                                         |
| G              |                                                                                  | CMOS output                                                                                                    |

### Table 1.4 Input/Output Circuit Configurations



| Classification | Circuit      | Remarks                                                                         |
|----------------|--------------|---------------------------------------------------------------------------------|
| н              | Analog input | Analog input                                                                    |
| I              |              | CMOS input     The pull-up resistor is optional.                                |
| J              |              | <ul> <li>Hysteresis input</li> <li>The pull-up resistor is optional.</li> </ul> |

### Table 1-4 Input/Output Circuit Configurations (Continued)

### **1.7 HANDLING DEVICES**

(1) Prevention of latch-up

In the CMOS IC, latch-up may occur when a voltage higher than  $V_{CC}$  or lower than  $V_{SS}$  is applied to other than the middle- or high-voltage resistant input or output pins, or when voltage exceeding the Absolute Maximum Ratings is applied between  $V_{CC}$  and  $V_{SS}$  pins.

When latch-up occurs, the supply current increases rapidly, sometimes resulting in overheating and destruction. Therefore, no voltage exceeding the Absolute Maximum Ratings should be used.

(2) Unused input pins

Leaving unused input pins open may cause a malfunction. Therefore, these pins should be pulled up or down with optional resistors in the Input/Output circuits. If the Input/Output circuit has no optional resistor, an exter nal resistor should be used.

(3) Non-Connected pins which have internal-connection (N.C.) Non-Connected pins which have internal-connection (N.C.) must be open when the device is used.

(4) Variations in supply voltage

Some malfunction may be caused by an abrupt change of the power supply voltage even though the voltage is in the guaranteed range. For this reason, the power supply to the device should be stabilized. For the stabi lization, it is recommended to keep the power supply for the V<sub>CC</sub> ripple voltage regulation (peak-to-peak) to less than 10% of the typical V<sub>CC</sub> at the commercial frequency (50 to 60 Hz), and the coefficient of transitional variation should be less than 0.1 V/ms at a sudden supply voltage change (e.g. voltage switching).

(5) Precautions for external clock

It may take a little time to stabilize the clock oscillation. The stabilization time should also be considered for an external clock during resets because all internal circuits in the device need to be initialized. So, an external clock should be input just after power-on reset (option selection) and cancellation of stop mode.

(6) Pin processing performed when A/D converter not used When the A/D converter is not used, the pins should be connected to be AVcc = Vcc.

When the A/D converter is not used, the pins should be connected to be AVcc = Vcc, and AVss = AVR = AVss.

(7) Recommended screening conditions

The OTPROM product should be screened by high-temperature aging before mounting.



Yield of preprogrammed product

The programming test cannot be performed for all bits of the preprogrammed OTPROM product due to its characteristics. Consequently, 100% yield of programming cannot be ensured.

### 2. HARDWARE CONFIGURATION

| 2.1 | CPU2-3                 |
|-----|------------------------|
| 2.2 | RESOURCE FUNCTIONS2-27 |

### 2.1 CPU

This section describes the CPU hardware composition. The CPU has the following six functions.

- Memory Space
- Arrangement of 16-bit Data in Memory
- Registers
- Operation Modes and External Bus Operation
- Clock Control Block
- Interrupt Controller

### 2.1.1 Memory Space

The MB89630 series of microcontrollers have a memory area of 64 Kbytes. All I/O, data, and program areas are located in this space. The I/O area is near the lowest address and the data area is immediately above it. The data area may be divided into register, stack, and direct-address areas according to the applications. The program area is located near the highest address and the tables of interrupt and reset vectors and vector-call instructions are at the highest address. Figure 2.1 shows the structure of the memory space for the MB89630 series of microcontrollers.



**Note:** This ROM space can be used for external data in mode operation. The ROMs of the MB89W637 and MB89P637 are internal OTPROMs. The ROM space is from  $8007_{\rm H}$  to FFFF<sub>H</sub>.

### Fig. 2.1 Memory Space of MB89630 Series of Microcontrollers

### (1) I/O area

This area is where various resources such as control and data registers are located. The memory map for the I/O area is given in Appendix 1.

(2) RAM area

This area is where the static RAM is located. Addresses from  $0100_{\text{H}}$  to  $01FF_{\text{H}}$  are also used as the general-purpose register area.

(3) External area

When data is read and written from and to this area with the external-bus function specified, the external de vice is accessed via ports 0, 1, and 2. Examples of expanding the external memory and peripheral resources by using the external-bus pins are described in 3.4 Memory Access Modes.

### (4) ROM area

This area is where the internal ROM is located. Addresses from  $FFCO_{H}$  to  $FFFF_{H}$  are also used for the tables of interrupt and reset vectors and vector-call instructions. Table 2-1 shows the correspondence between each interrupt number or reset and the table addresses to be referenced for the MB89630 series of microcon trollers.

|          | Table address     |                   |  |  |  |  |  |
|----------|-------------------|-------------------|--|--|--|--|--|
|          | Upper data        | Lower data        |  |  |  |  |  |
| CALLV #0 | FFC0 <sub>H</sub> | FFC1 <sub>H</sub> |  |  |  |  |  |
| CALLV #1 | FFC2 <sub>H</sub> | FFC3 <sub>H</sub> |  |  |  |  |  |
| CALLV #2 | FFC4 <sub>H</sub> | FFC5 <sub>H</sub> |  |  |  |  |  |
| CALLV #3 | FFC6 <sub>H</sub> | FFC7 <sub>H</sub> |  |  |  |  |  |
| CALLV #4 | FFC8 <sub>H</sub> | FFC9 <sub>H</sub> |  |  |  |  |  |
| CALLV #5 | FFCA <sub>H</sub> | FFCB <sub>H</sub> |  |  |  |  |  |
| CALLV #6 | FFCCH             | FFCD <sub>H</sub> |  |  |  |  |  |
| CALLV #7 | FFCEH             | FFCFH             |  |  |  |  |  |

Table 2.1 Table of Reset and Interrupt Vectors

|               | Table a                               | ddress            |
|---------------|---------------------------------------|-------------------|
|               | Upper data                            | Lower data        |
| Interrupt #11 | FFE4 <sub>H</sub>                     | FFE5 <sub>H</sub> |
| Interrupt #10 | FFE6 <sub>H</sub>                     | FFE7 <sub>H</sub> |
| Interrupt #9  | FFE8 <sub>H</sub>                     | FFE9 <sub>H</sub> |
| Interrupt #8  | FFEA <sub>H</sub>                     | FFEB <sub>H</sub> |
| Interrupt #7  | FFECH                                 | FFED <sub>H</sub> |
| Interrupt #6  | FFEEH                                 | FFEFH             |
| Interrupt #5  | FFF0 <sub>H</sub>                     | FFF1 <sub>H</sub> |
| Interrupt #4  | FFF2 <sub>H</sub>                     | FFF3 <sub>H</sub> |
| Interrupt #3  | FFF4 <sub>H</sub>                     | FFF5 <sub>H</sub> |
| Interrupt #2  | FFF6 <sub>H</sub>                     | FFF7 <sub>H</sub> |
| Interrupt #1  | FFF8 <sub>H</sub>                     | FFF9 <sub>H</sub> |
| Interrupt #0  | FFFA <sub>H</sub>                     | FFFB <sub>H</sub> |
| Reset mode    | · · · · · · · · · · · · · · · · · · · | FFFD <sub>H</sub> |
| Reset vector  | FFFE <sub>H</sub>                     | FFFFH             |

Note: FFFC<sub>B</sub> is already reserved.

### 2.1.2 Arrangement of 16-bit Data in Memory

When the MB89630 series of microcontrollers handle 16-bit data, the data written at the lower address is treated as the upper data and that written at the next address is treated as the lower data as shown in Figure 2.2.



Fig. 2.2 Arrangement of 16-bit Data in Memory

This is the same as when 16 bits are specified by the operand during execution of an instruction. Bits closer to the OP code are treated as the upper byte and those next to it are treated as the lower byte. This is also the same when the memory address or 16-bit immediate data is specified by the operand.

### Fig. 2.3 Arrangement of 16-bit Data during Execution of Instruction

Data saved in the stack by an interrupt is also treated in the same manner.

### 2.1.3 Internal Registers in CPU

The MB89630 series of microcontrollers have dedicated registers in the CPU, and general-purpose registers in memory.

<Dedicated registers>

- Program counter (PC) ........... 16-bit long register indicating location where instructions stored
- Accumulator (A) ......16-bit long register where results of operations stored temporarily; the lower byte is used to execute 8-bit data processing instructions.
- Temporary accumulator (T) ... 16-bit long register; the operations are performed between this register and the accumulator. The lower one byte is used to execute 8-bit data processing instructions
- Stack pointer (SP) ...... 16-bit long register indicating stack area
- Processor status (PS) ...........16-bit long register where register pointers and condition codes stored
- Index register (IX)......16-bit long register for index modification
- Extra pointer (EP).....16-bit long register for memory addressing

| 16 bits |                       | Initial value                            |
|---------|-----------------------|------------------------------------------|
| PC      | Program counter       | FFFDH                                    |
| A       | Accumulator           | Undefined                                |
| Т       | Temporary accumulator | Undefined                                |
| IX      | Index register        | Undefined                                |
| EP      | extra pointer         | Undefined                                |
| SP      | Stack pointer         | Undefined                                |
| PS      | Program status        | l flag = 0, IL1, 0 = 1.1                 |
|         |                       | All others than the above are undefined. |

The 16 bits of the program status (PS) can be divided into 8 upper bits for a register bank pointer (RP) and 8 lower bits for a condition code register (CCR). (See Figure 2.4.)





The RP indicates the address of the current register bank and the contents of the RP; the real addresses are translated as shown in Figure 2.5.

|                |     |     |     |     |            |     |     |     |    |    | RΡ |    | Lo | wer b | its of | OP of | ode |
|----------------|-----|-----|-----|-----|------------|-----|-----|-----|----|----|----|----|----|-------|--------|-------|-----|
|                | '0' | .0, | '0' | '0' | <b>'0'</b> | .0, | .0, | '1' | R4 | R3 | R2 | R1 | R0 | b2    | b1     | ь0    | 1   |
|                | ÷.  | ŧ   | ÷.  | ÷   | ŧ          | ŧ   | ÷   | ÷   | ŧ  | ÷  | .+ | ŧ  | ŧ  | ÷     | ÷      | ŧ     |     |
| Source address | A15 | A14 | A13 | A12 | A11        | A10 | A9  | A8  | A7 | A6 | A5 | A4 | A3 | A2    | A1     | A0    | ]   |

### Fig. 2.5 Rule for Translating Real Addresses at General-purpose Register Area

The CCR has bits indicating the results of operations and transfer data contents, and bits controlling the CPU operation when an interrupt occurs.

- H-flag: ......H-flag is set when a carry or a borrow out of bit 3 into bit 4 is generated as a result of operations; it is cleared in other cases. This flag is used for decimal-correction instructions.
- I-flag:.....An interrupt is enabled when this flag is 1 and is disabled when it is 0. The I-flag is 0 at reset.
- IL1 and IL0:...These bits indicate the level of the currently-enabled interrupt. The CPU executes interrupt processing only when an interrupt with a value smaller than the value indicated by this bit is requested.

| IL1 | IL0 | Interrupt level | High and low       |
|-----|-----|-----------------|--------------------|
| 0   | 0   | 1               | High               |
| 0   | 1   |                 | 1                  |
| 1   | 0   | 2               |                    |
| 1   | 1   | 3               | Low = No interrupt |

- N-flag: .....The N-flag is set when the most significant bit is 1 as a result of operations; it is cleared when the MSB is 0.
- Z-flag:.....Z-flag is set when the bit is 0 as a result of operations; it is cleared in other cases.
- V-flag:.....V-flag is set when a two's complement overflow occurs as a result of operations; it is reset when an overflow does not occur.
- C-flag: .....C-flag is set when a carry or a borrow out of bit 7 is generated as a result of operations; it is cleared in other cases. When the shift instruction is executed, the value of the C-flag is shifted out.

<General-purpose registers>

General-purpose registers are 8-bit long registers for storing data.

The 8-bit long general-purpose registers are in the register banks in memory. One bank has eight registers and up to 32 banks are available for the MB89630 series of microcontrollers. The register bank pointer (RP) indicates the currently-used bank.



Fig. 2.6 Register Bank Configuration



### 2.1.4 Operation Modes and External Bus Operation

The MB89630 series of microcontrollers have the following three operation modes.

- (1) Single-chip mode
- (2) External-ROM mode
- (3) External-access internal-ROM mode

The memory map for each mode is as follows:



\*: MB89635 Address values. For the addresses of each product in the MB89630 series, see 2.1.1.

### Fig. 2.7 Memory Maps in Various Modes

The mode that the device enters depends on the states of the device-mode pins and the contents of the mode data fetched during the reset sequence. The relationship between the states and operations of the device-mode pins is shown below.

| MOD1 | MOD0 | Description                                                                                                          |
|------|------|----------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Reset vectors are read from the internal ROM. The operation mode is determined according to the modde data contents. |
| 0    | 1    | Reset vectors are read from the external ROM. The external access functions.                                         |
| 1    | 0    | Reserved for future expansion and testing.                                                                           |
| 1    | 1    | Write mode for products containing EPROM.                                                                            |

The following functions are selected according to the mode-data setting conditions.

| Address: FFFDH |  | ۲ | ۲     | 8      | T2   | T1 | TO  | ®: Reserved: Specify 0. |
|----------------|--|---|-------|--------|------|----|-----|-------------------------|
|                |  |   |       |        | _    | ~_ | _   | Mode bits               |
|                |  |   | T2    | T2     | T2   |    |     | Operation               |
|                |  |   | 0     | 0      | 0    |    | Sel | ect single-chip mode.   |
|                |  |   | 0     | 0      | 1    |    | Ext | ernal access allowed.   |
|                |  |   | Other | than a | bove |    | Re  | served. Do not set.     |

**Note:** Do not select the single-chip mode with the externally-fetched mode data.

As shown in the flowchart below, each mode is set according to the status of the device-mode pins and the contents of the mode data fetched during the reset sequence.

| Setting procedure    | Mode selected                     | Mode pin | Mode data  |  |  |
|----------------------|-----------------------------------|----------|------------|--|--|
| (2)→(4)→(6)          | Single-chip mode                  | 00       | XXXXXX000  |  |  |
| (1)→(3)→ *(5) or (6) | External-ROM mode                 | 01       | XXXXXX001  |  |  |
| (2)→(4)→ *(5) or (6) | External-access internal-ROM mode | 00       | XXXXXXX001 |  |  |



When the external-bus function is used, the following pins become active at default.

A, AD, RD, WR, ALE, CLK, RDY, and BUFC

The external-bus pin-control register (BCTR) is used to switch the function of the pin controlling the external bus for port 2 in the external-bus mode. When either of the bits is set to 0, the pin corresponding to the bit serves as the port. In the single-chip mode, the contents of both bits are ignored and all 8 bits of port 2 serve as parallel ports. Access to this register is not allowed in modes other than the external-bus mode. The structure of the BCTR is as follows:

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|---------------|
| Address: 0005 <sub>H</sub> |       |       | -     | _     | _     | -     | HLD   | BUF   | XXXX XX01B    |
|                            |       |       |       |       |       |       | (W)   | (W)   |               |

[Bit 1] HLD: Hold-enable bit. Bit 1 is used to enable the holding operation.

| 0 | In external-bus mode, P21 and P22 serve as ports.                         |
|---|---------------------------------------------------------------------------|
| 1 | In external-bus mode, P21 used for HAK output and P22 used for HRQ input. |

[Bit 0] BUF: BUFC-operation enable bit. Bit 0 is used to enable the operation of the BUFC pin.

| 0 | In external-bus mode, P20 serves as port.       |  |
|---|-------------------------------------------------|--|
| 1 | In external-bus mode, P20 used for BUFC output. |  |

| Pin name   | Shingle chip | External Access   |                                                                                              |
|------------|--------------|-------------------|----------------------------------------------------------------------------------------------|
| P00 to P07 | P00 to P07   | AD7 to AD0        |                                                                                              |
| P17        | P17          | A15               |                                                                                              |
| P16        | P16          | A14               |                                                                                              |
| P15        | P15          | A13               |                                                                                              |
| P14        | P14          | A12               |                                                                                              |
| P13        | P13          | A11               |                                                                                              |
| P12        | P12          | A10               | Meaning of each signal                                                                       |
| P11        | P11          | A09               | AD0 to AD7: Address/data multiplex bus                                                       |
| P10        | P10          | A08               | A08 to A15: Address bus                                                                      |
| P27        | P27          | ALE               | ALE: Address-latch enable<br>RD: Read strobe (Active at L)<br>WR: Write strobe (Active at L) |
| P26        | P26          | RD                |                                                                                              |
| P25        | P25 P25 WR   | CLK: Clock output |                                                                                              |
| P24        | P24          | CLK               | RDY: Bus-ready input (Wait at L)                                                             |
| P23        | P23          | RDY               | HRQ: Hold request<br>HAK: Hold-acknowledge output (Active at L)                              |
| P22        | P22          | HRQ               | BUFC: Buffer control                                                                         |
| P21        | P21          | HAK               |                                                                                              |
| P20        | P20          | BUFC              | Note: RD, WR, and BUFC are not output when<br>the address indicates the internal area.       |

The states of the bus pins in each mode are as follows:

The timing concept for external access is shown below. Refer to the AC standard for details.



Note: The read cycle of the RDY signal is prolonged in the same manner as the write cycle.

RDY is an signal to execute the Ready function. When a Low level is input for RDY, the bus cycle is prolonged in CLK cycle. Fetching is carried out near the rising edge of the CLK signal. To prolong the bus cycle, set the RDY signal to Low before the rising edge of the CLK signal. When the ready function is not used in the external bus mode, the RDY pin should be pulled up.

The HRQ and HAK signals are used for the hold function. To obtain the external bus, set the HRQ signal to High. After that, the CPU recognizes the bus request between instructions to stop operation and sets the HAK signal to Low after waiting one half cycle. It signals the outside that the bus is open in this way. When another device terminates use of the bus, set the HRQ signal to Low to notify the CPU. When the CPU detects the Low level of the HRQ signal, it sets the HAK signal to High and starts using the external bus after waiting one half cycle. The hold function timing concept is diagram shown below.



# 2.1.5 Clock Control Block

This block controls the standby operation, oscillation stabilization time, software reset, and clock switching.

(1) Register list



- (2) Block diagram
- (a) Machine clock control section



(b) Reset control section



(3) Description of registers

(a) STBC (Standby-conrol register)

|                            | Bit 7 |     |       |     | Bit 3 |   |   | Bit 0 | Initial value |
|----------------------------|-------|-----|-------|-----|-------|---|---|-------|---------------|
| Address: 0008 <sub>H</sub> | STP   | SLP | SPL   | RST | TMD   | - | - |       | 0001 0XXXB    |
|                            | (W)   | (W) | (R/W) | (W) | (W)   |   |   |       |               |

[Bit 7] STP: Stop bit

Bit 7 specifies switching to the stop mode.

| 0 | No operation |
|---|--------------|
| 1 | Stop mode    |

This bit is cleared at reset or stop cancellation.

0 is always read when this bit is read.

#### [Bit 6] SLP: Sleep bit

Bit 6 specifies switching to the sleep mode.

| 0 | No operation |
|---|--------------|
| 1 | Sleep mode   |

This bit is cleared at reset or stop cancellation.

0 is always read when this bit is read.

[Bit 5] SPL: Pin state specifying bit

Bit 5 specifies the external pin state in the watch or stop mode.

When the pins for which "Pull-up resistor provided" is specified in the mask option enter the stop mode with SPL = 1, they are pulled up rather than having high impedance.

| 0 | A 4-instruction-cycle reset signal is generated. |  |  |  |  |  |  |
|---|--------------------------------------------------|--|--|--|--|--|--|
| 1 | High impedance                                   |  |  |  |  |  |  |

This bit is cleared at resetting.

[Bit 4] RST: Software reset bit

Bit 4 resets the software.

| 0 | Generate 4-cycle reset signal (6.4 µs at 10 MHz) |  |  |  |  |  |  |  |
|---|--------------------------------------------------|--|--|--|--|--|--|--|
| 1 | No operation                                     |  |  |  |  |  |  |  |

1 is always read when this bit is read.

If a software reset is performed during operation in a submode, one oscillation stabilization period is re quired to switch to the main mode. Therefore, a reset signal is output during the oscillation stabilization period.

## [Bit 3] TMD: Watch bit

Bit 3 specifies switching to the watch mode.

| 0 | No operation |
|---|--------------|
| 1 | Watch mode   |

Writing at this bit is possible only in the submode (SCS = 0). 0 is always read when this bit is read. This bit is cleared at an interrupt request or reset.

## (b) System clock control register (SYCC)

|                            |     |   |   | Bit 4 |     |     |       |     | Initial value        |
|----------------------------|-----|---|---|-------|-----|-----|-------|-----|----------------------|
| Address: 0007 <sub>H</sub> | SCM | - | _ | WT1   | WT0 | SCS | CS1   | CS0 | XM M100 <sub>B</sub> |
|                            | (R) |   |   |       |     |     | (R/W) |     |                      |

## [Bit 7] SCM: System clock monitor bit

Bit 7 checks whether the current system clock is the main clock or subclock.

| 0 | Subclock (Main clock is stopping or oscillation of main clock stable) |  |  |  |  |  |  |
|---|-----------------------------------------------------------------------|--|--|--|--|--|--|
| 1 | Main clock                                                            |  |  |  |  |  |  |

## [Bits 4 and 3] WT1 and WT0: Oscillation stabilization time select bits

Bits 4 and 3 select the oscillation stabilization wait time of the main clock.

| WT1 | WT0 | Oscillation stabilization time  | Oscillation stabilization time at<br>original oscillation of 10 MHz |
|-----|-----|---------------------------------|---------------------------------------------------------------------|
| 1   | 1   | Approximate 218/fch             | Approximate 26.2 (ms)                                               |
| 1   | 0   | Approximate 217/fch             | Approximate 13.1 (ms)                                               |
| 0   | 1   | Approximate 214/fch             | Approximate 1.6 (ms)                                                |
| 0   | 0   | Approximate 2 <sup>4</sup> /fch | Approximate 0 (ms)                                                  |

fch: Oscillation frequency of main clock

If the main mode is specified by the system clock select bit (SCS), the mode switches to main mode after the selected wait time has elapsed.

The initial value of this bit is determined by the mask option. Do not rewrite this bit during the oscillation stabilization period nor rewrite it concurrently with switching from low speed to high speed.

The oscillation stabilization time of the main clock is generated by dividing down the frequency of the main clock. Since the oscillation frequency is unstable immediately after oscillation starts, use the above table.

## [Bit 2] SCS: System clock select bit

Bit 2 selects the system clock mode.

| 0 | Selects subclock (32 kHz) mode   |  |  |  |  |  |  |
|---|----------------------------------|--|--|--|--|--|--|
| 1 | Selects main clock (10 MHz) mode |  |  |  |  |  |  |

[Bits 1 and 0] CS1 and CS0: System clock select bits

If the main mode is specified by the system clock select bit (SCS), the system clock is as given in the table below.

| CS1 | CS0 | Instruction cycle | Minimum instruction execu-<br>tion time at 10 MHz |
|-----|-----|-------------------|---------------------------------------------------|
| 0   | 0   | 64/fch            | 6.4 (µS)                                          |
| 0   | 1   | 16/fch            | 1.6 (µs)                                          |
| 1   | 0   | 8/fch             | 0.8 (µs)                                          |
| 1   | 1   | 4/fch             | 0.4 (µs)                                          |

fch: frequency of main clock

(4) Description of operation

(a) Low-power consumption mode

This chip has three operation modes. The sleep mode, and stop mode in the table below reduce the power consumption. In the main mode, four system clocks can be selected according to the system condition to minimize power consumption.

| Main<br>operation<br>mode | (CS1,<br>CS0) | Operation            |                     | Clock pulse<br>generation |                    | Each operating clock pulse<br>(10 MHz main clock) |                    |                 | Wake-up source in                                      |
|---------------------------|---------------|----------------------|---------------------|---------------------------|--------------------|---------------------------------------------------|--------------------|-----------------|--------------------------------------------------------|
|                           | CS0)          | mode                 | Main                | Sub                       | CPU                | Time-base<br>timer                                | Each<br>resource   | Clock           | each mode                                              |
|                           | (1, 1)        | RUN<br>SLEEP<br>STOP | Oscillates<br>Stops | Oscillates                | 5 MHz<br>Stops     | 5 MHz<br>Stops                                    | 5 MHz<br>Stops     | 32 kHz          | Various interrupt<br>requests<br>External interrupt    |
| Main                      | (1, 0)        | RUN<br>SLEEP<br>STOP | Oscillates<br>Stops | Oscillates                | 2.5 MHz<br>Stops   | 5 MHz<br>Stops                                    | 2.5 MHz<br>Stops   | 32 kHz          | Various interrupt<br>requests<br>External interrupt    |
| mode                      | (0, 1)        | RUN<br>SLEEP<br>STOP | Oscillates<br>Stops | Oscillates                | 1.25 MHz<br>Stops  | 5 MHz<br>Stops                                    | 1.25 MHz<br>Stops  | 32 kHz          | Various interrupt<br>requests<br>External interrupt    |
|                           | (0, 0)        | RUN<br>SLEEP<br>STOP | Oscillates<br>Stops | Oscillates                | 312.5 kHz<br>Stops | 5 MHz<br>Stops                                    | 312.5 kHz<br>Stops | 32 kHz          | Various interrupt<br>requests<br>External interrupt    |
| Submode                   | -             | RUN<br>SLEEP<br>STOP | Stops               | Oscillates<br>Stops       | 32 kHz<br>Stops    | Stops                                             | 32 kHz<br>Stops    | 32 kHz<br>Štops | Various interrupt<br>requests<br>"External interrupt " |
| CLOCK<br>mode             |               |                      | Stops               | Oscillates                | Stops              | Stops                                             | Stops              | 32 kHz          | Watch<br>External interrupt                            |

Table 2.2 Operating State of Low-power Consumption Modes

- The submode stops oscillation of the main clock.

- The SLEEP mode stops only the operating clock pulse of the CPU; other operations are continued.
- The WATCH mode stops the functions of all chips other than the special resources.
- The STOP mode stops the oscillation. Data can be held with the lowest power consumption in this mode.

# [1] WATCH mode

- Switching to WATCH mode
  - Writing 1 at the TMD bit (bit 3) of the STBC register switches the mode to WATCH mode. Writing is invalid if 1 is set at the SCS bit (bit 2) of the SYCC register.
  - The WATCH mode stops all chip functions except the watch prescaler, external interrupt, and wake-up functions. Therefore, data can be held with the lowest power consumption.
  - The input/output pins and output pins during the WATCH mode can be controlled by the SPL bit of the STBC register so that they are held in the state immediately before entering the WATCH mode or so that they enter the high-impedance state.
  - If an interrupt is requested when 1 is written at the TMD bit , instruction execution continues without switching to the WATCH mode.
  - In the WATCH mode, the values of registers and RAM immediately before entering the WATCH mode are held.
- Canceling WATCH mode
  - The WATCH mode is canceled by inputting the reset signal and requesting an interrupt.
  - When the reset signal is input during the WATCH mode, the CPU is switched to the reset state and the WATCH mode is canceled.
  - When an interrupt higher than level 11 is requested from a resource during the WATCH mode, the WATCH mode is canceled.
  - When the I flag and IL bit are enabled like an ordinary interrupt after canceling, the CPU executes the interrupt processing. When they are disabled, the CPU executes the interrupt processing from the instruction next to the one before entering the WATCH mode.
  - If the WATCH mode is canceled by inputting the reset signal, the CPU is switched to the oscillation stabilization wait state. Therefore, the reset sequence is not executed unless the oscillation stabilization time is elapsed. The oscillation stabilization time will be that of the main clock selected by the WT1 and WT0 bits. However, when Power-on Reset is not specified by the mask option, the CPU is not switched to the oscillation stabilization wait state, even if the WATCH mode is canceled by inputting the reset signal.

# [2] SLEEP mode

- Switching to SLEEP mode
  - Writing 1 at the SLP bit (bit 6) of the STBC register switches the mode to SLEEP mode.
  - The SLEEP mode stops the CPU operating clock pulse; only the CPU stops and the resources continue to operate.
  - If an interrupt is requested when 1 is written at the SLP bit (bit 6), instruction execution continues without switching to the SLEEP mode. In the SLEEP mode, the values of registers and RAM im mediately before entering the SLEEP mode are held.
- Canceling SLEEP mode
  - The SLEEP mode is canceled by inputting the reset signal and requesting an interrupt.
  - When the reset signal is input during the SLEEP mode, the CPU is switched to the reset state and the SLEEP mode is canceled.
  - When an interrupt higher than level 11 is requested from a resource during the SLEEP mode, the SLEEP mode is canceled.
  - When the I flag and IL bit are enabled like an ordinary interrupt after canceling, the CPU executes the interrupt processing. When they are disabled, the CPU executes the interrupt processing from the instruction next to the one before entering the SLEEP mode.

## [3] STOP mode

- Switching to STOP mode
  - Writing 1 at the STP bit (bit 7) of the STBC register switches the mode to STOP mode.
  - The STOP mode varies when the main clock is operating and when the subclock is operating.
    - When the main clock is operating: The main clock stops but the subclock does not stop. All chip functions except the watch function stop.

When subclock is operating:

Both the main clock and subclock stop. All chip functions

stop.

- -The input/output pins and output pins during the STOP mode can be controlled by the SPL bit (bit 5) of the STBC register so that they are held in the state immediately before entering the STOP mode, or so that they enter in the high-impedance state.
- If an interrupt is requested when 1 is written at the STP bit (bit 7), instruction execution continues without switching to the STOP mode.
- In the STOP mode, the values of registers and RAM immediately before entering the STOP mode are held.
- Canceling STOP mode
  - The STOP mode is canceled either by inputting the reset signal or by requesting an interrupt.
  - When the reset signal is input during the STOP mode, the CPU is switched to the reset state and the STOP mode is canceled.
  - When an interrupt higher than level 11 is requested from the external interrupt circuit during the STOP mode, the STOP mode is canceled.
  - When the I flag and IL bit are enabled like an ordinary interrupt after canceling, the CPU executes the interrupt processing. When they are disabled, the CPU executes the interrupt processing from the instruction next to the one before entering the STOP mode.
  - Four oscillation stabilization times of the main clock can be selected by the WT1 and WT0 bits. The oscillation stabilization time of the subclock is fixed (at 2<sup>15</sup>/fcl -- fcl: frequency of subclock).
  - If the STOP mode is canceled by inputting the reset signal, the CPU is switched to the oscillation stabilization wait state. Therefore, the reset sequence is not executed unless the oscillation stabilization time is elapsed. The oscillation stabilization time corresponds to the oscillation stabilization time of the main clock selected by the WT1 and WT0 bits. However, when Power-on Reset is not specified by the mask option, the CPU is not switched to the oscillation stabilization wait state even if the STOP mode is canceled by inputting the reset signal.

[4] Setting low power consumption mode

| S           | Mode                            |   |         |  |  |  |
|-------------|---------------------------------|---|---------|--|--|--|
| STP (Bit 7) | (Bit 7) SLP (Bit 6) TMD (Bit 3) |   |         |  |  |  |
| 0           | 0                               | 0 | Normal  |  |  |  |
| 0           | 0                               | 1 | WATCH   |  |  |  |
| 0           | 1                               | 0 | SLEEP   |  |  |  |
| 1           | 0                               | 0 | STOP    |  |  |  |
| 1           | ×                               | × | Disable |  |  |  |

**Note:** When the mode is switched from the subclock mode to the main clock mode, do not set the stop, sleep, and watch modes. If the SCS bit of the SYCC register is rewritten from 0 to 1, set the above modes after the SCM bit of the SYCC register has been set to 1.

(b) State transition diagram



When power-on reset option is selected

- (2) When power-on reset option is not selected
- (3) After oscillation stabilized
- (4) Set STP bit to 1.
- (5) Set SLP bit to 1.
- (6) Set SCS bit to 0.
- (7) External reset when power-on reset option not selected
- (8) External reset or interrupt when power-on reset option selected
- (9) External reset or interrupt
- (10)External reset when power-on reset option not selected
- (11) External reset or other reset when power-on reset option selected
- (12)Set SCS bit to 1.
- (13) After oscillation stabilized
- (14)Set STP bit to 1.
- (15)Set TMD bit to 1.
- (16)Set SLP bit to 1.
- (17)External reset after oscillation stabilized or when power-on reset option not selected

- (18) External reset or other reset when power-on reset option selected
- (19)External reset after oscillation is stabilized or when power-on reset option not selected
- (20)External reset when power-on reset option selected
- (21)External reset when power-on reset option not selected
- (22) Interrupt
- (23)External reset when power-on reset option selected
- (24)External reset when power-on reset option selected
- (25)External reset when power-on reset option not selected
- (26) Interrupt
- (27)External reset when power-on reset option selected
- (28)External reset when power-on reset option not selected

(29)Interrupt

# (d) Reset

There are four types of resets as shown in Table 2-3.

## Table 2.3 Sources of Reset

| Reset name         | Description                     |
|--------------------|---------------------------------|
| External-pin reset | Sets external-reset pin to Low  |
| Software reset     | Writes 0 at RST (bit 4) of STBC |
| Watchdog reset     | Overflows watchdog timer        |
| Power-on reset*    | Turns power on                  |

\*: "Power-on reset provided" is specified in the mask option.

When the power-on reset and reset during the stop mode are used, the oscillation stabilization time is needed after the oscillator operates. The time-base timer or watch prescaler controls this stabilization time. Consequently, the operation does not start immediately even after canceling the reset.

However, if Power-on Reset Disabled is selected by the mask option, no oscillation stabilization time is required in any state after external pins have been released from the reset.

**Note:** If Power-on Reset Disabled is selected, the RST pin must be kept Low until the oscillation stabilization time selected by the option has elapsed after power on.

### (5) Single clock

The single clock module can be selected by the mask option. In the single clock operation, the functions are the same as those of the double clock module except that the subclock mode cannot be set. In the single clock operation, P72/X0A/INT2 and P73/X1A/INT3 serve as external interrupt pins.

(a) State transition diagram



- When power-on reset option selected
- (2) When power-on reset option not selected
- (3) After oscillation stabilized
- (4) Set STP bit to 1.
- (5) Set SLP bit to 1.
- (7) External reset when power-on reset option not selected
- (8) External reset or interrupt when power-on reset option selected
- (9) External reset or interrupt

# 2.1.6 Interrupt Controller

The interrupt controller for the  $F^2MC-8L$  is located between the CPU and each resource. This controller re ceives interrupt requests from the resources, assigns priority to them, and transfers the priority to the CPU; it also decides the priority of same-level interrupts.

## (1) Block diagram



### (a) Register list



- (2) Description of registers
- Interrupt level setting register (ILRX: Interrupt Level Register X)

|      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |                          |
|------|-----|-----|-----|-----|-----|-----|-----|-----|--------------------------|
| 1LR1 | L31 | L30 | L21 | L20 | L11 | L10 | L01 | L00 | W When reset (1111 1111) |
| 1LR2 | L71 | L70 | L61 | L60 | L51 | L50 | L41 | L40 | W When reset (1111 1111) |
| 1LR3 | LB1 | LB0 | LA1 | LAO | L91 | L90 | L81 | L80 | W When reset (1111 1111) |

The ILRX sets the interrupt level of each resource. The digits in the center of each bit correspond to the inter rupt numbers.



When an interrupt is requested from a resource, the interrupt controller transfers the interrupt level based on the value set at the 2 bits of the ILRX corresponding to the interrupt to the CPU. The relationship between the 2 bits of the ILRX and the required interrupt levels is as follows:

| Lx1 | Lx0 | Required interrupt level |
|-----|-----|--------------------------|
| 0   | X   | 1                        |
| 1   | 0   | 2                        |
| 1   | 1   | 3 (None)                 |

- (3) Description of operation
- Interrupt functions

The MB89630 series of microcontrollers have 12 inputs for interrupt requests from each resource. The interrupt level is set by 2-bit registers corresponding to each input. When an interrupt is requested from a resource, the interrupt controller receives it and transfers the contents of the corresponding register to the CPU. The interrupt to the device is processed as follows:

- 1) An interrupt source is generated inside each resource.
- 2) If an interrupt is enabled, an interrupt request is output from each resource to the interrupt controller by referring to the interrupt-enable bit inside each resource.
- 3) After receiving this interrupt request, the interrupt controller determines the priority of simultaneouslyrequested interrupts and then transfers the interrupt level for the applicable interrupt to the CPU.
- 4) The CPU compares the interrupt level requested from the interrupt controller with the IL bit in the proc essor status register.
- 5) As a result of the comparison, if the priority of the interrupt level is higher than that of the current inter rupt processing level, the contents of the I-flag in the same processor status register are checked.
- 6) As a result of the check in step (5), if the I-flag is enabled for an interrupt, the contents of the IL bit are set to the required level. As soon as the currently-executing instruction is terminated, the CPU performs the interrupt processing and transfers control to the interrupt-processing routine.
- 7) When an interrupt source is cleared by software in the user's interrupt processing routine, the CPU terminates the interrupt processing.

Figure 2.8 outlines the interrupt operation for the MB89630 series of microcontrollers.



Fig. 2.8 Interrupt-processing Flowchart

# 2.2 RESOURCE FUNCTIONS

# 2.2.1 I/O Ports

- The MB89630 series of microcontrollers have eight parallel ports (53 ports). Ports 0, 1, and 3 serve as 8bit I/O ports; ports 4 and 5 serve as 4-bit I/O ports; ports 2, and 6 serve as 8-bit output-only ports and port 7 serves as a 5-bit input-only port.
- Each port is also used as a resource (ports 3, 4, 5, and 7) and as external-bus pins (ports 0 to 2).

| Pin name   | Input type           | Output type       | Function              | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |
|------------|----------------------|-------------------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| P00 to P07 | CMOS push-oull       |                   | Parallel port 0       | P07   | P06   | P05   | P04   | P03   | P02   | P01   | P00   |
| P00 10 P07 | CMUS                 | push-pull         | External-address mode | AD7   | AD6   | AD5   | AD4   | AD3   | AD2   | AD1   | AD0   |
| P10 to P17 | CMOS                 | CMOS<br>push-pull | Parallel port 1       | P17   | P16   | P15   | P14   | P13   | P12   | P11   | P10   |
| FIGIOFIA   | CMOS                 | pusn-puil         | External-address mode | A15   | A14   | A13   | A12   | A11   | A10   | A09   | A08   |
| P20 to P27 |                      | CMOS<br>push-pull | Parallel port 2       | P27   | P26   | P25   | P24   | P23   | P22   | P21   | P20   |
| P20 10 P27 | _                    | pusn-puii         | External-address mode | ALE   | RD    | WR    | CLK   | RDY   | HRQ   | HAK   | BUFC  |
| P30 to P37 | CMOS                 | CMOS<br>push-pull | Parallel port 3       | P37   | P36   | P35   | P34   | P33   | P32   | P31   | P30   |
| P30 10 P37 | (Hysteresis)         | /N-ch OD          | Resource              | wто   | PWC   | SI1   | SO1   | SCK1  | UI1   | UO1   | UCK1  |
| P40 to P43 | CMOS<br>(Hysteresis) | CMOS<br>push-pull | Parallel port 4       | -     | -     | -     |       | P43   | P42   | P41   | P40   |
| F40 10 F43 | (Hysteresis)         | pusn-puil         | Resource              | -     | -     | -     | -     | PTO1  | UI2   | UO2   | UCK2  |
| P50 to P53 |                      | N-ch              | Parallel port 5       | -     | -     |       | -     | P53   | P52   | P51   | P50   |
| P50 10 P53 | _                    | open drain        | Resource              | -     | - 1   | -     | -     | PTO2  | - 1   | BZ    | ADST  |
| P60 to P64 | Analog               | N-ch              | Parallel port 6       | P67   | P66   | P65   | P64   | P63   | P62   | P61   | P60   |
| P60 10 P64 | comparator           | open drain        | Resource              | AN7   | AN6   | AN5   | AN4   | AN3   | AN2   | AN1   | ANO   |
| P70 to P74 | CMOS<br>(Hysteresis) |                   | Parallel port 7       | -     | -     | -     | P74   | P73   | P72   | P71   | P70   |
| F70 10 P74 | (Hysteresis)         |                   | Resource              | - 1   | -     | - 1   | EC    | INT3  | INT2  | INT1  | INTO  |

 Table 2.4
 List of Port Functions

**Note:** Output type of P33, P34, and P35 can be selected from the CMOS or N-ch open drain. P70 and P71 serve as P70/INT0 and P71/INT1 at single clock operation and as X1A and X0A at double clock operation, respectively.

# (1) Port registers

| Register name                            | Read/Write | Address           | Initial value         |
|------------------------------------------|------------|-------------------|-----------------------|
| Port-0 data register (PDR0)              | R/W*1      | 0000 <sub>H</sub> | XXXXXXXXB             |
| Port-0 data direction register (DDR0)    | W*1        | 0001 <sub>H</sub> | 00000000B             |
| Port-1 data register (PDR1)              | R/W*1      | 0002 <sub>H</sub> | XXXXXXXXB             |
| Port-1 data direction register (DDR1)    | W*1        | 0003 <sub>H</sub> | 0000000 <sub>B</sub>  |
| Port-2 data register (PDR2)              | R/W        | 0004 <sub>H</sub> | 00000000B             |
| External-bus pin-control register (BCTR) | W*2        | 0005 <sub>H</sub> | XXXXXX01 <sub>B</sub> |
| Port-3 change register (CHG3)            | R/W        | 000C <sub>H</sub> | XX000XXX <sub>B</sub> |
| Port-3 data register (PDR3)              | R/W        | 000D <sub>H</sub> | XXXXXXXXB             |
| Port-3 data direction register (DDR3)    | w          | 000E <sub>H</sub> | 00000000 <sub>B</sub> |
| Port-4 data register (PDR4)              | R/W        | 000F <sub>H</sub> | XXXXXXXXB             |
| Port-4 data direction register (DDR 4)   | w          | 0010 <sub>H</sub> | XXXX0000B             |
| Port-5 data register (PDR5)              | R/W        | 0012 <sub>H</sub> | XXXX1111 <sub>B</sub> |
| Port-6 data register (PDR6)              | R/W        | 0013 <sub>H</sub> | 11111111 <sub>H</sub> |
| Port-7 data register (PDR7)              | R          | 0014 <sub>H</sub> | XXXXXXXX              |

## Table 2.5 Port Registers

- R/W: Read/write enabled
- R : Read only
- W : Write only
- X : Undefined

# \*1 Data can be read and written only in the single-chip mode.

\*2 Data can be written only when the external bus is extended.

\*3 The bit manipulation instructions cannot be used for DDR0, DDR1, DDR3, and DDR4.

(2) Description of functions

P00 to P07 CMOS-type I/O ports (also used as external-address/data bus)

P10 to P17 CMOS-type I/O ports (also used as external-address bus)

- Operation when external bus extended See the description of the bus functions.
- · Switching input and output

These ports have a data-direction register (DDR) and port-data register (PDR) for each bit. Input and out put can be set independently for each bit. The pin with the DDR set to 1 is set to output, and the pin with the DDR set to 0 is set to input. Note that the DDR is ineffective when the external bus is used.

• Operation for output port (DDR = 1)

The value written at the PDR is output to the pin when the DDR is set to 1. When the PDR is read, usually, the value of the pin is read instead of the contents of the output latch. However, when the Read Modify Write instruction is executed, the contents of the output latch are read irrespective of the DDR setting con ditions. Therefore, the bit-processing instruction can be used even if input and output are mixed with each other. When data is written to the PDR, the written data is held in the output latch irrespective of the DDR setting conditions.

Operation for input port (DDR = 0)

When settings the input, the output impedance goes High. Therefore, when the PDR is read, the value of the pin is read.

· State when reset

In the single-chip mode (MOD0 = Low, MOD1 = Low), the DDR is initialized to 0 by resetting and the output impedance goes High at all bits. (Pins with activated pull-up resistors are in the pull-up state.) The PDR is not initialized by resetting. Therefore, set the value of the PDR before setting the DDR to output.

• State in stop mode

With the SPL bit of the standby-control register set to 1, in the stop mode, the output impedance goes High irrespective of the value of the DDR. (Pins with activated pull-up resistors are in the pull-up state.)



Fig. 2.9 Ports 0 and 1 (in Single-chip Mode)



P20 to P27 CMOS-type output-only ports (also used as external-bus control pin)

- Operation when external bus extended See the description of the bus functions.
- Operation for output port

In the single-chip mode, the value written at the PDR is output to the pin. When the PDR is read, the con tents of the output latch are always read, so the bit- processing instruction is used even if the output level changes due to the load.

• State when reset

In the single-chip mode, the pin impedance goes High at reset. As soon as a vector is fetched, output of the port is enabled and the port starts operation as the output port. Since the PDR is initialized to 0 by resetting, the Low level is output to the pin.

· State in stop mode

With the SPL bit of the standby-control register set to 1, in the stop mode, the output impedance goes High irrespective of the value of the PDR.



Fig. 2.10 Port 2 (in Single-chip Mode)

P30 to P37 CMOS-type I/O ports (also used as resource input/output)

· Switching input and output

This port has a data-direction register (DDR) and a port-data register (PDR) for each bit. Input and output can be set independently for each bit. The pin with the DDR set to 1 is set to output, and the pin with the DDR set to 0 is set to input. When the resource-output enable bit is enabled, the pin is set to output irre spective of the DDR setting conditions.

• Operation for output port (DDR = 1)

The value written at the PDR is output to the pin when the DDR is set to 1. When the PDR is read, usually, the value of the pin is read instead of the contents of the output latch. However, when the Read Modify Write instruction is executed, the contents of the output latch are read irrespective of the DDR setting con ditions. Therefore, the bit-processing instruction can be used even if input and output are mixed with each other. When data is written to the PDR, the written data is held in the output latch irrespective of the DDR setting conditions.

P33 to P35 can be selected from either CMOS (Bit X = 0) or N-ch open drain (Bit X = 1).

• Operation for input port (DDR = 0)

When used as the input port, the output impedance goes High. Therefore, when the PDR is read, the value of the pin is read.

• Operation for resource output

When using as the resource output, setting is performed by the resource output- enable bit. (See the de scription of each resource.) If the output of each resource is enabled with the DDR set to 0, the port is set to output. Since the reading of the parallel port is effective even if the output of each resource is enabled, the output value of each resource can be read.

• Operation for resource input

Input to the resource is irrelevant to the setting conditions of the DDR and resource. The value of the pin is always input to the port serving as the resource input. When using an external signal at the resource, set the DDR to input.

· State when reset

When reset, the DDR and resource output-enable bit are initialized to 0 and the output impedance goes High at all bits. (Pins with activated pull-up resistors are in the pull-up state.) When reset, the PDR is unde fined. Therefore, set the value of the PDR before setting the DDR to output.

• State in stop mode

With the SPL bit of the standby-control register set to 1, in the stop mode, the output impedance goes High irrespective of the value of the DDR. (Pins with activated pull-up resistors are in the pull-up state.)



Fig. 2.11 Port 3

• CHG3: Port 3 change register

|                            | Bit 7 |   |       |       | Bit 3 |   |   | <br>Initial value          |
|----------------------------|-------|---|-------|-------|-------|---|---|----------------------------|
| Address: 000C <sub>H</sub> | -     | - | CG35  | CG34  | CG33  | - | - | <br>XX00 0XXX <sub>H</sub> |
|                            |       |   | (R/W) | (R/W) | (R/W) |   |   |                            |

| CHG3 setting |      |      |     | Output type of port 3 |      |      |      |      |     |     |  |
|--------------|------|------|-----|-----------------------|------|------|------|------|-----|-----|--|
| CG35         | CG34 | CG33 | P37 | P36                   | P35  | P34  | P33  | P32  | P31 | P30 |  |
| 0            | 0    | 0    |     |                       | CMOS | CMOS | CMOS |      |     |     |  |
| 0            | 0    | 1    |     | сомз                  |      | CMOS | N-OD |      |     |     |  |
| 0            | 1    | 0    |     |                       |      | N-OD | CMOS | ]    |     |     |  |
| 0            | 1    | 1    |     |                       |      | N-OD | N-OD |      |     |     |  |
| 1            | 0    | 0    |     | мə                    | N-OD | CMOS | CMOS | COMS |     |     |  |
| 1            | 0    | 1    |     |                       | N-OD | CMOS | N-OD |      |     |     |  |
| 1            | 1    | 0    |     |                       |      | N-OD | CMOS |      |     |     |  |
| 1            | 1    | 1    |     |                       |      | N-OD | N-OD |      |     |     |  |

P40 to P43 CMOS-type I/O ports (also used as resource input/output)

· Switching input and output

This port has a data-direction register (DDR) and a port-data register (PDR) for each bit. Input and output can be set independently for each bit. The pin with the DDR set to 1 is set to output, and the pin with the DDR set to 0 is set to input. When the resource-output enable bit is enabled, the pin is set to output irre spective of the DDR setting conditions.

Operation for output port (DDR = 1)

The value written at the PDR is output to the pin when the DDR is set to 1. When the PDR is read, usually, the value of the pin is read instead of the contents of the output latch. However, when the Read Modify Write instruction is executed, the contents of the output latch are read irrespective of the DDR setting con ditions. Therefore, the bit-processing instruction can be used even if input and output are mixed with each other. When data is written to the PDR, the written data is held in the output latch irrespective of the DDR setting conditions.

• Operation for input port (DDR = 0)

When used as the input port, the output impedance goes High. Therefore, when the PDR is read, the value of the pin is read.

Operation for resource output

When using as the resource output, setting is performed by the resource output- enable bit. (See the de scription of each resource.) If the output of each resource is enabled with the DDR set to 0, the port is set to output. Since the reading of the parallel port is effective even if the output of each resource is enabled, the output value of each resource can be read.

• Operation for resource input

Input to the resource is irrelevant to the setting conditions of the DDR and resource. The value of the pin is always input to the port serving as the resource input. When using an external signal at the resource, set the DDR to input.

State when reset

When reset, the DDR and resource output-enable bit are initialized to 0 and the output impedance goes High at all bits. (Pins with activated pull-up resistors are in the pull-up state.) When reset, the PDR is unde fined. Therefore, set the value of the PDR before setting the DDR to output.

• State in stop mode

With the SPL bit of the standby-control register set to 1, in the stop mode, the output impedance goes High irrespective of the value of the DDR. (Pins with activated pull-up resistors are in the pull-up state.)



Fig. 2.12 Port 4

P50 to P53 N-ch open-drain-type I/O ports (also used as resource input/output)

· Switching input and output

These ports have no register for specifying input or output. When using as an input port, set 1 at the Port Data Register (PDR).

· Operation for output port

The value written at the PDR is output to the pin. When the PDR is read, usually, the value of the pin is read instead of the contents of the output latch. However, when the Read Modify Write instruction is executed, the contents of the output latch are read. Therefore, the bit-processing instruction can be used even if input and output are mixed with each other.

• Operation for input port

When using as the input port, set 1 at the PDR to turn off the output transistor. When the PDR is read under this condition, the value of the pin can always be read.

Operation for resource output

When using as a resource output, setting is performed by the resource output- enable bit (see description of each resource). Even if output of each resource is enabled, the port can be read other than when the Read Modify Write instruction is read. Therefore, the state of the pin can be checked.

• Operation for resource input

The value of the pin is always input to the port serving also as the resource input irrespective of the setting of the resource. When using an external signal at the resource, set 1 at the PDR.

State when reset

The PDR is initialized to 1 at reset, so the output transistor is turned off at all bits.

• State in stop mode

When the SPL bit of the standby-control register is set to 1, in the stop mode, the output impedance goes High irrespective of the value of the PDR. (Pins with activated pull-up resistors are in the pull-up state.)



Fig. 2.13 Port 5



P60 to P67 N-ch open-drain-type output ports (also used as analog input)

• Operation for output port

The value written at the PDR is output to the pin. When the PDR is read, the contents of the output latch are always read. Therefore, the state of the pin cannot be read.

• Operation for analog input

When using as analog input, set 1 at the PDR to turn off the output transistor.

State when reset

When reset, the PDR is initialized to 1. Therefore, the output transistor is turned off at all bits.

· State in stop mode

When the SPL bit of the standby-control register is set to 1, in the stop mode, the output impedance goes High irrespective of the value of the PDR.



Fig. 2.14 Port 6

P70 to P74 Input-only ports (also used as external-interrupt input)

- Operation for external-interrupt input See the description of the external interrupts.
- Operation for input port

The PDR can only be read and the value of the pin is always read. When using as an external-interrupt input, the value of the pin can also be read.

- **Note:** P70 and P71 serve as oscillation circuit pins when the double clocks are operated and serve as input-only port which is also serve as external interrupt input, when single clock mode is operated.
- · State at reset

PDR is not initialized by raset.

• Operation at STOP mode

These bits serve as the external interrupt input pins even at STOP mode.



Fig. 2.15 Port 7

# 2.2.2 2-channel 8-bit PWM Timers (Timers 1 and 2)

- Four clock pulses can be selected.
- The input clock of CH2 has the CK12 mode to select CH1 output.
- This timer has the CH12PWM mode to output a PWM wave using CH1 and CH2.
- (1) Registers

| <b> -</b>                  | 8 bit |                        |
|----------------------------|-------|------------------------|
| Address: 0028 <sub>H</sub> | CNTR1 | R/W Control register 1 |
| Address: 0029 <sub>H</sub> | CNTR2 | R/W Control register 2 |
| Address: 002A <sub>H</sub> | CNTR3 | R/W Control register 3 |
| Address: 002B <sub>H</sub> | COMR1 | W Compare register 1   |
| Address: 002C <sub>H</sub> | COMR2 | W Compare register 2   |





(2) Block diagram

FUJITSU

- FUĴĨTSU
- (3) Description of registers

(a) Control register 1 (CNTR1)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0028 <sub>H</sub> | PTX1  | PTX2  | P7M2  | P7M2  | SC11  | SC10  | SC21  | SC20  | 0000 0000 <sub>B</sub> |
|                            | (R/W) |                        |

[Bit 7] PTX1: CH1 timer/PWM operation mode switching bit

[Bit 6] PTX2: CH2 timer/PWM operation mode switching bit

The operation is performed as the timer when 0 is set at these bits, and as the PWM control circuit when 1 is written at these bits.

| 0 | Timer               |
|---|---------------------|
| 1 | PWM-control circuit |

The timer/PWM operation mode should be switched when the counter stops operation (TPE = 0), the inter rupt is enabled (TIE = 0), and the interrupt request flag is cleared (TIR = 0).

[Bit 5] P7M1: CH1 PWM operation mode switching bit

## [Bit 4] P7M2: CH2 PWM operation mode switching bit

Writing 1 at P7W1 and P7W2 switches the mode from 8-bit PWM to 7-bit high-speed. This makes the PWM frequency two times larger than that in the 8-bit PWM mode.

| 0 | 8-bit PWM                  |
|---|----------------------------|
| 1 | 7-bit PWM, high-speed mode |

Do not write 1 at this bit in the timer mode.

[Bit 3 and 2] SC11, SC10: CH1 input-clock select bit

## [Bit 1 and 0] SC21, SC20: CH2 input-clock select bit

Following clock cycles can be selected by these bits.

| SC11 | SC10 | CH1 input-clock cycle (10 MHz with the highest speed gear) |  |  |  |  |  |  |  |  |
|------|------|------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0    | 0    | 1 instruction cycle (0.4 μs)                               |  |  |  |  |  |  |  |  |
| 0    | 1    | 8 instruction cycle (3.2 µs)                               |  |  |  |  |  |  |  |  |
| 1    | 0    | 16 inctruction cycle (6.4 μs)                              |  |  |  |  |  |  |  |  |
| 1    | 1    | 64 instruction cycle (25.6 μs)                             |  |  |  |  |  |  |  |  |

| SC21 | SC20 | CH2 input-clock cycle (10 MHz with the highest speed gear) |
|------|------|------------------------------------------------------------|
| 0    | 0    | 1 instruction cycle (0.4 μs)                               |
| 0    | 1    | 8 instruction cycle (3.2 μs)                               |
| 1    | 0    | 16 inctruction cycle (6.4 μs)                              |
| 1    | 1    | 64 instruction cycle (25.6 μs)                             |

Note that these bits must not be rewritten when the counter is in operation (TPE = 1)

### (b) Control register 2 (CNTR2)

|                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|-------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address:          | TPE1  | TPE2  | CK12  |       | TIR1  | TIR2  | TIE1  | TIE2  | 000X 0000 <sub>B</sub> |
| 0029 <sub>H</sub> | (R/W) | (R/W) | (R/W) |       | (R/W) | (R/W) | (R/W) | (R/W) |                        |

[Bit 7] TPE1: Counter-operation enable bit

[Bit 6] TPE2: Counter-operation enable bit

When this bit is set to 1, the timer or PWM-control circuit starts operation.

| 0 | Counter operation stop (Timer cleared) |
|---|----------------------------------------|
| 1 | Counter operation start                |

[bit 4] CK12: CH2 input-clock switching bit

When 1 is written at this bit, CH1 toggle output is selected as the input clock of CH2 irrespective of the values of the SC21 and SC20 bits.

| 0 | Clock selected by SC21 and SC20 bits |
|---|--------------------------------------|
| 1 | CH1 toggle output                    |

Do not write 1 at this bit when the CH1-2PWM mode is set (CH1-2 bit = 1).

[Bit 3] TIR1: CH1 interrupt-request flag bit

[Bit 2] TIR2: CH2 interrupt-request flag bit

When an interrupt source occurs, these bits go to 1. To clear the generated interrupt source, write 0 at these bits. The meaning of each bit to be read is as follows:

| 0 | Values of counter and COMR do not agree |
|---|-----------------------------------------|
| 1 | Values of counter and COMR agree        |

Note that 1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

Note: In the PWM operation mode, neither the read nor write values of these bits have any meaning.

[Bit 1] TIE1: CH1 interrupt enable bit (timer mode)

### [Bit 0] TIE1: CH2 interrupt enable bit (timer mode)

If these bits are set to 1, an interrupt occurs when the values of the counter and compare register agree.

| 0 | Counter interrupt-output disabled |
|---|-----------------------------------|
| 1 | Counter interrupt-output enabled  |

However, in the PWM operation mode, interrupt occur irrespective of the values of these bits.

(c) Control register 3 (CNTR3)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 002A <sub>H</sub> | -     | OE2   | OE3   | CH12  |       | -     | -     | -     | 0000 XXXX <sub>B</sub> |
|                            |       | (R/W) |       |       |       |       |       |       |                        |

# [Bit 6] OE2: CH2 output-signal control bit

If this bit is 1, the port serves as the timer/PWM output. In the timer operation mode, usually a signal which is reversed each time the value of the counter and compare register agree, is output. In the PWM operation mode, a PWM signal is output.

| 0 | General-purpose port (P53)    |
|---|-------------------------------|
| 1 | Counter/PWM output pin (PTO2) |

If this bit is 1, the port functions as the counter/PWM output pin even after the PDR P53 are set to 1.

## [Bit 5] OE3: CH 1-2 PWM mode output signal control bit

When this bit is 1, the port serves as the CH1-2 PWM output.

| 0 | General-purpose port pin (P43)         |
|---|----------------------------------------|
| 1 | CH1-2 PWM output pin/CH1 output (PTO1) |

When the CH1-2 bit is 0, the port serves as the CH1 output.

## [Bit 4] CH1-2: CH1-2 PWM mode set bit

When this bit is 1, the CH1-2PWM mode is set. CH1 and CH2 enter the timer mode irrespective of the values of the PTX1 and PTX2 bits.

| 0 | Ordinary mode  |
|---|----------------|
| 1 | CH1-2 PWM mode |

Do not rewrite this bit when CH1 or CH2 is in counter operation (TPE1 = 1 or TPE2 = 1).

#### (d) Compare register 1 (COMR1)

This register is used to set the value to be compared with the value of the counter in the CH1 timer-opera tion mode. The counter is cleared in the timer-operation mode and when the values of the counter and this register agree. In the PWM operation mode, the High pulse width can be specified by the value of this register.



#### (e) Compare register 2 (COMR2)

This register is used to set the value to be compared with the value of the counter in the CH2 timeropera tion mode. The counter is cleared in the timer-operation mode and when the value of the counter and this register agree. In the PWM operation mode, the High pulse width can be specified by the value of this register.



- (4) Description of operation
- (a) Timer operation

Setting the PTX bits 1 and 2 of the CNTR1 to 0 gives the timer-operation mode. When the TPE bits 1 and 2 of the CNTR2 are set to 1, the counter starts incrementing from 00H. When the value of the counter agrees with that of the COMR, the counter is cleared on the next count clock pulse and incrementing restarts. Therefore, the TIR bits 1 and 2 are set and the output pin is reversed (when the TPE bits 1 and 2 are 0, the output pin is fixed at Low level) in cycles of the count clock pulses when 00H is written at the COMR, or in cycles 256 times longer than those of the count clock pulses when FFH is written.

If the value of the COMR is rewritten in the timer-operation mode, it becomes effective from the next cycle (when the value of the counter is 00H, the value of the COMR is transferred to the comparator latch).



## Fig. 2.16 Timer Operation

If the TIE bits 1 and 2 of the CNTR2 are set to 1, an interrupt occurs when the values of the counter and COMR agree. During interrupt processing, the TIR bits 1 and 2 are used as the interrupt flag. The TIR bits 1 and 2 are set to 1 irrespective of the value of the TIE bits 1 and 2.

Writing 0 at the TIR bits 1 and 2 permits clearing of the interrupt source or the TIR bits 1 and 2. When the Read Modify Write instruction is read, the TIR bits 1 and 2 is set so that 1 can always be read to prevent erroneous clearing.

The count clock pulse can be selected from four clock pulses from the prescaler by the clock pulse select bits SC11, SC10, SC21, and SC20 of the CNTR1 register. When 1 is written at the CK12 bit of the CNTR2 register, CH1 toggle output is selected as the input clock of CH2 irrespective of the values of the SC21 and SC20 bits.

**Note:** When the PWM operation mode is specified, do not put CH1 in the CK12 mode (do not write 1 at the CK12 bit).



#### (b) PWM operation

Setting the PTX bits 1 and 2 of the CNTR1 to 1 gives the PWM operation mode. The COMR1 and 2 specify the duty of the output pulse. Pulses can be output with 1/256 resolution and a duty of 0% to 99.6%. When 0 (00H) is written at the COMR1 and 2, the duty of the PWM output pulse is 0%; when 128 (80H) is written, the duty is 50%, and when 255 (FFH) is written, it is 99.6%.

The value of COMR is transferred to the comparator latch when the value of the counter is 00H. If the value of the COMR is rewritten in the PWM operation mode, it becomes effective from the next cycle.

| <ul> <li>When COMR is 00H</li> </ul> |                    |                  |     |                        |   |
|--------------------------------------|--------------------|------------------|-----|------------------------|---|
| Counter value<br>PWM pulse output    | 00H                |                  | FFH | 00H                    |   |
| When COMR is 80H                     |                    |                  |     |                        |   |
| Counter value                        | 00H ·····→→→ ····· | 80H ·····→ ····· | FFH | 00H ·····→→→ ····· 80H |   |
| PWM pulse output                     |                    |                  |     |                        | - |
| When COMR is 80H                     |                    |                  |     |                        |   |
| Counter value                        | 00H→→→             | <b>→→→</b>       | FFH | 00H                    |   |
| PWM pulse output                     |                    |                  |     |                        |   |



The TIR bits 1 and 2 of the CNTR2 have no relation with the PWM operation. No interruption occurs irre spective of the TIE bits 1 and 2.

The cycle and frequency of the PWM pulse can be changed by switching the count clock pulse. The count clock pulse can be selected from four clock pulses from the prescaler by clock-pulse select bits SC11, SC10, SC21, and SC20 of the CNTR1. When 1 is written at the CK12 bit of the CNTR2 register, CH1 toggle output is selected as the input clock of CH2 irrespective of the values of the SC21 and SC20 bits.

**Note:** When the PWM operation mode is specified, do not put CH1 in the CK12 mode (do not write 1 at the CK12 bit).

## (c) High-speed PWM operation (7-bit PWM)

In the PWM operation mode, there are the normal mode with 8-bit 256 resolution and the high-speed mode with 7-bit 128 resolution.

Writing 1 at the P7M1 and P7M2 bits of the CNTR1 register gives this mode.

 Table 2.6 PWM Cycle and Resolution

(Clock = 10 MHz with the Highest Speed Gear (Instruction Cycle = 400 ns))

|                         | Ordinary mode |              |                  | High speed mode |              |                  |  |
|-------------------------|---------------|--------------|------------------|-----------------|--------------|------------------|--|
| Selected clock          | Resolution    | PWM<br>cycle | PWM<br>frequency | Resolution      | PWM<br>cycle | PWM<br>frequency |  |
| 1 instruction cycle     | 400 ns        | 102.4 µs     | 9.8 kHz          | 400 ns          | 51.2 μs      | 19.5 kHz         |  |
| 1/8 instruction cycle   | 3.2 µs        | 819.2 μs     | 1.2 kHz          | 3.2 µs          | 408.6 µs     | 2.4 kHz          |  |
| 1/16 instruction cycle  | 6.4 μs        | 1.6 ms       | 625 Hz           | 6.4 μs          | 819.2 μs     | 1.2 kHz          |  |
| 1/64 instruction cycle  | 25.6 µs       | 6.5 ms       | 153.8 Hz         | 25.6 µs         | 3.3 ms       | 303 Hz           |  |
| Channel-1 toggle output | 0.8 µs        | 204.8 µs     | 4.9/n Hz         | 0.8 µs          | 102.4 µs     | 4.9/n Hz         |  |

n = 1, 2, 3, ....., 255, 256 (CH1 timer compare register value + 1)

## (d) CH1-2 PWM mode

This mode causes the 2-channel PWM timer to be a timer and generates width L with the CH1 timer and the cycle with the CH2 timer to output a PWM wave.

Writing 1 at the CH1-2 bit of the CNTR3 register gives this mode. The timer mode is set irrespective of the values of the PTX1 and PTX2 bits of the CNTR1 register. A PWM wave is output from the P43 pin con trolled by OE3 to the compare registers 1 and 2.

To start the operation, write 1 simultaneously at the TPE1 and PTE2 bits of the CNTR2 register. Writing 1 separately at the TPE1 and TPE2 bits changes the duty or cycle. However, when the count value of CH2 agrees with the value of the compare register, both the CH1 and CH2 are simultaneously counter-cleared. Therefore, the duty or cycle is based on the value of the compare register from the second cycle.

When not in the CH1-2PWM mode, the P43 pin provides the CH1 toggle output or outputs a PWM wave. The default value of the PWM output is Low level.



Fig. 2.18 PWM Wave Output at CH1-2 PWM Mode

If the cycle of the CH1 timer becomes larger than that of the CH2 timer, a PWM wave is not output. The CH1 timer should be disabled for an interrupt. The CH2 timer can be used in the same manner as the normal timer.

#### (e) Prescaler

The prescaler can operate when either of the TPE1 or TPE2 bit is 1. Therefore, when 1 is written simulta neously at the TPE1 and TPE2 bits, both CH1 and CH2 perform the same operation from the first cycle. However, if either of the TPE1 or TPE2 bit is already 1 and the timer or PWM starts operation after the prescaler has been enabled, a difference of not more than one cycle occurs in the input clock pulse of the counter.



# 2.2.3 Pulse-width Count Timer (Timer 3)

- This timer has timer and pulse-width measurement functions.
- The timer function has two modes: reload timer and one-shot timer modes.
- In the reload-timer mode, the set values are decremented repeatedly.
- In the one-shot-timer mode, decrementing is started from the set value and stops at the first underflow.
- The pulse-width measurement function allows measurement of High, Low, or one-cycle widths of pulses input from pins.
- (1) Registers

|                            | ◄ 8 bit → |     |                                |
|----------------------------|-----------|-----|--------------------------------|
| Address: 0015 <sub>H</sub> | PCR1      | R/W | Pulse-width control register 1 |
| Address: 0016 <sub>H</sub> | PCR2      | R/W | Pulse-width control register 2 |
| Address: 0017 <sub>H</sub> | RLBR      | R/W | Reload-buffer register         |

### (2) Block diagram



Note: The CPU clock pulse is the pulse with 1/2 oscillation (gear max. at gear maximum speed).

(3) Description of registers

(a) Pulse-width control register 1 (PCR1)

This PCR1 is used to enable and disable each function and to display the state of the timer.

|                            | Bit 7 |       | Bit 5 |   |   |       |       |     | Initial value          |
|----------------------------|-------|-------|-------|---|---|-------|-------|-----|------------------------|
| Address: 0015 <sub>H</sub> | EN    | TOE   | IE    | - |   | UF    | IR    | BF  | 000x x000 <sub>B</sub> |
|                            | (R/W) | (R/W) | (R/W) |   | · | (R/W) | (R/W) | (R) |                        |

[Bit 7] EN: Counter-operation enable bit

At the timer function, when 1 is written at this bit, the value of the data register is loaded to start the decre menting. At the pulse-width measurement function, when 1 is written at this bit, the measurement-enable state is set. Under this condition, decrementing starts when the edge of the measured pulse is detected. When 0 is written at this bit during measurement, the operation stops but the value of the counter is not transferred to the buffer (RLBR).

|   | Timer function               | Pulse-width measurement function              |
|---|------------------------------|-----------------------------------------------|
| 0 | Count-operation disable      | Pulse-width measurement function stop/disable |
| 1 | Count-operation enable/start | Pulse-width measurement function enable/start |

### [Bit 6] TOE: TO bit output-enable bit

When Bit 6 is set to 1, the contents of the TO bit are output to port P37.

| 0  | General-purpose port (P37) (default) |
|----|--------------------------------------|
| 1. | TO bit output (WTO)                  |

If this bit is set to 1 even after the DDR of P37 is set to input, the port functions as the TO bit output port.

#### [Bit 5] IE: Interrupt-enable bit

When Bit 5 is 1, an interrupt request is output if the interrupt-request flags (UF, IR, and BF) are set.

| 0 | Interrupt disabled (default) |
|---|------------------------------|
| 1 | Interrupt enabled            |

## [Bit 2] UF: Underflow interrupt-request bit

Bit 2 indicates the presence or absence of timer overflow. The meaning of each bit to be read is as follows:

| 0 | Underflow does not occur. |
|---|---------------------------|
| 1 | Underflow occurs.         |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

[Bit 1] IR: Bit for interrupt request at measurement termination

When the IE bit (bit 5) of the PCR1 is 1, an interrupt occurs at termination of pulse measurement. The meaning of each bit to be read is as follows:

| 0 | Pulse-width measurement not terminated |
|---|----------------------------------------|
| 1 | Pulse-width measurement terminated     |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

## [Bit 0] BF: Buffer-full flag

When the IE bit (bit 5) of the PCR1 is 1, an interrupt occurs if any measured value is found in the RLBR. This bit is set when the pulse-width measurement is terminated, and is cleared when data in the buffer is read. The meaning of each bit to be read is as follows:

| 0 | Pulse-width measured value not found |
|---|--------------------------------------|
| 1 | Pulse-width measured value found     |

FUITSL

(b) Pulse-width control register 2 (PCR2)

The PCR2 is used to select the timer operation modes.

Rewriting is possible only when bit 7 (EN) of the PCR1 is 0.

|                            | Bit 7 |       | Bit 5 |         |       |       |       |       | Initial value          |
|----------------------------|-------|-------|-------|---------|-------|-------|-------|-------|------------------------|
| Address: 0016 <sub>H</sub> | FC    | RM    | то    | -       | C1    | CO    | W1    | W0    | 000X 0000 <sub>B</sub> |
|                            | (R/W) | (R/W) | (R/W) | · · · . | (R/W) | (R/W) | (R/W) | (R/W) |                        |

## [Bit 7] FC: Function-select bit

Bit 7 is used to select the timer and pulse-width measurement functions.

| 0 | Timer function                   |
|---|----------------------------------|
| 1 | Pulse-width measurement function |

# [Bit 6] RM: Timer mode-select bit

At the timer function, this bit is used to select the modes below.

| 0 | Reload-timer mode   |
|---|---------------------|
| 1 | One-shot timer mode |

#### [Bit 5] TO: Timer-output bit

The value of Bit 5 is reversed each time the counter underflows. When the TOE bit (bit 6 of CSR1) is 1, the contents of this bit are output from the WTO pin.

#### [Bits 3 and 2] C1 and C0: Counter clock-pulse select bits

Setting is made as shown below by a combination of these bits. These bits are not related to the value of the FC bit.

| C1 | C0 | Count clock pulse                            |
|----|----|----------------------------------------------|
| 0  | 0  | Internal clock pulse 1 instruction cycle     |
| 0  | 1  | Internal clock pulse 1/4 instruction cycle   |
| 1  | 0  | Internal clock pulse 1/32 instsruction cycle |
| 1  | 1  | Do not set.                                  |

[Bits 1 and 0] W1 and W0: Measured pulse-select bit

Setting is made as shown below by a combination of these bits. These bits are not relevant in the timerop eration mode (at FC = 0).

| W1 | WO | Measured pulse width         |  |  |  |  |  |  |  |  |
|----|----|------------------------------|--|--|--|--|--|--|--|--|
| 0  | 0  | High level                   |  |  |  |  |  |  |  |  |
| 0  | 1  | Low level                    |  |  |  |  |  |  |  |  |
| 1  | 0  | Rising edge to rising edge   |  |  |  |  |  |  |  |  |
| 1  | 1  | Falling edge to falling edge |  |  |  |  |  |  |  |  |

# (c) Reload buffer register (RLBR)

At the timer function, this register can be read and written. At the pulse-width measurement function, it functions as the read-only data buffer register used for holding the measured value. In this case, writing is impossible. Data is read to clear the BF flag (bit 0) of the PCR1.

|                                             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|---------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0017 <sub>H</sub>                  |       |       |       |       |       |       |       |       | XXXX XXXX <sub>B</sub> |
| At timer function $\Rightarrow$             | (R/W) |                        |
| At pulse-width ⇒<br>measurement<br>function | (R)   |                        |

- (4) Description of operation
- (a) Timer function

This timer has the following two modes: reload timer and one-shot timer.

(1) Reload timer mode

Each time the counter underflows, the value written at the RLBR is reloaded to continue the decrement ing. When the counter underflows, the interrupt flag UF (bit 2) is set. If the IE bit (bit 5) is set to 1, an interrupt request is output. If the TOE bit (bit 6) is set to 1, the value of the TO bit is reversed each time the timer underflows.

(2) One-shot timer mode

When an underflow occurs, the timer stops operation. When the counter underflows, the interrupt re quest flag UF (bit 2) is set. The EN bit (bit 7) is automatically set to 0 to stop counting.

In both modes, counting starts when 1 is written at the EN bit (bit 7), and it stops when 0 is written.

- (b) Pulse-width measurement function
  - (1) Measurement start

Writing 1 at the FC bit (bit 7) and EN bit (bit 7) causes the counter to enter the operation-enable state. Counting starts when the edge of the measured pulse input is detected under this condition. At the pulse-width measurement function, decrementing is started from  $FF_{H}$ .

(2) Measurement end and measured value

When measurement is terminated, the counter transfers the measured value to the buffer, sets the measurement-end flag IR (bit 1) and buffer-full flag BF (bit 0), and then enters the operation-enable state again. At this time, an interrupt request is output if the IE bit (bit 5) is set to 1. However, if the previous measured value cannot be read after continuous pulse-width measurement, continue to set the BF flag to hold the previous measured value. The new measured value is discarded.

(3) Long pulse

If the counter undeflows during measurement, set the UF bit (bit 2) to continue counting. In this case, an interrupt request is also output if the IE bit (bit 5) is set to 1.

(4) Operation stop

Measurement stops when 0 is written at the EN bit (bit 7).

(5) Calculation of pulse width

The measured value to be transferred to the buffer is the same as that of the counter when measure ment is terminated. Therefore, the pulse width should be calculated as follows:

Pulse width = [(256 - counter value) + (Number of TO reversed  $\psi$  256)]  $\psi$  1 cycle width of count clock pulse

## (6) Others

The counter is in the operation-enable state even after the end of measurement, so continuous pulsewidth measurement is enabled. The High width measurement is started from the changing edge of the input pulse. If the input pulse is already High, enable the EN bit (0 %1) to perform counting after the next rising edge occurs.



## (5) Precautions for use

- (a) When the EN bit is 1 (during timer operation or pulse-width measurement), do not rewrite the con tents of the PCR2.
- (b) When the mode is switched (the FC bit is rewritten), the state of each flag does not change. There fore, clear each flag immediately after switching the mode.
- (c) Read the measured value before the next underflow occurs. If the value is read after an underflow occurs, the TO bit is reversed, sometimes disabling calculation of the correct measured value.
- (d) If the previous measured value cannot be read after continuous pulse-width measurement, hold the previous measured value without transferring the new one to the buffer.

FUĨITSU

## 2.2.4 16-bit Timer/Counter (Timer 3)

- 16-bit binary timer/counter
- It is possible to select the timer function for count-clocking internal clock sources and the counter function for counting by detecting an arbitrary edge of the external pin input.
- An arbitrary byte value can be written from the data bus to the counter.
- An interrupt request can be output to the CPU by detecting counter overflow.

#### (1) Registers



(2) Block diagram



Note: The CPU clock pulse is the pulse with 1/4 oscillation.

- (3) Description of registers
- (a) Timer-control register (TMCR)

This 6-bit register selects and controls various operations of the counter, and controls interrupts.

|                            | Bit 7       | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value |
|----------------------------|-------------|-------|-------|-------|-------|-------|-------|-------|---------------|
| Address: 0018 <sub>H</sub> | $r = r^{2}$ | _     | TCR   | TCS1  | TCF0  | TCEF  | TCIE  | TCS   | XX00 0000B    |
|                            |             |       | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | •             |

## [Bit 5] TCR: Counter-clear bit

Bit 5 is used to clear the counter. The meaning of each bit to be written is as follows:

| 0 | Counter cleared - The contents of the 16-bit counter are set to 0000 g. |  |
|---|-------------------------------------------------------------------------|--|
| 1 | Other counters not affected                                             |  |

The read value of this bit is always 1.

[Bits 4 and 3] TCS1 and TCS0: Timer/counter operation-mode select bits

These bits are used to select the timer/counter operation mode and to determine the detection edge of the external-count clock pulse to be detected in the counter- operation mode. The counter-operation mode and the detection edge of the external-count clock pulse are selected as shown below.

| Table 2.7 | Selection of | f Timer/Counter | <b>Operation Mode</b> |
|-----------|--------------|-----------------|-----------------------|
|-----------|--------------|-----------------|-----------------------|

| TCS1 | TCS0 | Operation mode                                  |                                        |  |  |  |  |  |
|------|------|-------------------------------------------------|----------------------------------------|--|--|--|--|--|
| 0    | 0    | Timer mode (Internal clock source operation)    |                                        |  |  |  |  |  |
| 0    | 1    |                                                 | Detect falling edge of external input. |  |  |  |  |  |
| 1    | 0    | Counter mode Detect rising edge of external inp |                                        |  |  |  |  |  |
| 1    | 1    |                                                 | Detect both edges of external input.   |  |  |  |  |  |

## [Bit 2] TCEF: Interrupt-request flag

Bit 2 is a flag for interrupt request due to counter overflow. The meaning of each bit to be read is as follows:

| 0 | Counter does not overflow.                                          |
|---|---------------------------------------------------------------------|
| 1 | Counter overflows (counter value $FFFF_{R} \Rightarrow 0000_{R}$ ). |

**Note:** 1 is always read when the Read Modify Write instruction is read. When interrupt-output is enabled (TCIE = 1), an interrupt request is output to the CPU if this bit is 1.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |



#### [Bit 1] TCIE: Interrupt-request output-enable bit

Bit 1 is used to enable and disable interrupt output to the CPU. When the bit is 1, an interrupt request is output if the interrupt flag TCEF (bit 2) is set to 1. When the bit is 0, interrupt-request output is disabled.

| 0 | Interrupt-request output disabled |
|---|-----------------------------------|
| 1 | Interrupt-request output enabled  |

#### [Bit 0] TCS: Count start bit (counter-enable bit)

Bit 0 is used to start and stop the counter. When 1 is written at this bit, the TCR is enabled for counting and the value of the counter is incremented by the count clock. When 0 is written, the TCR stops counting to hold the value of the counter.

| 0 | Count disabled |
|---|----------------|
| 1 | Count enabled  |

#### (b) Timer-count register (TCR)

The TCR is a 16-bit binary up counter. TCHR is used for upper bytes; the TCLR is used for lower bytes. Writing to the counter should be performed when counting stops (TCS bit (bit 0) of TMCR = 0). To read the counter, always use the word transfer instructions (MOVW A, dir, etc.).

|          |                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial | value             |      |
|----------|-------------------|-------|-------|-------|-------|-------|-------|-------|-------|---------|-------------------|------|
| Address: | 0019 <sub>H</sub> |       |       |       |       |       |       |       |       | 0000    | 0000 <sub>B</sub> | TCHR |
| Address: | 001A <sub>H</sub> |       |       |       |       |       |       |       |       | 0000    | 0000 <sub>B</sub> | TCLR |
|          |                   | (R/W) | ,       |                   |      |

- (4) Description of functions
- (a) Operation modes

The operation modes of the 16-bit timer/counter can be selected from the timer and counter modes by a combination of bit 3 (TCS0) and bit 4 (TCS1) of the TMCR.

(1) Timer mode

Setting values other than  $00_B$  at bit 3 (TCS0) and bit 4 (TCS1) of the TMCR gives the timer mode. The TCR increments according to the internal clock source (1/4 oscillation or instruction cycle); external-count input is disabled at this time. Detecting an overflow enables generation of time intervals up to  $2^{16}$  times the clock source (65536 instruction cycles). The maximum time intervals are 32.8 ms at 8 MHz oscillation.

(2) Counter mode

Setting values other than  $00_B$  at bit 3 (TCS0) and bit 4 (TCS1) of the TMCR gives the counter mode. The edge polarities given in Table 2-1 can be selected according to the value to be set. The counter mode is divided into three according to the setting of the edge detection for the external-count input. In the counter mode, the TCR increments each time the arbitrary edge of the EC input for the external-count clock pin is detected. (The internal clock source is disabled at this time.) This enables counting with the number of external-count input events (arbitrary edges). The pulse width of the external-count clock input can be input from 8 to a minimum width of two instruction cycles (This corresponds to DC to 1/2 instruction cycle).

(b) Count start/stop

The TCR starts counting when 1 is written at bit 0 (TCS) of the TMCR, and stops counting when 0 is written.

(c) Counting and interrupt occurrence

In the timer mode, the TCR is incremented every one instruction cycle of the clock source; in the counter mode, it is incremented each time the effective edge of the external-count input is detected. When the counter value changes from  $\mathbf{FFFF}_{H}$  to  $0000_{H}$  (overflows), an overflow-interrupt request is output to the CPU if the interrupt flag TCEF (bit 2) of the TMCR is set to 1 and the interrupt-request output-enable bit TCIE (bit 1) is 1.

Any byte value can be set at the TCR. (This setting should be done when the counter stops (TCS = 0).) The value of the TCR can be read even during operation. To read, always use the word-transfer instructions (MOVW A, dir, etc.).

## (d) Counter clear

The TCR is cleared to  $0000_{\text{H}}$  when 0 is written at bit 5 (TCR) of the TMCR. If clearing is performed concur rently with overflow, the interrupt flag is not set.

# FUĴITSU

# 2.2.5 UART

Outline

- Full-duplex double buffers
- CLK synchronous and asynchronous data transfer
- 14 baud rates (for internal clock) The baud rate can also be freely selected by external clock input or input from the internal timer.
- Variable data length
- NRZ transfer format
- (1) Registers

| it ——• |                   |          |
|--------|-------------------|----------|
| с      | 002D <sub>H</sub> | Address: |
| С      | 002E <sub>H</sub> | Address: |
| D      | 002F <sub>H</sub> | Address: |
| R      | 0030 <sub>H</sub> | Address: |
| R      | 0030 <sub>H</sub> | Address: |
|        | 0030 <sub>H</sub> | Address: |

R/W Serial mode control register

R/W Serial rate control register

R/W Serial status and data register

R Serial input data register

W Serial output data register

(2) Block diagram



(3) Description of registers

(a) Serial mode control register (SMC)

This register is used to select the UART operation mode.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 002D <sub>H</sub> | PEN   | SBL   | MC1   | MC0   | SMDE  | _     | UCKE  | UOE   | 0000 0-00 <sub>B</sub> |
|                            | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |       | (R/W) | (R/W) |                        |

## [Bit 7] PEN: Parity enable

Bit 7 is used to determine whether to append a parity bit (when transmitting) or to detect it (when receiving) for serial data input/output.

| 0 | No parity (default)                                               |
|---|-------------------------------------------------------------------|
| 1 | Parity (Odd or even parity is set by TD8/TP of the SSD register.) |

#### [Bit 6] SBL: Stop bit length

Bit 6 is used to determine the stop bit length of transmit data. At the receiving end, only the first bit of the stop bit is recognized; second and later bits are ignored (default: 0).

| 0 | 2-bit length (default) |
|---|------------------------|
| 1 | 1-bit length           |

## [Bits 5 and 4] MC1 and MC0: Mode control

Bits 5 and 4 are used to select the transfer mode (data length).

| MC1 | MC0 | Mode            | Data length     |
|-----|-----|-----------------|-----------------|
| 0   | 0   | 0               | 7 (6)           |
| 0   | 0   | 0               | 8 (7)           |
| 1   | 1   | can not be used | can not be used |
| 1   | 1   | 1               | 9 (8)           |

(Initial value) Values in parentheses indicate the data length with parity.

[Bit 3] SMDE:

| 0 | Synchronous transfer (default) |
|---|--------------------------------|
| 1 | Asynchronous transfer          |



## [Bit 1] UCKE: UART clock enable

When 1 is written at bit 1, the UART serial clock output pin is switched to the port to output an external synchronous clock pulse.

If the mode in which a synchronous clock pulse is input from the outside is set by the CS1 and CS0 bits of the SRC register, the value can also be read from the port as the input pin.

| 0 | Port functions as general-purpose input/output port that does not output serial clock pulse.<br>(default)<br>When the port is set to input (DDR = 0), it also functions as a serial clock input pin. |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | Port functions as UART serial clock output pin.                                                                                                                                                      |

In the external clock input mode, set this bit to 0.

## [Bit 0] UOE: UART output enable

When 1 is written at bit 0, the port is switched to the UART serial data output pin to enable serial data output.

| 0 | No parity (default)                                               |
|---|-------------------------------------------------------------------|
| 1 | Parity (Odd or even parity is set by TD8/TP of the SSD register.) |

(b) Serial rate control register (SRC)

This register is used to control the data transfer speed (baud rate) of the UART.

|                            | Bit 7 |   |       | Bit 4 |       |       |       |       | Initial value        |
|----------------------------|-------|---|-------|-------|-------|-------|-------|-------|----------------------|
| Address: 002E <sub>H</sub> | -     | - | CR    | SCS1  | SCS0  | RC2   | RC1   | RC0   | 01 1000 <sub>B</sub> |
|                            |       |   | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |                      |

[Bit 5] CR: Clock rate

Bit 5 is used to select the asynchronous transfer clock rate. However, when the CS1 and CS0 bits are 11<sub>B</sub>, the 1/8 clock rate is selected irrespective of the value of the CR bit.

| 0 | 1/16 of clock input (default) |
|---|-------------------------------|
| 1 | 1/64 of clock input           |

Note: The synchronous transfer clock rate is as follows irrespective of the value of the CR bit: Internal clock 1/2.....1/2 External clock, dedicated baud rate generator ......1/1 Clock source -

## [Bits 4 and 3] SCS1 and SCS0: Clock select

Bits 4 and 3 are used to select the clock input of the UART port. If the external or internal clock is selected as clock input, the baud rate is a 1/16 or 1/64 clock frequency according to the value of the CR bit (default:  $11_B$ ). For details, see 4.4.

#### [Bits 2 to 0] RC2 to RC0:

Bits 2 to 0 are needed only when generating a serial clock pulse with the dedicated baud rate generator. Fourteen baud rates can be selected by these bits (default:  $000_{B}$ ). For the baud rate setting, see 4.4.

(c) Serial status and data register (SSD)

This register is used to indicate the current status of the UART. When the data communication length is 9 bits, the most significant data (bit 8) is included.

|            |                  |      |      | Bit 5 |       |       |       |        |        | Initial |                   |
|------------|------------------|------|------|-------|-------|-------|-------|--------|--------|---------|-------------------|
| Address: 0 | 02F <sub>H</sub> | RDRF | ORFE | TDRE  | TIE   | RIE   | PSEL  | TD8/TP | RD8/RP | 0010    | 001X <sub>B</sub> |
|            |                  | (R)  | (R)  | (R)   | (R/W) | (R/W) | (R/W) | (R/W)  | (R)    |         |                   |

## [Bit 7] RDRF:

The RDRF flag is used to indicate the data status of the serial input data register (SIDR).

| 0 | Empty (default) |
|---|-----------------|
| 1 | Contains data   |

When the SIDR register is read after reading the SSD register with the RDRF flag set to 1, the RDRF flag is cleared. When this flag is set to 1, the receiver interrupt request is output.

## [Bit 6] ORFE:

The ORFE flag is used to indicate that an overrun or framing error has occurred. This flag is initialized to 0 at reset.

| 0 | Normal |
|---|--------|
| 1 | Error  |

If this flag is set, data is not transferred from the receive shift register to the SIDR register.

When the SIDR register is read after reading the SSD register with the ORFE flag set to 1, the ORFE flag is cleared. When this flag is set to 1, the receiver interrupt request is output.

The status of input data is specified by the RDRF and ORFE flags as follows:

| RDRF | ORFE | SIDR data status                                                            |
|------|------|-----------------------------------------------------------------------------|
| 0    | 0    | Empty                                                                       |
| 0    | 1    | Framing error (If new data is input under this condition, RDRF is not set.) |
| 1    | 0    | Normal data                                                                 |
| 1    | 1    | Overrun (previous data remains)                                             |

#### [Bit 5] TDRE:

The TDRE flag is used to indicate the status of the serial output data register (SODR).

| 0 | Contains data   |
|---|-----------------|
| 1 | Empty (default) |

When data is written to the SODR register after reading the SSD register with the TDRE flag set to 1, serial data is output from the SOUT pin.

When the TDRE flag is set to 1, a transmitter interrupt request is output.

[Bit 4] TIE: Transmitter interrupt request enable bit

Bit 4 is used to enable the transmitter interrupt request.

| 0 | Interrupt disabled (default) |
|---|------------------------------|
| 1 | Interrupt enabled            |

#### [Bit 3] RIE: Receiver interrupt request enable bit

Bit 3 is used to enable the receiver interrupt request.

| 0 | Interrupt disabled (default) |
|---|------------------------------|
| 1 | Interrupt enabled            |

#### [Bit 2] PSEL: Port select bit

Bit 2 is used to select the UART ports.

| 0 | P30 to P32 selected (default) |  |  |  |
|---|-------------------------------|--|--|--|
| 1 | P40 to P42 selected           |  |  |  |

#### [Bit 1] TD8/TP

When parity is not provided, bit 1 is treated as bit 8 of the SODR register. When parity is provided, this bit is used to determine whether the parity of serial output data is even or odd.

| 0 | Odd parity  |
|---|-------------|
| 1 | Even parity |

#### [Bit 0] RD8/RP:

When parity is not provided, bit 0 is treated as bit 8 of the SIDR register. When parity is provided, this bit is used to determine whether the parity of serial input data is even or odd (default: undefined).

| 0 | Odd parity  |
|---|-------------|
| 1 | Even parity |

(d) Serial input data register (SIDR)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address: 0030 <sub>H</sub> |       |       |       |       |       |       |       |       |
|                            | (R)   |

The SIDR register is used for input of serial data (default: undefined).

(e) Serial output data register (SODR)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address: 0030 <sub>H</sub> |       |       |       |       |       |       |       |       |
| · ·                        | (W)   |

The SODR register is used for output of serial data (default: undefined).

#### (4) Description of operation

#### (a) Operation modes

The UART has the operation modes listed in Table 2-2; they can be switched by setting the value at the serial mode control register (SMC).

| Mode | Parity       | Data length | Clock mode               | Stop bit length |
|------|--------------|-------------|--------------------------|-----------------|
|      | Provided     | 6           | Asynchronous/synchronous | 1 bit or 2 bits |
| 0    | Not provided | 7           | Asynchronous/synchronous | 1 bit or 2 bits |
|      | Provided     | 7           | Asynchronous/synchronous | 1 bit or 2 bits |
| 1    | Not provided | 8           | Asynchronous/synchronous | 1 bit or 2 bits |
| 2    |              |             | Can not be used          |                 |
| 3    | Provided     | 8           | Asynchronous/synchronous | 1 bit or 2 bits |
| 3    | Not provided | 9           | Asynchronous/synchronous | 1 bit or 2 bits |

Table 2.8 Operation Modes of UART

However, the stop bit length can be specified only for the transmitter channel. The 1-bit length is always specified for the receiver channel.

(b) Interrupt occurrence and flag setting conditions

The UART has three flags and two interrupt sources.

The three flags are ORFE, RDRF, and TDRE. The ORFE flag is an overrun/framing error flag which is set when an error occurs at receiving. The RDRF flag indicates that the receive data is ready at the SIDR register. The TDRE flag indicates that writing to the transmit data register (SODR) is enabled.

The two interrupt sources are one for receiving, and one for transmitting. At receiving, an interrupt is re quested by the RDRF or ORFE flag. At transmitting, an interrupt is requested by the TDRE flag.

• Receiving in modes 0, 1, and 3

Both the RDRF (receive data register full) and ORFE (overrun/framing error) flags are set when receiving and transfer are completed and the last stop bit is detected. An interrupt request is then output to the CPU. When the RDRF flag is active, the received data is transferred to the serial data input register (SIDR).

| Data          | $\rightarrow$ | Stop | (Stop) |
|---------------|---------------|------|--------|
| RDRF          | '             | ·    |        |
| SIN interrupt |               |      |        |

Fig. 2.9 RDRF Flag Set Timing







#### • Transmission

When the next data is ready to write after data written to the serial output data register (SODR) is trans ferred to the interrupt shift register, the TDRE (transmit data register empty) flag is set and an interrupt request is output to the CPU.



Fig. 2.11 TDRE Flag Set Timing (Mode 0)

#### (c) Transfer data format

The UART can handle only NRZ (non-return-to-zero)-type data. The relationship between transmitter/re ceiver clocks and data is shown in the figure below.



Transmitted data is 01001101<sub>B</sub> (mode 1) or 101001101<sub>B</sub> (mode 3)

## Fig. 2.4 Transfer Data Format

As shown in the figure, data transfer starts from the start bit (Low-level data), the data bit length specified by the LSB first is transferred, and transfer ends at the stop bit (High-level data).

In asynchronous transfer, the relationship between UCK and SIN is not as shown in the above figure. In addition, at asynchronous transfer, the relationship is not as shown in the above diagram even when UCK is set to input.

## (d) Transfer clock selection

The transfer clock can be selected from the external clock (UCK pin), two internal clocks (PTO1 and PTO2), and the dedicated baud rate generator. This selection is done by the SCS0, SCS1, and CR bits of the serial rate control register (SRC). The division ratios are listed in Table 2-3.

| SCS1 | SCS0           | Clock input         | CR | Asynchronous | Synchronous |   |  |             |   |      |     |
|------|----------------|---------------------|----|--------------|-------------|---|--|-------------|---|------|-----|
| 0    | External clock |                     | 0  | 1/16         | 1/1         |   |  |             |   |      |     |
| 0    | 0              |                     | 1  | 1/64         | 1/1         |   |  |             |   |      |     |
|      |                | PWM timer 1         | 0  | 1/16         | 1/2         |   |  |             |   |      |     |
| 0 1  |                |                     | 1  | 1/64         | 1/2         |   |  |             |   |      |     |
|      | _              |                     |    | _            | 0           | 0 |  | PWM timer 2 | 0 | 1/16 | 1/2 |
| 1 0  |                |                     | 1  | 1/64         | 1/2         |   |  |             |   |      |     |
| 1    | 1              | Dedicated baud rate | -  | 1/8          | 1/1         |   |  |             |   |      |     |

 Table 2.9 Clock Division Ratio

The transfer clocks when using the dedicated baud rate generator are listed in Table 2-4.

## Table 2.10 Baud Rate Selection

| RC2 | RC1 | RC0 | CLK asynchronous (µs/baud) | CLK synchronous (µs/baud) |
|-----|-----|-----|----------------------------|---------------------------|
| 0   | 0   | 0   | 104/9615                   | 1 /1 M                    |
| 0   | 0   | 1   | 208/4808                   | 2/500 K                   |
| 0   | 1   | 0   | 416/2404                   | 4/250 K                   |
| 0   | 1   | 1   | 832/1202                   | 8/125 K                   |
| 1   | 0   | 0   | 1664/601                   | 16/62.5 K                 |
| 1   | 0   | 1   | 3228/300                   | 32/31.25 K                |
| 1   | 1   | 0   | 16/62500                   | 2/500 K                   |
| 1   | 1   | 1   | 128/7813                   | 16/62.5 K                 |

(At 10-MHz oscillation)

**Note:** After canceling register initialization by a reset, initialization of the internal control section requires an initialization time of 11 shift clocks.



(e) Expression for Calculating Dedicated Baud Rate (UART)

The dedicated baud rate is determined by the settings of the clock gear, <u>clock division ratio registers (SCS1</u> and SCS0), and <u>baud rate select registers (RC2, RC1 and RC0)</u>. The baud rate is calculated as follows:



• Clock division ratio (SCS1, SCS0)

When using a dedicated baud rate, set the clock division ratio register SCS1 to 1 and SCS0 to 0. The clock division ratio results in 1/8 in the asynchronous mode.

| SCS1 | SCS0 | Clock input         | Asynchronous mode |
|------|------|---------------------|-------------------|
| 1    | 1    | Dedicated baud rate | 1/8               |

• Baud rate selection (RC2, RC1, RC0)

The baud rates can be selected depending on the settings of RC2, RC1, and RC0. For example, the baud rates at an original oscillation of 10 MHz are listed in the following table.

| RC2 | RC1 | RC0 | Division ratio selected as baud rate | CLK in asynchronous<br>mode (μs/baud) |
|-----|-----|-----|--------------------------------------|---------------------------------------|
| 0   | 0   | 0   | 13                                   | 104/9615                              |
| 0   | 0   | 1   | 26                                   | 208/4808                              |
| 0   | 1   | 0   | 52                                   | 416/2404                              |
| 0   | 1   | 1   | 104                                  | 832/1202                              |
| 1   | 0   | 0   | 208                                  | 1664/601                              |
| 1   | 0   | 1   | 416                                  | 3328/300                              |
| 1   | 1   | 0   | 2                                    | 16/62500                              |
| 1   | 1   | 1   | 16                                   | 128/7813                              |

(Original oscillation: 10 MHz)

(f) Expression for Calculating Baud Rate (UART)

The baud rate is determined by the clock input selected by the clock division ratio registers (SCS1 and SCS0). The clock inputs of the external clock and the PWM timer 1/PWM timer 2 are selectable. Each expression for calculating baud rate is given below.

• External clock selected

• PWM timer 1/PWM timer 2 selected



FUĴĨTSU

# 2.2.6 8-bit Serial I/O 1

- 8-bit serial data transfer is possible by the clock synchronous method.
- LSB first or MSB first can be selected for data transfer.
- Four shift-clock modes (three internal and one external) can be selected.

## (1) Registers



(2) Block diagram



(3) Description of registers

(a) Serial-mode register 1 (SMR1)

The SMR1 is used to control serial I/O.

|                            | Bit 7 |       | Bit 5 |       |       |       |       |       | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 001C <sub>H</sub> | SIOF  | SIOE  | SCKE  | SOE   | CKS1  | CKS0  | BDS   | SST   | 0000 0000 <sub>B</sub> |
|                            | (R/W) |                        |

## [Bit 7] SIOF: Serial I/O interrupt-request flag

Bit 7 indicates the serial I/O transfer state.

The meaning of each bit to be read is as follows:

| 0 | Serial data transfer not terminated |
|---|-------------------------------------|
| 1 | Serial data transfer terminated     |

Note that 1 is always read when the Read Modify Write instruction is read. If this bit is set when an interrupt is enabled (SIOE = 1), an interrupt request is output to the CPU.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

The end-of-transfer decision may be made by either the SST bit (bit 0) of the SMR or by this bit.

## [Bit 6] SIOE: Serial I/O interrupt-enable bit

Bit 6 is used to enable a serial I/O interrupt request.

| 0 | Serial I/O interrupt-output disable |
|---|-------------------------------------|
| 1 | Serial I/O interrupt-output enable  |

#### [Bit 5] SCKE: Shift-clock output-enable bit

Bit 5 is used to control the shift-clock I/O pins.

| 0 | General-purpose port pins (P33) or SCK1 input pin |
|---|---------------------------------------------------|
| 1 | SCK1 (shift clock) output pin                     |

When using the P33/SCK1 and P55/SCK2 pins as external clocks, always set the DDR to input (bit 3 of DDR3 = 0).

FUĴITSU

#### [Bit 4] SOE: Serial-data output-enable bit

Bit 4 is used to control the output pins for serial I/O.

| 0 | General-purpose port pins (P34) |
|---|---------------------------------|
| 1 | SO (serial data) output pin     |

When using P35/SI1 and P57/SI2 pins as the SI pin, always set the DDR to input (bit 3 of DDR3 = 0).

[Bits 3 and 2] CKS1 and CKS0: Shift-clock select bits

Bits 3 and 2 are used to select the serial shift-clock modes.

| CKS1 | CKS0 | Mode                      | (Clock rate)             | SCK    |
|------|------|---------------------------|--------------------------|--------|
| 0    | 0    | Internal shift-clock mode | (1/2 instruction cycle)  | Output |
| 0    | 1    | Internal shift-clock mode | (1/8 instruction cycle)  | Output |
| 1    | 0    | Internal shift-clock mode | (1/32 instruction cycle) | Output |
| 1    | 1    | External shift-clock mode | (SCK1)                   | Input  |

[Bit 1] BDS: Transfer direction select bit

At serial data transfer, Bit 1 is used to select whether data transfer is performed from the least significant bit first (LSB first) or from the most significant bit first (MSB first).

| 0 | LSB first |  |
|---|-----------|--|
| 1 | MSB first |  |

Note that when this bit is rewritten after writing data to the SDR, the data become invalid.

#### [Bit 0] SST: Serial I/O transfer-start bit

Bit 0 is used to start serial I/O transfer. The bit is automatically cleared to 0 when transfer is terminated.

| 0 | Serial I/O transfer stop  |
|---|---------------------------|
| 1 | Serial I/O transfer start |

Before starting transfer, ensure that transfer is stopped (SST = 0).

(b) Serial-data register 1 (SDR1)

This 8-bit register is used to hold serial I/O transfer data. Do not write data to this register during the serial I/O operation.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 001D <sub>H</sub> |       |       |       |       |       |       |       |       | XXXX XXXX <sub>B</sub> |
|                            | (R/W) |                        |



- (4) Description of operation
- (a) Outline

This module consists of the serial-mode register (SMR) and serial-data register (SDR). At serial output, data in the SDR is output in bit serial to the serial output pin (SO) in synchronization with the falling edge of a serial shift-clock pulse generated from the internal or external clock. At serial input, data is input in bit serial from the serial input pin (SI) to the SDR at the rising edge of a serial shift-clock pulse.



## (b) Operation modes

The serial I/O has three internal shift-clock modes and one external shift-clock mode, which are specified by the SMR. Mode switching or clock selection should be made with serial I/O stopped (SST bit (bit 0) of SMR = 0).

(1) Internal shift-clock mode

Operation is performed by the internal clock. A shift-clock pulse with a duty of 50% is output from the SCK pin as a synchronous timing output. Data is transferred bit-by-bit at every clock pulse.

(2) External shift-clock mode

Data is transferred bit-by-bit at every clock pulse in synchronization with the external shift-clock pulse input from the  $\overline{SCK}$  pin. If an external clock is input when the SST bit is set to 0, no shift operation occurs and data of the SDR register (or the value of bit 7 when MSB first used) is output to the SO pin. However, the pin value is also rewritten when the SDR register data is rewritten. The transfer speed can be from DC to 1/2 oscillation (two instruction cycles). When one instruction cycle is 0.4 $\mu$ s (at 10 MHz oscilla tion), the transfer speed can be up to 1.25 MHz.

Do not write data to the SMR and SDR during the serial I/O operation in either mode.

(c) Interrupt functions

This module can output an interrupt request to the CPU. To output an interrupt request, set the SIOE bit (bit 6) of the SMR to 1 to enable an interrupt and then set the interrupt flag SIOF (bit 7) of SMR after 8-bit data transfer is terminated.



#### (d) Shift start/stop timing

Data transfer starts when 1 is written at the SST bit (bit 0) of the SMR, and stops when 0 is written. When data transfer is terminated, the SST bit is automatically cleared to 0, which stops the operation.

(1) Internal shift-clock mode (LSB first)

[When transfer terminated]



**Note:** When data is written at the SDR, the output data changes at the falling edge of the external-clock pulse.



# (e) Input/output shift timing

Data is output from the serial output pin (SO) at the falling edge of the shift-clock pulse, and is input from the serial input pin (SI) to the SDR at the rising edge of the shift-clock pulse.



Fig. 2.13 Input/Output Shift Timing

FUĬĨTSU

## 2.2.7 10-bit A/D Converter

This is an 10-bit sequential-comparison A/D converter. This register has the following features:

- A/D conversion time: 33 instruction cycles 13.2 µs (at 10 MHz oscillation)
- Sense function: Compare time 18 instruction cycles 7.2 μs at 10 MHz.
   The sense function compares the preset value in the data register with the analog input value.
- Start by program or continuous start external input clock selectable
- · End detection enabled by interrupt or software polling

(1) Registers

|                            | ← 8 bit ► |                                        |
|----------------------------|-----------|----------------------------------------|
| Address: 0020 <sub>H</sub> | ADC1      | R/W A/D control-status register 1      |
| Address: 0021 <sub>H</sub> | ADC2      | R/W A/D control-status register 2      |
| Address: 0022 <sub>H</sub> | ADDH      | R/W A/D data register H (Upper 2 bits) |
| Address: 0023 <sub>H</sub> | ADDL      | R/W A/D data register L (Lower 2 bits) |
|                            |           |                                        |

#### (2) Block diagram



## (3) Description of registers

(a) A/D converter control register 1 (ADC1)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0020 <sub>H</sub> | ANS3  | ANS2  | ANS1  | ANS0  | ADI   | ADMV  | SIFM  | AD    | 0000 0000 <sub>B</sub> |
|                            | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R)   | (R/W) | (R/W) |                        |

[Bits 7 to 4] AN3 to AN0: Analog-input channel select bits

These four bits are used to select analog-input channel.

| ANS3 | ANS2 | ANS1 | ANS0 | Select channel | ANS3 | ANS2 | ANS1 | ANS0 | Select channel |  |
|------|------|------|------|----------------|------|------|------|------|----------------|--|
| 0    | 0    | 0    | 0    | ANO            | 0    | 0    | 0    | 0    |                |  |
| 0    | 0    | 0    | 1    | AN1            | 0    | 0    | 0    | 1    | _              |  |
| 0    | 0    | 1    | 0    | AN2            | 0    | 0    | 1    | 0    |                |  |
| 0    | 0    | 1    | 1    | AN3            | 0    | 0    | 1    | 1    | —              |  |
| 0    | 1    | 0    | 0    | AN4            | 0    | 1    | 0    | 0    |                |  |
| 0    | 1    | 0    | 1    | AN5            | 0    | 1    | 0    | 1    |                |  |
| 0    | 1    | 1    | 0    | AN6            | 0    | 1    | 1    | 0    |                |  |
| 0    | 1    | 1    | 1    | AN7 0 1 1 1    |      |      |      |      |                |  |

#### [Bit 3] ADI: Interrupt-flag bit

The meaning of each bit to be read in the A/D mode is as follows:

| 0 | Conversion not terminated. |
|---|----------------------------|
| 1 | Conversion terminated.     |

The meaning of each bit to be read in the sense mode is as follows:

| 0 | Conditions specified by SIFM bit not met |  |  |  |
|---|------------------------------------------|--|--|--|
| 1 | Conditions specified by SIFM bit met     |  |  |  |

In both the A/D and sense modes, an interrupt request is output if these bits are set when the ADIE bit (bit 4) of the ADC2 is 1.

The meaning of each bit to be written in both the A/D and sense modes is as follows:

| 0 | This bit is cleared.                            |  |  |  |
|---|-------------------------------------------------|--|--|--|
| 1 | This bit does not change nor affect other bits. |  |  |  |

1 is always read when the Read Modify Write instruction is read.

#### [Bit 2] ADMV: Conversion-on/comparison-on flag

This flag indicates that A/D conversion/comparison is in progress.

| 0 | Conversion/comparison not in progress |
|---|---------------------------------------|
| 1 | Conversion/comparison in progress     |

#### [Bit 1] SIFM: Interrupt-source setting bit

Bit 1 is used to set the conditions for setting the interrupt source in the sense mode.

| 0 | Set interrupt source when analog input value lower than the value set by the data register.  |
|---|----------------------------------------------------------------------------------------------|
| 1 | Set interrupt source when analog input value higher than the value set by the data register. |

#### [Bit 0] AD: A/D conversion start bit

When the EXT bit (bit 1) of the ADC2 is 0, writing 1 at this bit starts the A/D conversion in both the A/D and sense modes. Writing 0 at this bit does not make sense. 0 is always read. The meaning of each bit to be written is as follows:

| 0 | No A/D conversion                                    |
|---|------------------------------------------------------|
| 1 | A/D conversion start (when EXT (bit 1) of ADC2 is 0) |

(b) A/D converter control and status display register 2 (ADC2)

The ADC2 is used to control the A/D converter and display its status.

|                            |  |       |       |       |       | Bit 2 |       |       | Initial value          |
|----------------------------|--|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0021 <sub>H</sub> |  | TIM1  | TIMO  | ADCK  | ADIE  | ADMD  | EXT   | TEST  | X000 0001 <sub>B</sub> |
|                            |  | (R/W) |                        |

[Bits 6 and 5] TIM1 and 0: Reserved bits

Always set 00 at these bits.

| TIM1 | TIMO | Conversion time at 10 MHz       | Compara time at 10 MHz         |  |  |  |
|------|------|---------------------------------|--------------------------------|--|--|--|
| 0    | 0    | 33 instruction cycles (13.2 µs) | 18 instruction cycles (7.2 µs) |  |  |  |

[Bit 4] ADCK: External input-clock pulse-select bit

Bit 4 is used to select the external input clock pulse for starting A/D conversion.

| 0 | 2 <sup>8</sup> division of high speed clock oscillation |
|---|---------------------------------------------------------|
| 1 | Input to P50/ADST                                       |

When using the external-clock input, set the DDR of P30 to input.

## [Bit 3] ADIE: Interrupt-enable specifying bit

Bit 3 is used to specify interrupt enable/disable.

| 0 | Interrupt disabled |
|---|--------------------|
| 1 | Interrupt enabled  |

[Bit 2] ADMD: Function select bit

Bit 2 is used to select the A/D mode and sense mode.

| 0 | A/D mode   |  |
|---|------------|--|
| 1 | Sense mode |  |

# [Bit 1] EXT: Conversion select bit

Bit 1 is used to select starting method of A/D conversion.

| 0 | Start by AD (bit 0) of ADC1                                          |  |
|---|----------------------------------------------------------------------|--|
| 1 | Start at rising edge of clock pulse selected by ADCK (bit 4) of ADC2 |  |

## [Bit 0] TEST: Testing bit

Bit 0 is used only for testing. <u>Always write 1 at this bit.</u> 1 is always read.

(c) A/D data registers H and L (ADDH, ADDL)

These registers store the results of A/D conversion in A/D mode. They write the setting value for the com parison in it in sense mode. Upper 2 bits and Lower 8 bits assigned to ADDH and ADDL, respectivery.

|            |                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|------------|-------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0 | 0022 <sub>H</sub> |       |       |       |       |       |       |       |       | XXXX XXXX <sub>B</sub> |
|            |                   | (R/W) |                        |
|            |                   |       |       |       |       |       |       |       |       |                        |
|            |                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
| Address: 0 | 023 <sub>H</sub>  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     | XXXX XXXX <sub>B</sub> |
|            |                   | (R/W) |                        |

• A/D mode

In the A/D mode, the results are stored as soon as the A/D conversion is terminated. After the conversion, the contents of the register are held until next conversion is started. Once started, the value becomes undefined. Therefore, always read the data after the end of conversion.

Sense mode

In the sense mode, the vale to be compared with the converted value is written in these registers in ad vance. The contents set in the register are held without changing by the comparison operation.

Do not write data during conversion in either the A/D or sense mode.

#### (4) Description of operation

- (a) A/D mode
  - (1) Start or restart by program

Writing 0 at the ADMD bit (bit 2) of the ADC2 gives the A/D mode. Writing 1 at the AD bit (bit 0) of the ADC1 starts the A/D conversion. If 1 is written at the AD bit (bit 0) of ADC1 during A/D conversion, the conversion operation is canceled and restarted.

(2) Start/restart by external clock

Writing 1 at EXT (bit 1) of ADC2 sets the AD mode to wait for starting by the external clock. A/D conversion is started after detecting the rising edge of the clock pulse selected by the ADCK bit (bit 4) of ADC2. If the rising clock pulse occurs during the operation, the conversion operation is canceled and restarted. When the external clock is used for starting or restarting by setting EXT (bit 1) to 1, A/D conversion cannot be started or restarted by the program.

(3) End

When A/D conversion is terminated, the result of the operation is stored in the data register and AD1 (bit 3) of ADC1 is set. At that time, an interrupt request is output when ADIE (bit 2) of ADC2 is 1. The conversion result is stored in the data register until next conversion starts. Therefore, read the conversion result before starting the next conversion. The result stored in the register is lost when the operation is restarted.

(4) Continuous start of AD conversion by external clock

The A/D conversion can be started continuously by providing an external clock based on the conver sion time and operation result reading time.

(b) Sense Mode

(1) Comparison/recomparison by program

Preprogram a specified comparison value in the data register.

Writing 1 at ADMD (bit 2) of ADC2 gives the sense mode. Writing 1 at AD (bit 0) of ADC1 starts compari son. If 1 is written at AD (bit 0) of ADC1 during comparison, the operation is canceled and restarted.

(2) Comparison/recomparison by external clock

Preprogram a specified comparison value in the data register.

Writing 1 at EXT (bit 1) of ADC2 sets the sense mode to wait for starting by the external clock. Compari son is started at after detecting rising edge of the clock pulse selected by the ADCK bit (bit 4) of ADC2. If the rising clock pulse occurs during the operation, comparison is canceled and restarted. When the external clock is used for comparison or recomparison, comparison and recomparison cannot be exe cuted by the program.

(3) End

When the result of the comparison meets the conditions specified by SIFM (bit 1) of ADC1, ADI (bit 3) of ADC1 is set. At that time, an interrupt request is output when ADIE (bit 2) of ADC2 is 1. If the result of the operation does not meet the specified conditions, ADI (bit 3) of ADC1 is not set. In this case, check that ADMV (bit 2) of ADC1 is 0.

The preset contents of the data register are held without loss by the comparison operation.

(4) Continuous start of comparison by external clock

Comparison can be started continuously by providing an external clock based on the comparison time.

FUĬĪTSU

- (5) Precautions for A/D converter
- (a) The A/D conversion and comparison are stopped and all registers are initialized by a reset. The operating flag bit [ADMV (bit 2) of ADC1] is cleared and other bits are not changed.
- (b) Activation cannot be performed by the program [AD (bit 1) of ADC1] when an external-clock start is selected.
- (c) Do not rewrite each register during conversion and comparison. When an external-clock start is selected, change the settings of the registers after writing 0 at EXT (bit 1) of ADC2 when operation is stopped [ADMV (bit 2) of ADC1 is 0] to inhibit an external-clock start. However, when program starting is selected [AD (bit 1) of ADC1], the analog input channel can be reselected and the inter rupt source for the sense mode can be switched at reset.
- (d) Switch the A/D or sense mode after clearing the ADI interrupt flag (bit 3) of ADC1.
- (e) To perform continuous conversion or comparison by an external clock, provide the clock based on the conversion or comparison time and the operation result reading time. The A/D conversion re sult is valid until the next conversion is started. The value set in the data register in the sense mode is held without loss by the comparison operation.

FUÏITSU

# 2.2.8 External Interrupt Circuit

- The edges of four external-interrupt sources (INT0 to INT3) can be detected to set the corresponding flag.
- An interrupt can be generated at the same time the flag is set.
- The four interrupts can release the STOP, SLEEP or watch mode.

### (1) Registers



## (2) Block diagram



(3) Description of registers

(a) External-interrupt 1 control register 1 (EIC1)

The EIC1 controls interrupts by the INT0 and INT1 pins.

|                            | Bit 7 | <br>Bit 5 |       |       |       |       |       | Initial value |
|----------------------------|-------|-----------|-------|-------|-------|-------|-------|---------------|
| Address: 0024 <sub>H</sub> | EIR1  | <br>SEL1  | EIE1  | EIR0  | INTE  | SEL0  | EIE0  | 0X00 0000B    |
|                            | (R/W) | (R/W)     | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |               |

Note: The bit manipulation instructions (Read Modify instructions) should not be used for this register.

# [Bit 7] EIR1: External-interrupt request flag

When the edge specified by the SEL1 bit is input to the INT1 pin, bit 7 is set to 1. When the EIE1 bit is 1, an interrupt request (IRQ0) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT1 pin               |  |  |  |
|---|----------------------------------------------------|--|--|--|
| 1 | Specified edge input to INT1 pin (IRQ0 is output.) |  |  |  |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

#### [Bit 5] SEL1: Edge-polarity select bit

Bit 5 is used to control the input edge polarity of the INT1 pin.

| 0 | Rising edge  |
|---|--------------|
| 1 | Falling edge |

#### [Bit 4] EIE1: Interrupt-enable bit

Bit 4 is used to enable an external-interrupt request by the INT1 pin.

| 0 | Interrupt request disabled                |
|---|-------------------------------------------|
| 1 | Interrupt request enabled by EIR1 setting |

# [Bit 3] EIR0: External-interrupt request flag

When the edge specified by the SEL0 bit is input to the INT0 pin, bit 3 is set to 1. When the EIE0 is 1, an interrupt request (IRQ0) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT0 pin               |  |  |  |  |
|---|----------------------------------------------------|--|--|--|--|
| 1 | Specified edge input to INT0 pin (IRQ0 is output.) |  |  |  |  |

1 is always read when the Read Modify Write instruction is read.



The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

#### [Bit 2] INTE: Testing bit

Bit 2 is used only for testing. Always write 0 in this bit.

[Bit 1] SEL0: Edge-polarity select bit

Bit 1 is used to control the input edge polarity of the INT0 pin.

| 0 | Rising edge  |
|---|--------------|
| 1 | Falling edge |

#### [Bit 0] EIE0: Interrupt-enable bit

Bit 0 is used to enable an external-interrupt request by the INT0 pin.

| 0 | Interrupt request disabled                |
|---|-------------------------------------------|
| 1 | Interrupt request enabled by EIR0 setting |

(b) External-interrupt control register 2 (EIC2)

The EIC2 controls an interrupt by the INT2 and INT3 pins.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 0025 <sub>H</sub> | EIR3  | -     | SEL3  | EIE3  | EIR2  | -     | SEL2  | EIE2  | 0X00 0X00 <sub>B</sub> |
|                            | (R/W) |       | (R/W) | (R/W) | (R/W) |       | (R/W) | (R/W) |                        |

[Bit 7] EIR3: External-interrupt request flag

When the edge specified by the SEL3 bit is input to the INT3 pin, bit 7 is set to 1. When the EIE3 bit is 1, an interrupt request (IRQ1) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT3 pin               |  |  |  |
|---|----------------------------------------------------|--|--|--|
| 1 | Specified edge input to INT3 pin (IRQ1 is output.) |  |  |  |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

## [Bit 5] SEL3: Edge-polarity select bit

Bit 5 is used to control the input edge polarity of the INT3 pin.

| 0 | Rising edge  |
|---|--------------|
| 1 | Falling edge |

#### [Bit 4] EIE3: Interrupt-enable bit

Bit 4 is used to enable an external-interrupt request by the INT3 pin.

| 0 | Interrupt request disabled                   |
|---|----------------------------------------------|
| 1 | Interrupt request enabled by setting of EIR3 |

#### [Bit 3] EIR2: External-interrupt request flag

When the edge specified by the SEL2 bit is input to the INT2 pin, bit 3 is set to 1. When the EIE2 is 1, an interrupt request (IRQ2) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT2 pin               |  |  |  |
|---|----------------------------------------------------|--|--|--|
| 1 | Specified edge input to INT2 pin (IRQ1 is output.) |  |  |  |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

#### [Bit 1] SEL2: Edge-polarity select bit

Bit 1 is used to control the input edge polarity of the INT2 pin.

| 0 | Rising edge  |
|---|--------------|
| 1 | Falling edge |

#### [Bit 0] EIE2: Interrupt-enable bit

Bit 0 is used to enable an external-interrupt request by the INT2 pin.

| 0 | Interrupt request disabled                   |
|---|----------------------------------------------|
| 1 | Interrupt request enabled by setting of EIR2 |

#### (4) Precautions for external-interrupt circuit

When enabling an interrupt after clearing reset, always clear the interrupt flag simultaneously. An interrupt request is output immediately when the interrupt flags (EIR3, EIR2, EIR1, EIR0) are set to 1.

Don't use INT0 and INT1 when double clock operation is specified.

If an interrupt is selected on the rising edge, the pull-up option for the pin should not be used.

# 2.2.9 Buzzer Output Circuit

- The buzzer output sound for checking key input can be output from port 51.
- Three frequencies can be output by setting the registers.
- (1) RegistersTBTC



# (2) Block diagram





- (3) Detailed description of registers
- (a) Buzzer register (BUZR)

This 8-bit register enables buzzer output and selects the frequency.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|---------------|
| Address: 0011 <sub>H</sub> |       | -     |       | -     |       | -     | BUZ1  | BUZ0  | XXXX XX00B    |
|                            |       |       |       |       |       |       |       | (R/W) |               |

[Bits 1 and 0] BUZ1 and BUZ0: Buzzer-select bits

Bits 1 and 0 are used to enable buzzer output and select the frequency. The buzzer output function is disabled by 00 and the port operates normally. In other cases, the frequencies listed in the table below are selected.

| BUZ1 | BUZ0 | Buzzer output frequency        |
|------|------|--------------------------------|
| 0    | 0    | General-purpose port operation |
| 0    | 1    | 1220 Hz                        |
| 1    | 0    | 2441 Hz                        |
| 1    | 1    | 4883 Hz                        |

Table 2.11 Buzzer Output Frequencies (at 10 MHz Oscillation)

(4) Description of operation

This circuit outputs a signal for use as a check sound. The buzzer register is used to enable buzzer output and select the frequency. When values other than 00 are set at the BUZR register, the square wave of the set frequency is output at the port.

(5) Precautions for buzzer output circuit

Part of the time-base timer is used as the buzzer output. Therefore, clearing the time-base timer affects the circuit.

## 2.2.10 Watch Prescaler

- This prescaler has a 15-bit binary counter
- Four interval times can be selected.
- This function cannot be used when the single clock module is selected by the mask option.
- (1) Registers



- (3) Description of registers
- (a) Watch prescaler control register (WPCR)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Initial value          |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| Address: 000B <sub>H</sub> | WIF   | WIE   |       |       | _     | WS1   | WS0   | WCLR  | 00XX X000 <sub>B</sub> |
|                            | (R/W) | (R/W) |       |       |       | (R/W) | (R/W) | (R/W) |                        |

[Bit 7] WIF: Watch interrupt flag

When writing, this bit is used to clear the watch interrupt flag.

| 0 | Clears watch interrupt flag |
|---|-----------------------------|
| 1 | No operation                |

When reading, this bit indicates that the watch interrupt has occurred.

| 0 | Watch interrupt not occurred |
|---|------------------------------|
| 1 | Watch interrupt occurred     |

1 is read when the Read Modify Write instruction is read. If the WIF bit is set to 1 when the WIE bit is 1, an interrupt request is output. This bit is cleared upon reset.

#### [Bit 6] WIE: Watch interrupt enable bit

This bit is used to enable an interrupt by the watch.

| 0 | Interrupt by watch disabled |
|---|-----------------------------|
| 1 | Interrupt by watch enabled  |

[Bit 2] WS1: Interrupt interval time specification bit by watch

[Bit 1] WS0: Interrupt interval time specification bit by watch

These bits are used to specify the interrupt cycles.

| WS1 | WS0 | Interrup   | t cycle              |
|-----|-----|------------|----------------------|
| 0   | 0   | 31.25 [ms] | 2 <sup>10</sup> /fcl |
| 0   | 1   | 0.25 [s]   | 2 <sup>13</sup> /fcl |
| 1   | 0   | 0.50 [s]   | 2 <sup>14</sup> /fcl |
| 1   | 1   | 1.00 [s]   | 2 <sup>15</sup> /fcl |

/fcl: Subclock oscillation frequency

[Bit 0] WCLR: Bit clearing watch prescaler

This bit is used to clear the watch prescaler.

| 0 | Watch prescaler cleared |  |
|---|-------------------------|--|
| 1 | No operation            |  |

1 is always read when this bit is read.

# 2.2.11 Time-base Timer

- This timer has a 21-bit binary counter and uses a clock pulse with 1/2 oscillation of the main clock.
- Four interval times can be selected.
- This function cannot be used when the main clock is stopped.
- (1) Registers



\* TBTC is a clock pulse with 1/2 oscillation of the main clock.

- (3) Description of registers
- (a) Time-base timer control register (TBCR)

|                            | Bit 7 |       |   |   | <br>     | Bit 1 |     | Initial value |
|----------------------------|-------|-------|---|---|----------|-------|-----|---------------|
| Address: 000A <sub>H</sub> | TBOF  | TBIE  | - | - | <br>TBC1 | TBC0  | TBR | 00XX X000B    |
|                            | (R/W) | (R/W) |   |   | (R/W)    | (R/W) | (W) |               |

[Bit 7] TBOF: Interval timer overflow bit

When writing, this bit is used to clear the interval timer overflow flag.

| 0 | Interval timer overflow flag cleared |  |  |
|---|--------------------------------------|--|--|
| 1 | No operation                         |  |  |

When reading, this bit indicates that an interval timer overflow has occurred.

| 0 | Interval timer overflow not occurred |  |  |  |
|---|--------------------------------------|--|--|--|
| 1 | Interval timer overflow occurred     |  |  |  |

1 is read when the Read Modify Write instruction is read. If the TBIF bit is set to 1 when the TBIE bit is 1, an interrupt request is output. This bit is cleared upon reset.

#### [Bit 6] TBIE: Interval-timer interrupt enable bit

This bit is used to enable an interrupt by the interval timer.

| 0 | Interval interrupt disabled |
|---|-----------------------------|
| 1 | Interval interrupt enabled  |

[Bit 2] TBC1: Interval time specification bit

[Bit 1] TBC2: Interval time specification bit

Bits 1 and 2 are used to specify interval timer cycle.

| TBC1 | TBC0 | Interval time        | At 10 MHz oscillation |
|------|------|----------------------|-----------------------|
| 0    | 0    | 2 <sup>13</sup> /fch | 0.81 [ms]             |
| 0    | 1    | 2 <sup>15</sup> /fch | 3.27 [ms]             |
| 1    | 0    | 2 <sup>18</sup> /fch | 26.21 [ms]            |
| 1    | 1    | 2 <sup>22</sup> /fch | 0.419 [s]             |

/fch: main clock frequency

[Bit 0] TBR: Time-base timer clear bit

This bit is used to clear time-base timer.

| 0 | Time-base timer cleared |
|---|-------------------------|
| 1 | No operation            |

1 is always read when this bit is read.

# 2.2.12 Watchdog Timer Reset

Either of a signal output from the time-base timer for counting with the main clock or a signal output from the watch prescaler for counting with the subclock can be selected as a clock.

#### (1) Registers





(3) Description of register

Watchdog timer control register (WDTE)



#### [Bit 7] CS: Clock source switching bit

Bit 7 is used to select a count clock from either the watch prescaler or time-base timer.

| 0 | Time-base timer | Period 1/222 fch |                           |
|---|-----------------|------------------|---------------------------|
| 1 | Watch prescaler | Period 1/214 fcl |                           |
|   |                 |                  | fch: Main clock frequency |

fch: Main clock frequency fcl: Subclock frequency

Set this bit as soon as the watchdog timer is started. Do not change the bit after the timer is started. When using the submode, always select the watch prescaler.

[Bits 3 to 0] WTE3 to WTE0: Watchdog timer control bit

Bits 3 to 0 control the watchdog timer.

First write only after reset

| 0101                 | Watchdog timer started |
|----------------------|------------------------|
| Other than the above | No operation           |

Second and later write

| 0101                 | Watchdog timer counter cleared. |
|----------------------|---------------------------------|
| Other than the above | No operation                    |

The watchdog timer can be stopped only by reset. 1111 is read when these bit are read.

(4) Description of operation

The watchdog timer enables detection of a program nullfunction.

• Starting watchdog timer

The watchdog timer starts when 0101 is written at the watchdog timer control bits.

• Clearing watchdog timer

When 0101 is written at the watchdog timer control bits after start, the watchdog timer is cleared. The counter of the watchdog timer is cleared when changing to the standby mode (STOP, SLEEP, CLOCK) or hold mode.

• Watchdog timer reset

If the watchdog timer is not cleared within the time given in the table below, a watchdog timer reset occurs to reset the chip internally.

|              | Clock            |                 |                           |
|--------------|------------------|-----------------|---------------------------|
|              | Time-base timer  | Watch prescaler |                           |
| Minimum time | Approx. 419.4 ms | Approx. 512 ms  | at high-speed 10 MHz cloc |
| Maximum time | Approx. 838.8 ms | Approx. 1024 ms | at low-speed 32 kHz clock |

# Stopping watchdog timer

Once started, the watchdog timer will not stop until a reset occurs.

# 3. OPERATION

| CLOCK PULSE GENERATOR             |
|-----------------------------------|
| RESET                             |
| INTERRUPT                         |
| MEMORY ACCESS MODE                |
| READY AND HOLD FUNCTIONS          |
| LOW-POWER CONSUMPTION MODES 3-12  |
| PIN STATES FOR SLEEP, STOP, HOLD, |
| AND RESET                         |
|                                   |

# 3.1 CLOCK PULSE GENERATOR

The MB89630 series of microcontrollers incorporate the system clock pulse generator. The crystal oscillator is connected to the X0 and X1 pins to generate clock pulses. Clock pulses can also be supplied internally by inputting externally-generated clock pulses to the X0 pin. The X1 pin should be kept open.

The X0A and A1A pins are for subclock inputs. They function like the X0 and X1 pins.

When the single-channel option is selected, the X0A and X1A pins serve as P71/INT1 and P70/INT2, respec tively.



Fig. 3.15 Clock Pulse Generator

# 3.2 RESET

# 3.2.1 Reset Operation

When reset conditions occur, the MB89630 series of microcontrollers suspend the currently-executing in struction to enter the reset state. The contents written at the RAM do not change before and after reset. How ever, if a reset occurs during writing of 16-bit long data, data is written to the upper bytes and may not be written to lower bytes. If a reset occurs around write timing, the contents of the addresses being written are not as sured.

When the reset conditions are cleared, the MB89630 series of microcontrollers are released from the reset state and start operation after fetching the mode data from address  $\mathtt{FFFD}_{H}$ , the upper bytes of the reset vec tors from address  $\mathtt{FFFE}_{H}$ , and the lower bytes from address  $\mathtt{FFFF}_{H}$ , in that order. Figure 3.2 shows the flow chart for the reset operation.



Fig. 3.16 Outline of Reset Operation

Table 3-1 indicates the structure of data to be stored in addresses  $FFFD_{H}$ ,  $FFFE_{H}$ , and  $FFFF_{H}$ .

| FFFF <sub>H</sub> | Lower 8 bits of reset vector<br>Upper 8 bits of reset vector | Enter<br>execu |   |   |   |   |   |   |   | hich wi<br>ed. |
|-------------------|--------------------------------------------------------------|----------------|---|---|---|---|---|---|---|----------------|
| FFFD <sub>H</sub> | Mode data                                                    | 1              | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
| Mode bit          | Reserved; alway                                              |                |   |   | Ĵ |   |   |   | Ĩ |                |

 Table 3.12
 Reset Vector Structure

| T2   | T1       | то   | Operation                                    |
|------|----------|------|----------------------------------------------|
| 0    | 0        | 0    | External-access disable (single chip)        |
| 0    | 0        | 1    | External-access enable (external-bus enable) |
| Othe | r than a | bove | Reserved; do not set.                        |

#### 3.2.2 Reset Sources

The MB89630 series of microcontrollers have the following reset sources.

(1) External pin

A Low level is input to the  $\overline{RST}$  pin.

(2) Specification by software

0 is written at the RST bit of the standby-control register.

(3) Power-on

The power is turned on when the power-on reset option is selected.

(4) Watchdog function

The watchdog function is enabled by the watchdog-control register and reaccess to this register is not obtained within the specified time.

When the stop mode is cleared by reset or power-on reset (option selected), operation is started after elapse of the oscillation stabilization time.

See the state transition diagram and (d) Reset in 2.1.5 for details of the reset operation.

# 3.3 INTERRUPT

If the interrupt controller and CPU are ready to accept interrupts when an interrupt request is output from the resources or by an external-interrupt input, the CPU temporarily suspends the currently-executing instruction and executes the interrupt-processing program. Figure 3.3 shows the interrupt-processing flow-chart.



Fig. 3.17 Interrupt-processing Flowchart

All interrupts are disabled after a reset is cleared. Therefore, initialize interrupts in the main program (1). Each resource generating interrupts and the interrupt-level-setting registers (ILR1 - ILR3) in the interrupt controller corresponding to these interrupts are to be initialized. The levels of all interrupts can be set by the interrupt-level-setting registers (ILR1 - ILR3) in the interrupt level can be set from 1 to 3, where 1 indicates the highest level, and 2 the second highest level. Level 3 indicates that no interrupt occurs. The interrupt request of this level can be accepted. After initializing the resource registers, the main program exe cutes various controls (2). Interrupts are generated from the resources (3). The highest-priority interrupt requests are identified from those occurring at the same time by the interrupt controller and are transferred to the CPU. The CPU then checks the current interrupt level and the status of the I-flag (4), and starts the interrupt processing.

The CPU performs the interrupt processing to save the contents of the current PC and PS in the stack (5) and fetches the entry addresses of the interrupt program from the interrupt vectors. After updating the IL value in the PS to the required one, the CPU starts executing the interrupt-processing routine.

Clear the interrupt sources (6) and process the interrupts in the user's interrupt-processing routine. Finally, restore the PC and PS values saved by the RETI instruction in the stack (8) to return to the interrupted instruction.

**Note:** Unlike the  $F^2MC$ -8, A and T are not saved in the stack at the interrupt time.

Table 3-2 lists the relationships between each interrupt source and interrupt vector.

| Interrupt source                  | Upper vector address | Lower vector address |
|-----------------------------------|----------------------|----------------------|
| IRQ0 (External interrupt 1#1)     | FFFA <sub>H</sub>    | FFFB <sub>H</sub>    |
| IRQ1 (External interrupt 1#2)     | FFF8 <sub>H</sub>    | FFF9 <sub>H</sub>    |
| IRQ2 (8-bit serial I/O)           | FFF6 <sub>H</sub>    | FFF7 <sub>H</sub>    |
| IRQ3 (8-bit PWM timer #2)         | FFF4 <sub>H</sub>    | FFF5 <sub>H</sub>    |
| IRQ4 (8-bit PWM timer #2)         | FFF2 <sub>H</sub>    | FFF3 <sub>H</sub>    |
| IRQ5 (Pulse-width count timer)    | FFF0 <sub>H</sub>    | FFF1 <sub>H</sub>    |
| IRQ6 (URAT receiver interrupt)    | FFEE <sub>H</sub>    | FFEFH                |
| IRQ7 (URAT transmitter interrupt) | FFECH                | FFED <sub>H</sub>    |
| IRQ8 (8-bit serial I/O#2)         | FFEA <sub>H</sub>    | FFEB <sub>H</sub>    |
| IRQ9 (A/D converter)              | FFE8 <sub>H</sub>    | FFE9 <sub>H</sub>    |
| IRQA (Interval timer)             | FFE6 <sub>H</sub>    | FFE7 <sub>H</sub>    |
| IRQB (Watch)                      | FFE4 <sub>H</sub>    | FFE5 <sub>H</sub>    |

 Table 3.13 Interrupt Sources and Interrupt Vectors

# 3.4 MEMORY ACCESS MODE

When external access is enabled by setting bits 2 to 0 of the mode data at address  $FFFD_{H}$ , the areas in Figure 3.4 are externally accessed via the P0 to P2 pins.



Fig. 3.18 Memory Map in Various Modes

As shown in Figure 3.5, when accessing by the external pins, specify the address of the external peripheral/ memory to be accessed according to the access information to be output to the address and address-data pins. The lower 8 bits of the address are input and output by time-sharing with the data bus. Therefore, the external circuit should be created so that the address information can be latched at the falling edge of the ALE signal to be output to the ALE pin. For access, when reading, input data from the external peripheral/ memory to the data pin in synchronization with the read strobes to be output to the RD pin; when writing, write the data to be output to the data pin to the external peripheral/memory in synchronization with the write strobes to be output to the WR pin.



Fig. 3.19 External-access Timing Chart

The BUFC signal is used when the address-data bus has an external buffer. It controls the buffer direction. This signal can be used to facilitate buffer control.

Figure 3.6 shows an example of connecting the external peripheral/memory to the MB89630 series of micro controllers. In this circuit, the external bus is used after enabling the operation of the HAK pin by the external ROM. When using the hold function, the pull-up resistor must be attached externally to the HAK pin.

At access to internal ROM, A15 to A08, AD7 to AD0, and ALE are output but WR and RD are not output.



Fig. 3.20 External Peripheral/Memory Connection

# 3.5 READY AND HOLD FUNCTIONS

## 3.5.1 Ready Function

The RDY pin allows access to the low-speed memory and resources. When the RDY pin goes Low while the CPU is conducting external access, the CPU prolongs the last bus cycle by double oscillations. When the CPU conducts an internal access, the value of the RDY pin is ignored. As shown in Figure 3.7, the Ready signal is input near the center of the  $\overline{RD}$  or  $\overline{WR}$  pin. In the not-ready state, the Ready signal is input around the CLK rising edge. The Ready/Not-ready signal can be generated in the circuit as shown in Figure 3.8.



Note: The read cycle is also prolonged in the same manner.





Fig. 3.22 Ready Generation Circuit

# 3.5.2 Hold Function

The <u>CPU</u> samples the user hold-request input to the HRQ pin at the boundary of each instruction and sets the HAK pin to Low to open the bus. When the CPU detects that the HRQ pin is active, it temporarily suspends operation to set the address, data,  $\overline{RD}$ ,  $\overline{WR}$ , and BUFC pins to High impedance, and also enters the hold state after outputting a Low level from the HAK pin. Figure 3.9 shows the hold timing.



Fig. 3.23 Hold Timing

The CPU does not accept any hold requests in the stop and sleep modes. The use of the hold-acknowledge signal with an external buffer is shown in Figure 3.6.

In the hold mode, the CPU is stopped but each resource is operable. No watchdog reset occurs during the hold mode because the watchdog timer counter is cleared.

# 3.6 LOW-POWER CONSUMPTION MODES

The MB89630 series of microcontrollers have three standby modes: sleep, stop, and watch to reduce the power consumption. Writing to the standby-control register (STBC) gives these three standby modes. Clear ing is performed by an interrupt or at reset. See 2.1.5 for setting and releasing each mode.

The MB89630 series of microcontrollers have a dual-clock module, and the low-power consumption modes vary with the main clock and subclock modes. In addition, whether or not an oscillation stabilization period is required at release from the low-power consumption mode depends on the mask option of the power-on reset. (See the state transition diagram in 2.1.5.)

If the single-clock module is specified with the mask option, the MB89630 series of microcontrollers can be used as single clocks. If the microcontrollers are used as single clocks without specifying the single-clock module with the mask option, once the subclock mode is entered, it cannot be released. Therefore, when using these controllers as a single clock, specify the single-clock module with the mask option.

|            | Function           | Note |         | Main Mode | •        |            | Sub       | Mode    |         |
|------------|--------------------|------|---------|-----------|----------|------------|-----------|---------|---------|
|            | Function           | Note | RUN     | SLEEP     | STOP     | RUN        | SLEEP     | STOP    | WATCH   |
| Main clock | k                  |      | Operate | Operate   | Stop     | Stop       | Stop      | Stop    | Stop    |
| Subclock   |                    | -    | Operate | Operate   | Operate  | Operate    | Operate   | Stop    | Operate |
|            | Instruction        | -    | Operate | Stop      | Stop     | Operate    | Stop      | Stop    | Stop    |
| CPU        | ROM                | -    | Operate | Hold      | Hold     | Operate    | Hold      | Hold    | Hold    |
|            | RAM                | -    | Operate | Hola      | Hold     | Operate    | Hold      | Hold    | Hold    |
|            | I/O                | 0    | Operate | Hold      | Hold     | Operate    | Hold      | Hold    | Hold    |
|            | Watch prescaler    | ×    | Operate | Operate   | Operate* | Operate    | Operate   | Stop    | Operate |
|            | Time-base timer    | ×    | Operate | Operate   | Stop     | Stop       | Stop      | Stop    | Stop    |
|            | 8-bit PWM          | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
|            | 8-bit PWC          | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
| Resource   | 16-bit timer       | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
| nesource   | 8-bit timer        | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
|            | 8-bit SIO          | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
|            | UART               | 0    | Operate | Operate   | Stop     | Operate    | Operate   | Stop    | Stop    |
|            | A/DC               | 0    | Operate | Operate   | Stop     | Operate**  | Operate** | Stop    | Stop    |
|            | External interrupt | 0    | Operate | Operate   | Operate  | Operate    | Operate   | Operate | Operate |
|            | Buzzer output      | ×    | Operate | Operate   | Stop     | Stop       | Stop      | Stop    | Stop    |
|            | Watchdog timer     | ×    | Operate | Stop      | Stop     | Operate*** | Stop      | Stop    | Stop    |

Table 3.14 Low-power Consumption Mode at Each Clock Mode

#### Notes:

- $\bigcirc$  : Clock mode (for main mode or submode) where operation speed affected by gear function.
- $X \ : \ Clock \ mode$  (for main mode or submode) where operation speed not affected by gear function.
- \* : The watch prescaler can operate counting but the watch interrupt cannot be operated.
- \*\* : These functions can be operated but do not use them.
- \*\* : When clock source used as watch prescaler.



# 3.7 PIN STATES FOR SLEEP, STOP, HOLD, AND RESET

The state of each pin of the MB89630 series of microcontrollers at sleep, stop, hold, and reset is as follows:

(1) Sleep

The pin state immediately before the sleep state is held.

(2) Stop

The pin state immediately before the stop state is held when the stop mode is started and bit 5 of the stand by-control register (STBC) is set to 0; the impedance of the output and input/output pins goes High when the bit is set to 1.

(3) Hold

The impedance of the bus pins goes High.

(4) Reset

When the MOD pin is 00, the impedance of all I/O and resource pins (excluding pins for pull-up option) goes High. When the MOD pin is 01, the ALE, CLK, RDY, and BUFC signals become active.

The detailed pin state in each mode is described on the following pages.

|                | Pin name       | Normal                         | Sleep                          | Stop<br>(Sub) SPL = 0            | Stop<br>(Sub) SPL = 1      | Reset                  |
|----------------|----------------|--------------------------------|--------------------------------|----------------------------------|----------------------------|------------------------|
| P00/A          | D0 to P07/AD7  | Port input/output              | Port input/output              | Port input/output                | High impedance<br>(Note 1) | High impedance         |
| P10/A          | 08 to P17/A15  | Port input/output              | Port input/output              | Port input/output                | High impedance<br>(Note 1) | High impedance         |
| XD             |                | Input for oscillation          | Input for oscillation          | High impedance<br>(Note 1)       | High impedance<br>(Note 1) | Input for oscillation  |
| P71            | X0A (Note 3)   | Input for oscillation          | Input for oscillation          | High impedance                   | High impedance             | Input for oscillation  |
|                | INT1 (Note 2)  | Port/resource input            | Port/resource input            | Port/resource input              | Resource input             | High impedance         |
| K1             |                | Output for oscillation         | Output for oscillation         | H output                         | H output                   | Output for oscillation |
| P70            | X1A (Note 3)   | Output for oscillation         | Output for oscillation         | H output                         | Houtput                    | Output for oscillation |
|                | INTO (Note 2)  | Port/resource input            | Port/resource input            | Port/resource input              | Resource input             | High impedance         |
| MOD            |                | Mode input                     | Mode input                     | Mode input                       | Mode input                 | Mode input             |
| RST            |                | Reset input                    | Reset input                    | Reset input                      | Reset input                | Reset input (Note 4)   |
| P27/A          | LE             | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P26/R          | 0              | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P25/V          | R              | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P24/C          | 1.K            | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P23/R          | ЮY             | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P22/H          | RQ             | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P21/H          | IAK .          | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P20/8          | UFC            | Port output                    | Port output                    | Port output                      | High impedance             | High impedance         |
| P30/U<br>P37/M | ICK1 to<br>VTO | Port/resource input/<br>output | Port/resource input/<br>output | Port/resource output<br>(Note 5) | High impedance<br>(Note 1) | High impedance         |
| P40/U<br>P43/P | ICK2 to<br>TO1 | Port/resource input/<br>output | Port/resource input/<br>output | Port/resource output<br>(Note 5) | High impedance<br>(Note 1) | High impedance         |
| P50/A<br>P53/P | DST to<br>TO2  | Port/resource input/<br>output | Port/resource input/<br>output | Port/resource output<br>(Note 5) | High impedance<br>(Note 1) | High impedance         |
| P60/A          | N0 to P67/AN7  | Port/resource input            | Port/resource input            | Port/resource output<br>(Note 5) | High impedance<br>(Note 1) | High impedance         |
| P72/I          | NT2 to P74/EC  | Port/resource input            | Port/resource input            | Port/resource input              | Resource input             | High impedance         |

Normal Pins for MB89630 Series of Microcontrollers (in Single-Chip Mode)

#### Notes:

- 1 : The input level is fixed to prevent leakage due to open input.
- 2: When single clock is operated.
- 3: When double clocks are operated.
- 4: The reset pin may serve as and output depending on the option setting.
- 5: When these pins are used for port or resource inputs, the input level is fixed to prevent leakage due to open input.



Normal Pins for MB89630 Series of Microcontrollers (in External-ROM and External-Access Internal-ROM Modes)

| Р               | in name          | Normal                        | Hold                          | Sleep                         | Stop<br>(Sub) SPL = 0               | Stop<br>(Sub) SPL = 1      | Reset<br>(MOD = 00)       | Reset<br>(MOD = 01)        |
|-----------------|------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------------|----------------------------|---------------------------|----------------------------|
| P00/A<br>P07/A  |                  | Address/data<br>input/output  | High impedance                | Data output                   | Data output                         | High impedance<br>(Note 1) | High impedance            | Undefined                  |
| P10/A/<br>P17/A |                  | Address<br>output             | High impedance                | Address<br>output             | Address<br>output                   | High impedance<br>(Note 1) | High impedance            | Undefined                  |
| XO              |                  | Input for<br>oscillation      | input for<br>oscillation      | Input for<br>oscillation      | High impedance<br>(Note 1)          | High impedance<br>(Note 1) | Input for<br>oscillation  | Input for oscillation      |
| P71/            | X0A<br>(Note 3)  | Input for<br>oscillation      | Input for<br>oscillation      | Input for<br>oscillation      | High impedance<br>(Note 1)          | High impedance<br>(Note 1) | Input for<br>oscillation  | Input for<br>oscillation   |
|                 | INT1<br>(Note 2) | Port/resource<br>input        | Port/resource<br>input        | Port/resource<br>input        | Port/resource<br>input              | Port/resource<br>input     | High impedance            | High impedance             |
| X1              |                  | Output for<br>oscillation     | Output for<br>oscillation     | Output for<br>oscillation     | H output                            | H output                   | Output for<br>oscillation | Output for<br>oscillation  |
| P70/            | X1A<br>(Note 3)  | Output for<br>oscillation     | Output for<br>oscillation     | Output for<br>oscillation     | H output                            | H output                   | Output for<br>oscillation | Output for<br>oscillation  |
|                 | INT0<br>(Note 2) | Port/resource<br>input        | Port/resource<br>input        | Port/resource<br>input        | Port/resource<br>input              | Port/resouce<br>input      | High impedance            | High impedance             |
| MOD0<br>MOD1    |                  | Mode input                    | Mode input                    | Mode input                    | Mode input                          | Mode input                 | Mode input                | Mode input                 |
| RST             |                  | Reset input                   | Reset input                   | Reset input                   | Reset input                         | Reset input                | Reset input<br>(Note 2)   | Reset input<br>(Note 4)    |
| P27/A           | LE               | ALE output                    | L output                      | L output                      | L output                            | High impedance             | High impedance            | L output                   |
| P26/Ĥ           | D                | RD output                     | High impedance                | H output                      | H output                            | High impedance             | High impedance            | H output                   |
| P25/W           | /R               | WR output                     | High impedance                | H output                      | H output                            | High impedance             | High impedance            | H output                   |
| P24/C           | LK               | CLK output                    | CLK output                    | CLK output                    | H output                            | High impedance             | High impedance            | CLK output                 |
| P23/R           | DY               | RDY input                     | High impedance                | High impedance                | High impedance<br>(Note 1)          | High impedance             | High impedance            | RDY input                  |
| P22/H           | RQ               | HRQ input<br>(Note 5)         | HRQ input<br>(Note 5)         | High impedance<br>(Note 5)    | High impedance<br>(Notes 1 and 5)   | High impedance<br>(Note 1) | High impedance            | Port output<br>(Low level) |
| P21/H           | AK               | HAK output<br>(Note 4)        | L output                      | H output<br>(Note 5)          | H output<br>(Note 5)                | High impedance             | High impedance            | Port output<br>(Low level) |
| P20/B           | UFC              | BUFC output                   | High impedance<br>(Note 5)    | H output<br>(Note 5)          | H output<br>(Note 5)                | High impedance             | High impedance            | H output                   |
| P30/U<br>P37/W  | CK1 to<br>/TO    | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>output<br>(Note 6) | High impedance<br>(Note 1) | High impedance            | High impedance             |
| P40/U<br>P43/P  | CK2 to<br>TO1    | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>output<br>(Note 6) | High impedance<br>(Note 1) | High impedance            | High impedance             |
| P50/A<br>P53/P  | DST to<br>TO2    | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>output<br>(Note 6) | High impedance<br>(Note 1) | High impedance            | High impedance             |
| P60/A<br>P67/A  |                  | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>input/output | Port/resource<br>output<br>(Note 6) | High impedance<br>(Note 1) | High impedance            | High impedance             |
| P72/IN<br>P74/E |                  | Portiresource<br>input        | Port/resource input           | Portiresource<br>input        | Port/resource<br>input              | Port/resource<br>input     | High impedance            | High impedance             |

#### Notes:

- 1: The input level is fixed to prevent leakage due to open input.
- 2: Single clock
- 3: Double clocks
- 4: The reset pin may serve as an output depending on the option setting.
- 5: This may operate as a port depending on the setting of the bus-control register (BCTR).
- 6: When these pins are used for port or resource inputs, the input level is fixed to prevent leakage due to open input.

# 4.1 TRANSFER INSTRUCTIONS 4-3 4.2 OPERATION INSTRUCTIONS 4-3 4.3 BRANCH INSTRUCTIONS 4-4 4.3 BRANCH INSTRUCTIONS 4-5 4.4 OTHER INSTRUCTIONS 4-6 4.5 F<sup>2</sup>MC-8L INSTRUCTION MAP 4-7

# **4.1 TRANSFER INSTRUCTIONS**

| NO       | MNEMONIC                     | -        | •   | OPERATION                                                                                              | π        | тн  | AH           | NZVC    | OP CODE  |
|----------|------------------------------|----------|-----|--------------------------------------------------------------------------------------------------------|----------|-----|--------------|---------|----------|
| 1        | MOV dir,A                    | 3        | 2   | $(dir) \leftarrow (\lambda)$                                                                           | -        | -   | ( <b>-</b> 1 |         | 45       |
| 2        | MOV @IX+off,A                | 4        | 2   | ((IX)+off) + (A)                                                                                       | -        | -   | -            |         | 46 61    |
| 3        | MCV ext, A                   | 4        | 3   | $(ext) \leftarrow (\lambda)$                                                                           | -        | _   | -            |         | 47       |
| 6        | MOV REP, A<br>MOV RI, A      | 3        | î   | $((EP)) \leftarrow (\lambda)$                                                                          | -        | -   | -            |         | 48 to 4F |
| °        | NUV KL,A                     | 1        | •   | (R1) ← (A)                                                                                             | -        | -   | -            |         |          |
| 6        | MOV A,#d8                    | 2        | 2   | (A) ← d8                                                                                               | AL       | -   | -            | * *     | 04       |
| 7        | MOV A, dir                   | 3        | 2   | $(h) \leftarrow dir$                                                                                   | AL<br>AL | -   | -            |         | 05       |
| ŝ        | MOV A, #IX+off<br>MOV A, ext | 1.2      | 3   | $(h) \leftarrow ((IX)+off)$                                                                            | AL       | -   | -            |         | 60       |
| 10       | MOV A, RA                    | 3        | ĩ   | $(A) \leftarrow (ext)$<br>$(A) \leftarrow ((A))$                                                       | AL       | -   | -            | + +     | 92       |
|          |                              |          |     |                                                                                                        |          |     |              |         | 07       |
| 11<br>12 | MOV A, REP                   | 3        | 1   | $(A) \leftarrow ((EP))$                                                                                | AL<br>AL | -   | -            | * *     | 08 to 0F |
| 13       | MOV A,Ri<br>MOV dir,#d8      | 4        | 3   | (A) ← (R1)                                                                                             | -        | -   | -            |         | 85       |
| 14       | MOV #IX+off,#d8              | 5        | 3   | (dir) ← d8<br>((IX)*off)← d8                                                                           | -        | _   | -            |         | 86       |
| 15       | HOV #EP,#d8                  | 4        | 2   | ((EP)) ← d8                                                                                            | -        | -   | -            |         | 87       |
|          | 1000 B.( 4.10                | Ι.       |     |                                                                                                        |          |     |              |         | 88 to 8F |
| 16<br>17 | MOV R1,#d8                   | 4        | 2   | (R1) ← d8                                                                                              | -        | -   | -            |         | 00 10 0F |
| 18       | MOVW dir,A<br>MOVW #IX+off,A | 5        | ź   | (dir) ←(AH),(dir+1) ← (AL)                                                                             | -        | -   |              |         | D6       |
| 19       | MOVW ext,A                   | 5        | 3   | ((IX)+off)←(AH),((IX)+off+1)←(AL)                                                                      | -        | -   | -            |         | D4       |
| 20       | MOVW #EP,A                   | 4        | 1   | $(ext) \leftarrow (AH), (ext+1)\leftarrow (AL)$<br>$((EP)) \leftarrow (AH), ((EP)+1)\leftarrow (AL)$   | -        | -   | -            |         | D7       |
| 21       | WHEN PR A                    | 2        | 1   |                                                                                                        |          |     |              |         | E3       |
| 22       | MOVW EP, A<br>MOVW A, #d16   | 5        | 3   | $(EP) \leftarrow (A)$                                                                                  | AL       | AH  | dH           | + + = = | E4       |
| 23       | MOVW A, dir                  | 4        | 2   | $(\lambda) \leftarrow d16$                                                                             | AL       | AR  | dH           | * *     | C5       |
| 24       | MOVW A, @IX+off              | 5        | 2   | (AB)+-(dir),(AL)+-(dir+1)<br>(AB)+-((IX)+off),(AL)+-((IX)+off+1)                                       | AL       | AH  | dH           | + + = = | C6       |
| 25       | MOVW A, ext                  | 5        | 3   | (AH)+-(ext), (AL)+-(ext+1)                                                                             | AL       | Alf | dH           | * *     | C4       |
| 28       | MOVW A, #A                   | 4        | 1   |                                                                                                        | AL       | AR  | dit          | * *     | 93       |
| 27       | MOVW A, EEP                  | 4        | 1   | $(AH) \leftarrow ((A)), (AL) \leftarrow ((A)+1)$<br>$(AH) \leftarrow ((EP)), (AL) \leftarrow ((EP)+1)$ | AL       | AH  | dH           | + +     | C7       |
| 28       | MOVE A, EP                   | 2        | 1   | $(A) \leftarrow (EP)$                                                                                  | -        | -   | dH           |         | F3       |
| 29       | MOVW EP,#d16                 | 3        | 3   | (EP) -d16                                                                                              |          | -   | -            |         | E7       |
| 30       | MOVW IX, A                   | 2        | 1   | (IX) - (A)                                                                                             | -        | -   | -            |         | E2       |
| 31       | HOVW A, IX                   | 2 2      | 1   | $(\lambda) \leftarrow (IX)$                                                                            | -        | -   | dH           |         | F2       |
| 32       | MOVW SP,A                    | 2        | 1   | $(SP) \leftarrow (A)$                                                                                  | -        | -   | -            |         | E1       |
| 33       | MOVW A, SP                   | 2        | 1   | (A) ← (SP)                                                                                             | -        | -   | dH           |         | F1<br>82 |
| 34<br>35 | HOV #A,T                     | 3        | 1   | $((\lambda)) \leftarrow (\overline{z})$                                                                | -        | -   | -            |         | 83       |
| 35       | HOVW &A,T                    | l .      |     | ((A)) ← (TE),((A)+1) ← (TL)                                                                            |          | -   | -            |         | ~        |
| 36       | MOVW IX,#d16                 | . 3      | 3   | (IX)= d16                                                                                              | -        | -   | -            |         | E6       |
| 37       | MOVW A, SP                   | 2        | 1   | $(A) \leftarrow (PS)$                                                                                  | -        | -   | dI           |         | 70       |
| 38       | MOVW PS,A                    | 2        | 1   | $(PS) \leftarrow (A)$                                                                                  | -        | -   | -            | * * * * | 71       |
| 39       | MCVW SP,#d16                 | 3        | 3   | (SP)- d16                                                                                              |          | -   | AL           |         | E5<br>10 |
| -40      | SWAP                         | <b>1</b> | · * | (AH) + (AL)                                                                                            | -        | -   | ~            |         | 10       |
| 41       | SETB dir:n                   | 4        | 2   | (dir):n = 1                                                                                            | -        | -   | -            |         | A8 to AF |
| 42       | CLRB dir:n                   | 4        | 2   | (dir):n + 0                                                                                            |          | -   | -            |         | A0 to A7 |
| 43       | XCH A,T                      | 2        | 1   | (AL) · (TL)                                                                                            | AL       | AH  | dH           |         | 42<br>43 |
| 44       | XCHN A,T<br>XCHN A,EP        | 3        | 1   | (A) = (T)                                                                                              | AL.      | AH  | dit          |         | 43<br>F7 |
| 40       | AVON ALEF                    | 1        | 1   | (A) 🗰 (EP)                                                                                             |          |     |              |         |          |
| 48       | XCHW A, IX                   | 3        | 1   | (A) - (IX)                                                                                             | -        | -   | dH           |         | F6       |
| 47       | XCHW A, SP                   | 3        | 1   | $(\lambda) \Leftrightarrow (1\lambda)$<br>$(\lambda) \Leftrightarrow (SP)$                             | -        | -   | dH           |         | F5<br>F0 |
| 48       | MOVW A, PC                   | 2        | 1   | $(\Lambda) \leftarrow (PC)$                                                                            | -        | -   | dH           |         | FO       |
|          |                              | _        |     | fut feet                                                                                               |          | _   |              |         |          |

Note:

- 1 : In byte transfer to A, T  $\leftarrow$  A is only for low bytes.
- 2 : Operands for two or more operand instructions should be stored in the order designated in MNE-MONIC (Opposite order to F<sup>2</sup>MC-8 family).
- $\sim$ : Cycles
- #: Byte counts

# **4.2 OPERATION INSTRUCTIONS**

| NO                         | MNEMONIC                                                                  | ~                     | •                     | OPERATION                                                                                                                                                                                                                                                                                                                                                                           | n | тн    | АН                   | NZVC                                                           | OP CODE                                |
|----------------------------|---------------------------------------------------------------------------|-----------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------|----------------------|----------------------------------------------------------------|----------------------------------------|
| 1 2 3 4 5                  | ADDC A,Ri<br>ADDC A,#d8<br>ADDC A,dir<br>ADDC A,#IX+off<br>ADDC A,#IX+off | 32543                 | 1 2 2 2 1             | $ \begin{array}{l} (\lambda) &\leftarrow (\lambda) + (Ri) + C \\ (\lambda) &\leftarrow (\lambda) + dB + C \\ (\lambda) &\leftarrow (\lambda) + (dir) + C \\ (\lambda) &\leftarrow (\lambda) + ((IX) + off) + C \\ (\lambda) &\leftarrow (\lambda) + ((EP)) + C \end{array} $                                                                                                        |   |       | i i i i              | ****                                                           | 28 to 2F<br>24<br>25<br>26<br>27       |
| 6<br>7<br>8<br>9<br>10     | ADDCW A<br>ADDC A<br>SUBC A,R1<br>SUBC A,#d0<br>SUBC A,dir                | 3 2 2 2 3             | 1 1 2 2               | $ \begin{aligned} (\lambda) &\leftarrow (\lambda) + (\mathbb{T}) + \mathbb{C} \\ (\lambda L) &\leftarrow (\lambda L) + (\mathbb{T}L) + \mathbb{C} \\ (\lambda) &\leftarrow (\lambda) - \mathbb{C} \\ (\lambda) &\leftarrow (\lambda) - dB - \mathbb{C} \\ (\lambda) &\leftarrow (\lambda) - dB - \mathbb{C} \\ (\lambda) &\leftarrow (\lambda) - (dir) - \mathbb{C} \end{aligned} $ |   |       | dH<br>-<br>-<br>-    | · · · · · · · · · · · · · · · · · · ·                          | 23<br>22<br>38 to 3F<br>34<br>35       |
| 11<br>12<br>13<br>14<br>15 | SUDC A, #IX+off<br>SUDC A, #EP<br>SUDCW A<br>SUDC A<br>INC Ri             | 4 3 3 2 4             | 211111                | $ \begin{array}{l} (A) \leftarrow (A) - (\{IX\} + off\}) - C \\ (A) \leftarrow (A) - (\{EP\}) + C \\ (A) \leftarrow (T) - (A) - C \\ (AL) \leftarrow (TL) - (AL) - C \\ (R1) \leftarrow (R1) + 1 \end{array} $                                                                                                                                                                      |   |       | -<br>dH<br>-         | · · · · · · · · · · · · · · · · · · ·                          | 36<br>37<br>33<br>32<br>C8 to CF       |
| 16<br>17<br>18<br>19<br>20 | INCW EP<br>INCW IX<br>INCW A<br>DEC RI<br>DECW EP                         | 3<br>3<br>3<br>4<br>3 | 1 1 1 1 1             | $(EP) \leftarrow (EP)+1$ $(IX) \leftarrow (IX)+1$ $(A) \leftarrow (A)+1$ $(R1) \leftarrow (R1)-1$ $(EP) \leftarrow (EP)-1$                                                                                                                                                                                                                                                          |   |       | -<br>-<br>-<br>-     |                                                                | C3<br>C2<br>C0<br>D8 to DF<br>D3       |
| 21<br>22<br>23<br>24<br>25 | DECW IX<br>DECW A<br>MULU A<br>DIVU A<br>ANDW A                           | 3<br>19<br>21<br>3    | 1<br>1<br>1<br>1      | $(IX) \leftarrow (IX) - 1$ $(A) \leftarrow (A) - 1$ $(A) \leftarrow (AL)^* (TL)$ $(A) \leftarrow (T) / (AL), \text{ MOD} \rightarrow (T)$ $(A) \leftarrow (A) \land (T)$                                                                                                                                                                                                            |   |       | dH<br>dH<br>00<br>dH | <br><br><br>+ + R -                                            | D2<br>D0<br>01<br>11<br>63             |
| 26<br>27<br>28<br>29<br>30 | CORM A<br>XORW A<br>CMP A<br>CMPW A<br>RORC A                             | 3 5 5 5 5             | 1 1 1 1 1             | $ \begin{array}{l} (\lambda) \leftarrow (\lambda) \forall (T) \\ (\lambda) \leftarrow (\lambda) \forall (T) \\ (TL) - (\lambdaL) \\ (T) - (\lambda) \\ \hline \end{array} $                                                                                                                                                                                                         |   |       | 네퍼<br>네퍼<br>         | * * R -<br>* * R -<br>* * * *<br>* * * *<br>* * - *            | 73<br>53<br>12<br>13<br>03             |
| 31                         | ROLC A                                                                    | 2                     | 1                     | C + A -                                                                                                                                                                                                                                                                                                                                                                             | - | -     | -                    | * * = *                                                        | 02                                     |
| 32<br>33<br>34<br>35       | CMP A,#d8<br>CMP A,dir<br>CMP A,êEP<br>CMP A,êIX+off                      | 2<br>3<br>3<br>4      | 2<br>2<br>1<br>2      | $(\lambda) - d\theta$ $(\lambda) - (dir)$ $(\lambda) - ((EP))$ $(\lambda) - ((IX) + off)$                                                                                                                                                                                                                                                                                           |   |       | -                    | : : : : :<br>: : : : :                                         | 14<br>15<br>17<br>16                   |
| 36<br>37<br>38<br>39<br>40 | CMP A,Ri<br>DAA<br>DAS<br>XOR A<br>XOR A,#d8                              | 00 N N N N            | 1 1 1 2               | (A)- (Ri)<br>decimal adjust for addition<br>decimal adjust for subtraction<br>(A) $\leftarrow$ (AL) $\forall$ (7L)<br>(A) $\leftarrow$ (AL) $\forall$ dB                                                                                                                                                                                                                            |   |       |                      | * * * *<br>* * * *<br>* * * *<br>* * R -<br>* * R -            | 18 to 1F<br>84<br>94<br>52<br>54       |
| 41<br>42<br>43<br>44<br>45 | XOR A,dir<br>XOR A,0EP<br>XOR A,0IX+off<br>XOR A,RI<br>AND A              | 5 5 4 5 N             | 2<br>1<br>2<br>1<br>1 | $\begin{array}{l} (\lambda) \leftarrow (\lambda L) \ \forall \ (dir) \\ (\lambda) \leftarrow (\lambda L) \ \forall \ ((EP)) \\ (\lambda) \leftarrow (\lambda L) \ \forall \ ((IX) + off) \\ (\lambda) \leftarrow (\lambda L) \ \forall \ (Ri) \\ (\lambda) \leftarrow (\lambda L) \ \checkmark \ (Ri) \end{array}$                                                                  |   |       |                      | + + R =<br>+ + R =<br>+ + R =<br>+ + R =<br>+ + R =            | 55<br>57<br>58<br>58 to 5F<br>62       |
| 46<br>47<br>48<br>49<br>50 | AND A,#d8<br>AND A,dir<br>AND A,8EP<br>AND A,8IX+off<br>AND A,Ri          | 200040                | 22121                 | $ \begin{array}{l} (\lambda) \ \leftarrow \ (\lambda L) \ \land \ d\theta \\ (\lambda) \ \leftarrow \ (\lambda L) \ \land \ (dir) \\ (\lambda) \ \leftarrow \ (\lambda L) \ \land \ (dir) \\ (\lambda) \ \leftarrow \ (\lambda L) \ \land \ ((EP)) \\ (\lambda) \ \leftarrow \ (\lambda L) \ \land \ ((IX) + off) \\ (\lambda) \ \leftarrow \ (\lambda L) \ (Ri) \end{array} $      |   |       |                      | + + R -<br>+ + R =<br>+ + R -<br>+ + R -<br>+ + R -<br>+ + R - | 64<br>65<br>67<br>68 to 6F             |
| 51<br>52<br>53<br>54<br>55 | CR A<br>CR A,#d8<br>CR A,dir<br>CR A,8EP<br>CR A,8IX+off                  | N N N N N 4           | 1 2 2 1 2             | $ \begin{array}{l} (\lambda) \ \leftarrow \ (\lambdaL) \ \lor \ (TL) \\ (\lambda) \ \leftarrow \ (\lambdaL) \ \lor \ (dir) \\ (\lambda) \ \leftarrow \ (\lambdaL) \ \lor \ (dir) \\ (\lambda) \ \leftarrow \ (\lambdaL) \ \lor \ ((EP)) \\ (\lambda) \ \leftarrow \ (\lambdaL) \ \lor \ ((IX) + off) \end{array} $                                                                  |   | 11111 |                      | + + R =<br>+ + R =<br>+ + R =<br>+ + R =<br>+ + R =            | 72<br>74<br>75<br>77<br>76             |
| 56<br>57<br>58<br>59<br>60 | CR A,Ri<br>CMP dir,#d8<br>CMP #EP,#d8<br>CMP #EX+off,#d8<br>CMP RI,#d8    | 35454                 | 1 3 2 3 2             | $(A) \leftarrow (AL) \lor ((AL) \circ OL),$<br>(dir) = d8<br>((EP)) = d8<br>((IX) + off) = d8<br>(Ri) = d8                                                                                                                                                                                                                                                                          |   | 1111  |                      | * * R =<br>* * * *<br>* * * *<br>* * * *<br>* * * *            | 78 to 7F<br>95<br>97<br>98<br>98 to 9F |
| 61<br>62                   | INCW SP<br>DECW SP                                                        | 3                     | 1                     | (SP) ← (SP) + 1<br>(SP) ← (SP) - 1                                                                                                                                                                                                                                                                                                                                                  | - | -     | -                    |                                                                | C1<br>D1                               |

# **4.3 BRANCH INSTRUCTIONS**

| NO | MNEMONIC      | ~ |   | OPERATION                                       | π   | тн  | AH  | NZVC    | OP CODE              |
|----|---------------|---|---|-------------------------------------------------|-----|-----|-----|---------|----------------------|
| 1  | BZ/BEQ rel    | 3 | 2 | if 2=1 then PC +-PC+rel                         | -   | -   | -   |         | FD                   |
| 2  | BNZ/BNE rel   | 3 | 2 | if Z=0 then PC +-PC+rel                         | - 1 | -   | -   |         | FC                   |
| 3  | BC/BLO rel    | 3 | 2 | if C=1 then PC +-PC+rel                         | -   | -   | -   |         | FC<br>F9<br>F8<br>F8 |
| 4  | BNC/BHS rel   | 3 | 2 | if C=0 then PC +-PC+rel                         | - 1 | -   | -   |         | FB                   |
| 5  | BN rel        | 3 | 2 | if N=1 then PC +-PC+rel                         | -   | -   | -   |         | FB                   |
| 6  | BP rel        | 3 | 2 | if N=0 then PC +-PC+rel                         | -   | -   | -   |         | FA<br>FF<br>FE       |
| 7  | BLT rel       | 3 | 2 | if VWN=1 then PC+PC+rel                         | -   | - 1 | -   |         | FF                   |
| 8  | BGE rel       | 3 | 2 | if VWN=0 then PC+-PC+rel                        |     | -   | -   |         | FE                   |
| 9  | BBC dir:b,rel | 5 | 3 | if (dir:b)=0 then PC+-PC+rel                    | - 1 | - 1 | -   | - +     | B0 to B7             |
| 10 | BBS dir:b,rel | 5 | 3 | if (dir:b)=1 then PC+-PC+rel                    | -   | -   | -   | - +     | B8 to BF             |
| 11 | JMP @A        | 2 | 1 | (PC) ← (A)                                      | -   | -   | -   |         | E0                   |
| 12 | JMP ext       | 3 | 3 | (PC)+ext                                        | - 1 | - 1 | - 1 |         | 21                   |
| 13 | CALLV #vct    | 6 | 1 | vector call                                     | - 1 | -   | -   |         | E8 to EF             |
| 14 | CALL ext      | 6 | 3 | subroutine call                                 |     | - 1 | - 1 |         | 31                   |
| 15 | XCHW A, PC    | 3 | 1 | $(PC) \leftarrow (A)$ , $(A) \leftarrow (PC)+1$ | -   | -   | dI  |         | F4                   |
| 16 | 887           | 4 | 1 | return from subroutine                          | -   | -   | -   |         | 20                   |
| 17 | RETI          | 6 | 1 | return from interrupt                           | -   | -   | -   | restore | 30                   |

# 4.4 OTHER INSTRUCTIONS

| NO               | MNEMONIC                                        | ~                | •                | OPERATION                                            | π    | тн    | AH   | NZVC       | OP CODE                    |
|------------------|-------------------------------------------------|------------------|------------------|------------------------------------------------------|------|-------|------|------------|----------------------------|
| 12345            | PUSHM A<br>POPW A<br>PUSHW IX<br>POPW IX<br>NOP | * * * * 1        | 1<br>1<br>1<br>1 | $\begin{array}{llllllllllllllllllllllllllllllllllll$ | 1111 | 11111 |      |            | 40<br>50<br>41<br>51<br>00 |
| 6<br>7<br>8<br>9 | CLRC<br>SETC<br>CLRI<br>SETI                    | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 | C ← 0<br>C ← 1<br>C ← 0<br>C ← 1                     | 1111 |       | 1111 | 8<br>8<br> | 81<br>91<br>80<br>90       |

# FUjitsu

# 4.5 F<sup>2</sup>MC-8L INSTRUCTION MAP

| 1 | 0               | 1               | 2                | 3                | 4              | 9                    | 9               | 7              | •                 | 8                 | ٨             | 8                 | с                  | D               | З               | F              |
|---|-----------------|-----------------|------------------|------------------|----------------|----------------------|-----------------|----------------|-------------------|-------------------|---------------|-------------------|--------------------|-----------------|-----------------|----------------|
| 0 | 906             | BHALF           | TET              | NETT             | NUGHW          | A WIDE               | NOV<br>Å, ext   | NUCH<br>N, PS  | CLAI              | 1185              | CLAB<br>dir:0 | BBC dir<br>10,rel | INCW               | DECW            | 785<br>47       | NOWN<br>A, PC  |
| 1 | N<br>MULU       | PIWU A          | 38P<br>addr16    | CALL<br>addr16   | NIISUY         | FOFW                 | NDV<br>ext., A  | NOUN NO.       | CLINC             | BBTC              | CL8B<br>dir:1 | BBC dir<br>11,rel | INCM               | DBCN            | NVON<br>SP,A    | NUCH<br>A, SP  |
| 8 | ROLC            | CNP<br>A        | ADDC             | suac A           | xca<br>A, 7    | XOR A                | AND A           | CR A           | NDV<br>8A.7       | NOV<br>A, 8A      | CLBB<br>dir=2 | BBC dir<br>12,rel | INCW               | DBCW            | NOVN<br>IX,A    | NUCUN<br>A, IX |
|   | NOBIC A         | CHIW A          | ADDOW            | SUBCH A          | XCBN<br>A.7    | к                    | ANDW A          | CBN A          | NOWN<br>8A., T    | MACON             | cras<br>dir:3 | BBC dir<br>13,rel | INCH               | DECW            | A, 43           | NOVN<br>A, EP  |
|   | NOV<br>A, #43   | CMP<br>A,#d8    | ADDC<br>A,#d8    | SUBC<br>A,#dB    | $\backslash$   | 208<br>A, #d8        | AND<br>A, #d8   | CR<br>A, #d8   | DAA               | DAB               | CLBB<br>dir:4 | BBC dir<br>14,rel | NOVW<br>A, ext     | MOWN<br>ext,A   | NOVN<br>A, #d16 | XCBN<br>A, PC  |
| 8 | NOV<br>A,dir    | CHP<br>A,dir    | ADDC<br>A,dir    | SUBC<br>A,dir    | MOV<br>A,dir   | 2008<br>A,dir        | AND<br>Ardir    | OR<br>A,dir    | MOV<br>dir,#dB    | CMP<br>dir,#d8    | ctan<br>dires | BBC dir<br>15,rel | NOVN<br>A, dir     | MOWW<br>dir,A   | NOVN<br>SP,#016 | XCBN<br>A, SP  |
|   | NOV<br>A, 81X+d | CHP<br>A, êIX+d | ADDC<br>A, ē1X+d | BUBC<br>A, ēIX+d | NDV<br>PIX+d,A | 2008.<br>A., @ I X+d | AND<br>A, &IX+d | OR<br>A, @IX+d | NDV 8<br>X+d, #48 | CHP 8<br>IX+d,#d8 | CL88<br>dir:6 | 880 dir<br>16,rel | NOOVN<br>A, ê IX+d | MOWN<br>ØIX+d,A | NOVN<br>IX,#d16 | XCBN<br>A, IX  |
| 7 | NOV<br>A, FEP   | CHP<br>A, EP    | ADDC<br>A, GEP   | SUBC<br>A, 9EP   | NOV<br>REP.A   | X08<br>A, 62P        | AND<br>A, REP   | 08<br>A, 612   | NOV<br>BEP,#d8    | CHP<br>8112, #40  | CLBB<br>dir:7 | BBC dir<br>17,rel | N//08              | HOVW<br>REP,A   | NOVN<br>8P,#d16 | XCBN<br>A, EP  |
|   | NOV<br>A.RD     | CHP<br>A, 80    | ADDC<br>A, R0    | BUBC<br>A, RO    | NOV<br>R0,A    | 2008.<br>A. H0       | AND<br>A.RO     | OR<br>A, 80    | MOV<br>RD,#d8     | CHP<br>80,#48     | 8ETB<br>dir:0 | 888 dir<br>10,rel | 1NC RO             | DEC             | CALLV           | BBC<br>rel     |
|   | NOV<br>A.RI     | CNP<br>A, 81    | ADDC<br>A,RI     | subc<br>A, 81    | NOV<br>R1,A    | X08<br>A, H1         | AND<br>A. B.1   | OR AJRI        | NON<br>ND , #d8   | CHP<br>BL,#48     | SETB<br>dir:1 | BBS dir<br>11,rel | 118C<br>8.1        | DBC             | CMLLV           | BC .           |
| × | NOV<br>A.R2     | CHP<br>A, 82    | ADDC<br>A,82     | 80BC<br>A, 82    | NOV<br>82,A    | X08.<br>A. K2        | AND<br>A, 82    | OR<br>A. R2    | NOV<br>R2,#d8     | CHP<br>82,440     | SETB<br>dir:2 | BBS dir<br>12,rel | 18C<br>82          | DBC R2          | CALLV<br>#2     | BP<br>rel      |
|   | MOV<br>A, R3    | CHP<br>A, KJ    | ADDC<br>A,RJ     | SUBC<br>A, RJ    | NOV<br>R3,A    | XOR                  | AKD<br>A, 8.3   | OR<br>A, R3    | 83,#d8            | CHP<br>83,#48     | SETS<br>diriJ | BBS dir<br>13,rel | INC NJ             | DBC R3          | CALLV.          | 68<br>rel      |
| c | моv<br>А. R4    | CHP<br>A. NI    | ADDC<br>A, R4    | sunc<br>A, R4    | N00V<br>R4,A   | XOR<br>A, R4         | AND<br>A., 84   | 0R<br>A, 84    | NOV<br>84,#d8     | CHP<br>84,#48     | 8ETB<br>dir:4 | BBS dir<br>14,rel | IBC R4             | DEC             | CALLV<br>#4     | BHZ<br>rel     |
| ٥ | A, R5           | CHP<br>A, 85    | ADDC<br>A, N5    | 80BC<br>A,85     | N0N<br>N5,A    | X08<br>A, 85         | AND<br>A, 85    | 0R<br>A, 85    | NOV<br>BD#, 28    | CHP<br>35,#48     | SETB<br>dire5 | BBS dir<br>15,rel | INC NS             | DBC             | CALLV<br>#5     | nz<br>rel      |
| E | ноv<br>А, R6    | CKP<br>Å. RS    | ADDC<br>A, RS    | SUBC<br>A, RS    | NOV<br>R5,A    | XOR<br>A, RS         | ABD<br>A, 86    | OR<br>A,RS     | 86,#d8            | CHP<br>86, #48    | SETS<br>diri6 | BBS dir<br>16,rel | INC<br>Nó          | DEC             | CMLLV<br>#6     | BGE<br>rel     |
| F | MDV<br>År R7    | CHF<br>A.K7     | ADDC<br>A, K7    | suac<br>A, K7    | N00<br>87, A   | XOR<br>A, R7         | AKD<br>A., R7   | ак<br>А, К7    | 80V<br>87,#d8     | CHP<br>87,#d8     | 8ETB<br>dir:7 | BBS dir<br>17,rel | IBC 87             | DEC<br>R7       | CALLV<br>#7     | BL7<br>rel     |



| Table 5.15 | Mask | Options |
|------------|------|---------|
|------------|------|---------|

| NO | Туре                                                                                                                                                                                                                                                                                        | MB89635<br>MB89636<br>MB89637               | MB89P637<br>MB89W637                      | MB89PV630<br>MB89T635                                         |  |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------------------------------------|---------------------------------------------------------------|--|
|    | Specification method                                                                                                                                                                                                                                                                        | Select when<br>ordering mask                | Set by<br>EPROM writer                    | Cannot be set                                                 |  |
| 1  | Pull-up resistor<br>P00 to P07, P10 to P17,<br>P30 to P37, P40 to P43,<br>P50 to P53, P72 to P74                                                                                                                                                                                            | Can be selected<br>for each pin<br>(Note 1) | Can be set for<br>each pin<br>(Note 1, 2) | Pull-up resister<br>not provided                              |  |
| 2  | Power-on reset<br>Power-on reset available<br>Power-on reset not available                                                                                                                                                                                                                  | Can be selected                             | Can be set                                | Power-on reset<br>available                                   |  |
| 3  | Main clock oscillation stabilization<br>time selection (10 MHz)<br>Approx.2 <sup>18</sup> /fch (Approx. 26.2 ms)<br>Approx.2 <sup>17</sup> /fch (Approx. 13.1 ms)<br>Approx.2 <sup>14</sup> /fch (Approx. 1.6 ms)<br>Approx.2 <sup>4</sup> /fch (Approx. 0 ms)<br>fch: Main clock frequency | Can be selected                             | Can be set                                | 2 <sup>18</sup> /fch (26.2 ms)                                |  |
| 4  | Reset pin output<br>Reset output provided<br>Reset output not provided                                                                                                                                                                                                                      | Can be selected                             | Can be set                                | Reset output<br>provided                                      |  |
| 5  | System clock selection<br>(Initial value)                                                                                                                                                                                                                                                   | Fixed to 64/fch<br>(6.4 µs)                 | Fixed to 64/fch<br>(6.4 µs)               | Fixed to 64/fch<br>(6.4 µs)                                   |  |
| 6  | Single clock option<br>Single clock<br>Double clocks                                                                                                                                                                                                                                        | Can be selected                             | Can be selected                           | MB89PV630-101<br>Single clock<br>MB89T635-101<br>Single clock |  |
|    |                                                                                                                                                                                                                                                                                             |                                             |                                           | MB89PV630-102<br>Double clock<br>MB89T635-102<br>Double clock |  |

# Notes:

1: When using P72 and P73 as standby cancel pins, the pull-up resistor should not be set.

2: Pull-up resistor cannot be selected for P50 to P53.

# APPENDIX

APPENDIX 1 I/O MAP..... App.-3 APPENDIX 2 WRITING TO EPROM OF MB89P637 . App.-5 APPENDIX 3 SETTING PROM OPTION ..... App.-6

# APPENDIX 1 I/O MAP

| Address | Read<br>/Write | Register | Desistances                           |       | Bit name |       |       |       |       |         |       |  |
|---------|----------------|----------|---------------------------------------|-------|----------|-------|-------|-------|-------|---------|-------|--|
|         |                | abbr     | Register name                         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1   | Bit 0 |  |
| 00H     | R/W            | PDR0     | Port 0 data register                  | PD07  | PD06     | PD05  | PD04  | PD03  | PD02  | PD01    | PD00  |  |
| 01H     | w              | DDR0     | Port 0 direction register             | DD07  | DD06     | DD05  | DD04  | DD03  | DD02  | DD01    | DD00  |  |
| 02H     | R/W            | PDR1     | Port 1 data register                  | PD17  | PD16     | PD15  | PD14  | PD13  | PD12  | PD11    | PD10  |  |
| COH     | w              | DDR1     | Port 1 direction register             | DD17  | DD16     | DD15  | DD14  | DD13  | DD12  | DD11    | DD10  |  |
| 04H     | R/W            | PDR2     | Port 2 data register                  | PD27  | PD26     | PD25  | PD24  | PD23  | PD22  | PD21    | PD20  |  |
| 05H     | w              | BCTR     | External bus pin control register     | -     | -        | -     |       | -     | -     | HLD     | BUF   |  |
| 06H     | -              | -        | _                                     | -     | -        | -     | -     | -     | -     | -       | -     |  |
| 07H     | R/W            | SYCC     | System clock control register         | SCM   | -        | -     | WT1   | WTO   | SCS   | CS1     | CS0   |  |
| 08H     | R/W            | STBC     | Standby control register              | STP   | SLP      | SPL   | RST   | TMD   | -     |         | ·     |  |
| OGH     | R/W            | WDTE     | Watchdog timer control register       | CS    | -        | -     | -     | WTE3  | WTE2  | WTE1    | WTE   |  |
| GAH     | R/W            | TBCR     | Time-base timer control register      | TBOF  | TBIE     | -     | -     | -     | TBC1  | TBC0    | TBR   |  |
| OBH     | R/W            | WPCR     | Watch prescaler control register      | WIF   | WIE      | -     |       |       | WS1   | WS0     | WCLF  |  |
| 0CH     | R/W            | CHG3     | Port 3 change register                | -     | -        | CG35  | CG34  | CG33  | -     | -       | -     |  |
| ODH     | R/W            | PDR3     | Port 3 data register                  | PD37  | PD36     | PD35  | PD34  | PD33  | PD32  | PD31    | PD30  |  |
| OEH     | w              | DDR3     | Port 3 direction register             | DD37  | DD36     | DD35  | DD34  | DD33  | DD32  | DD31    | DD30  |  |
| OFH     | R/W            | PDR4     | Port 4 data register                  | -     | -        | -     |       | PD43  | PD42  | PD41    | PD40  |  |
| 10H     | w              | DDR4     | Port 4 direction register             | -     | -        | -     | -     | DD43  | DD42  | DD41    | DD40  |  |
| 11H     | R/W            | BUZR     | Buzzer register                       | -     | -        | -     | -     |       |       | BUZ1    | BUZO  |  |
| 12H     | R/W            | PDR5     | Port 5 data register                  | -     | -        |       |       | PD53  | PD62  | PD51    | PD60  |  |
| 13H     | R/W            | PDR6     | Port 6 data register                  | PD67  | PD66     | PD65  | PD64  | PD63  | PD62  | PD61    | PD60  |  |
| 14H     | R              | PDR7     | Port 7 data register                  |       |          | -     | PD74  | PD73  | PD72  | PD71    | PD70  |  |
| 15H     | R/W            | PCR1     | PWC pulse width control register 1    | EN    | TOE      | IE    | -     |       | UF    | IR      | BF    |  |
| 16H     | R/W            | PCR2     | PWC pulse width control register 2    | FC    | RM       | TO    | -     | C1    | CO    | W1      | W0    |  |
| 17H     | R/W            | ALBA     | PWC reload buffer register            | RLB7  | ALB6     | RLB5  | RLB4  | RLB3  | RL82  | RLB1    | RLBO  |  |
| 18H     | R/W            | TMCR     | 16-bit timer control register         | -     | -        | TCR   | TCS1  | TCS0  | TCEF  | TCIE    | TCS   |  |
| 19H     | R/W            | TCHR     | 16-bit timer count register (H)       | TC15  | TC14     | TC13  | TC12  | TC11  | TC10  | TC09    | TC08  |  |
| 1AH     | R/W            | TCLR     | 16-bit timer count register (L)       | TC07  | TC06     | TC05  | TC04  | TC03  | TC02  | TC01    | TC00  |  |
| 18H     | -              | -        | -                                     | -     | -        | _     | -     | -     | -     | -       | -     |  |
| 1CH     | R/W            | SMR1     | Serial mode register                  | SIOF  | SICE     | SCKE  | SOE   | CKS1  | CKS0  | BDS     | SST   |  |
| 1DH     | R/W            | SDR1     | Serial data register                  | SD07  | SD06     | SD05  | SD04  | SD03  | SD02  | SD01    | SD00  |  |
| 1EH     | -              | -        | _                                     | _     | -        |       | -     | -     |       | -       | -     |  |
| 1FH     | -              | -        | -                                     | _     | -        | _     | _     | _     | -     | -       | -     |  |
| 20H     | R/W            | ADC1     | A/D control register 1                | ANS3  | ANS2     | ANS1  | ANS0  | ADI   | ADMV  | SIFM    | AD    |  |
| 21H     | R/W            | ADC2     | A/D control register 2                | -     | TIM1     | TIMO  | ADCK  | ADIE  | ADMD  | EXT     | TEST  |  |
| 22H     | R/W            | ADDH     | A/D data register (H)                 | _     | -        |       | -     | -     | -     | ADD9    | ADDR  |  |
| 23H     | R/W            | ADDL     | A/D data register (L)                 | ADD7  | ADD6     | ADD5  | ADD4  | ADD3  | ADD2  | ADD1    | ADDO  |  |
| 24H     | R/W            | EIC1     | External interrupt control register 1 | EIR1  | -        | SEL1  | EIE1  | EIR0  | INTE  | SELO    | EIE0  |  |
| 25H     | R/W            | EIC2     | External interrupt control register 2 | EIR3  | _        | SEL3  | EIE3  | EIR2  | _     | SEL2    | EIE2  |  |
| 26H     | -              | -        | _                                     | -     |          | _     |       | _     | _     | -       | -     |  |
| 27H     | _              | -        |                                       |       |          | _     | -     | _     | -     | · · - · | _     |  |
| 28H     | R/W            | CNTR1    | PWM timer control register 1          | PTX1  | PTX2     | P7M1  | P7M2  | SC11  | SC10  | SC21    | SC20  |  |
| 29H     | R/W            | CNTR2    | PWM timer control register 2          | TPE1  | TPE2     | CK12  | -     | TIR1  | TIR2  | TIE1    | TIE2  |  |

| Address       | Read<br>/Write | Register<br>abbr | Register name                                                       | Bit name     |              |              |              |              |              |              |              |
|---------------|----------------|------------------|---------------------------------------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Address       |                |                  | Hegister hame                                                       | Bit 7        | Bit 6        | Bit 5        | Bit 4        | Bit 3        | Bit 2        | Bit 1        | Bit 0        |
| 2AH           | R/W            | <b>CNTR3</b>     | PWM timer control register 3                                        | -            | OE2          | OE3          | CH12         | -            | -            | -            | -            |
| 2BH           | w              | COMR1            | PWM timer compare register 1                                        | CM17         | CM16         | CM15         | CM14         | CM13         | CM12         | CM11         | CM10         |
| 2CH           | w              | COMR2            | PWM timer compare register 2                                        | CM27         | CM26         | CM25         | CM24         | CM23         | CM22         | CM21         | CM20         |
| 2DH           | R/W            | SMC              | UART serial mode control register                                   | PEN          | SBL          | CM1          | CM0          | SMDE         | -            | UCKE         | UOE          |
| 2EH           | R/W            | SRC              | UART serial rate control register                                   | -            | -            | CR           | SCS1         | SCS0         | RC2          | RC1          | RC0          |
| 2FH           | R/W            | SSD              | UART serial status & data register                                  | RDRF         | ORRE         | TDRE         | TIE          | AIE          | PSEL         | TD6/TP       | RD6/RP       |
| 30H           | R              | SIDR             | UART serial input data register<br>UART serial output data register | SID7<br>SOD7 | SID6<br>SOD6 | SID6<br>SOD5 | SID4<br>SOD4 | SID3<br>SOD3 | SID2<br>SOD2 | SID1<br>SOD1 | SID0<br>SOD0 |
| 31H to<br>7BH |                |                  |                                                                     | -            |              | -            | -            | -            | -            | -            | -            |
| 7CH           | w              | ILR1             | Interrupt level setting register 1                                  | L31          | L30          | L21          | L20          | L11          | L10          | L01          | L00          |
| 7DH           | w              | ILR2             | Interrupt level setting register 2                                  | L71          | L70          | L61          | L60          | L51          | L50          | L41          | L40          |
| 7EH           | w.             | ILR3             | Interrupt level setting register 3                                  | LB1          | LB0          | LA1          | LAD          | L91          | L90          | L81          | L80          |
| 7FH           | -              | -                |                                                                     | -            |              | -            | -            | -            | -            | -            | -            |

Note: - is empty space. Do not use this space.



# APPENDIX 2 WRITING TO EPROM OF MB89P637

Use of a dedicated conversion socket permits writing to the MB89P637A with a general-purpose EPROM writ er. This allows the MB89P657A to have the functions equivalent to those of the MBM27C256A.

However, electronic signature mode cannot be used.

<Writing>

(1) Set the EPROM writer to the write mode of the MBM27C256A.

(2) Load program data into the addresses  $0007_{H}$  to  $7FFF_{H}$  of the EPROM writer.

(Addresses  $8000_{\text{H}}$  to  $7\text{FFF}_{\text{H}}$  in single-chip operation correspond to the addresses  $0000_{\text{H}}$  to  $7\text{FFF}_{\text{H}}$  in the EPROM mode.)

Load the option information into the addresses  $0000_{\text{H}}$  to  $0006_{\text{H}}$  of the EPROM writer. (See bit map in App. 6 for the correspondence of each option.)

(3) Use the EPROM writer to write data to the addresses  $0000_{H}$  to  $7FFF_{H}$ .

The memory space in each mode, such as PROM32K and option PROM, is shown below.



# APPENDIX 3 SETTING PROM OPTION

Bit Map for PROM Option

|                  | 7                               | 6                               | 5                               | 4                                                                  | 3                                                       | 2                                                       | 1                                                                                                                    | 0                               |  |
|------------------|---------------------------------|---------------------------------|---------------------------------|--------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------|--|
| 900 <sub>H</sub> | Empty<br>Read/write<br>possible | Empty<br>Read/write<br>possible | Empty<br>Read/write<br>possible | Single clock<br>specification<br>1 Double clocks<br>2 Single clock | Reset pin<br>output<br>1 Available<br>2 Unavailable     | Power-on reset                                          | Oscillation stabilization (Fth)<br>11: 2 <sup>18</sup> 01: 2 <sup>17</sup><br>10: 2 <sup>14</sup> 00: 2 <sup>4</sup> |                                 |  |
| 001 <sub>H</sub> | P07                             | P06                             | P05                             | P04                                                                | P03                                                     | P02                                                     | P01                                                                                                                  | P00                             |  |
|                  | Pull-up resistor                | Pull-up resistor                | Pull-up resistor                | Pull-up resistor                                                   | Pull-up resistor                                        | Pull-up resistor                                        | Pull-up resistor                                                                                                     | Pull-up resisto                 |  |
|                  | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                                                      | 1 Unavailable                                           | 1 Unavailable                                           | 1 Unavailable                                                                                                        | 1 Unavailable                   |  |
|                  | 0 Available                     | 0 Available                     | 0 Available                     | 0 Available                                                        | 0 Available                                             | 0 Available                                             | 0 Available                                                                                                          | 0 Available                     |  |
| 002 <sub>H</sub> | P17                             | P16                             | P15                             | P14                                                                | P13                                                     | P12                                                     | P11                                                                                                                  | P10                             |  |
|                  | Pull-up resistor                | Pull-up resistor                | Puli-up resistor                | Puli-up resistor                                                   | Pull-up resistor                                        | Pull-up resistor                                        | Pull-up resistor                                                                                                     | Pull-up resisto                 |  |
|                  | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                                                      | 1 Unevailable                                           | 1 Unavailable                                           | 1 Unavailable                                                                                                        | 1 Unavailable                   |  |
|                  | 0 Available                     | 0 Available                     | 0 Available                     | 0 Available                                                        | 0 Available                                             | 0 Available                                             | 0 Available                                                                                                          | 0 Available                     |  |
| 900 <sub>H</sub> | P37                             | P36                             | P35                             | P34                                                                | P33                                                     | P32                                                     | P31                                                                                                                  | P30                             |  |
|                  | Puli-up resistor                | Puli-up resistor                | Puli-up resistor                | Puli-up resistor                                                   | Pull-up resistor                                        | Pull-up resistor                                        | Pull-up resistor                                                                                                     | Pull-up resisto                 |  |
|                  | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                                                      | 1 Unavailable                                           | 1 Unavailable                                           | 1 Unavailable                                                                                                        | 1 Unavailable                   |  |
|                  | 0 Available                     | 0 Available                     | 0 Available                     | 0 Available                                                        | 0 Available                                             | 0 Available                                             | 0 Available                                                                                                          | 0 Available                     |  |
| 004 <sub>H</sub> | P53                             | P52                             | P51                             | P50                                                                | P43                                                     | P42                                                     | P41                                                                                                                  | P40                             |  |
|                  | Puli-up resistor                | Puli-up resistor                | Puli-up resistor                | Pull-up resistor                                                   | Pull-up resistor                                        | Pull-up resistor                                        | Pull-up resistor                                                                                                     | Pull-up resisto                 |  |
|                  | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                   | 1 Unavailable                                                      | 1 Unavailable                                           | 1 Unavailable                                           | 1 Unavailable                                                                                                        | 1 Unavailable                   |  |
|                  | 0 Available                     | 0 Available                     | 0 Available                     | 0 Available                                                        | 0 Available                                             | 0 Available                                             | 0 Available                                                                                                          | 0 Available                     |  |
| 005 <sub>H</sub> | Empty<br>Read/write<br>possible | Empty<br>Read/write<br>possible | Empty<br>Read/write<br>possible | P74<br>Pull-up resistor<br>1 Unavailable<br>0 Available            | P73<br>Puli-up resistor<br>1 Unavailable<br>0 Available | P72<br>Puli-up resistor<br>1 Unavailable<br>0 Available | Empty<br>Read/write<br>possible                                                                                      | Empty<br>Read/write<br>possible |  |
| 006 <sub>H</sub> | Empty                           | Empty                           | Empty                           | Empty                                                              | Empty                                                   | Empty                                                   | Empty                                                                                                                | Reserved*                       |  |
|                  | Read/write                      | Read/write                      | Read/write                      | Read/write                                                         | Read/write                                              | Read/write                                              | Read/write                                                                                                           | Read/write                      |  |
|                  | possible                        | possible                        | possible                        | possible                                                           | possible                                                | possible                                                | possible                                                                                                             | possible                        |  |

# Notes:

- \* Always write 1 to reserved bit.
- \*\* Each bit is set to 1 when PROM data is erased.