**Preliminary User's Manual** 



# 78K0/KF1

# **8-Bit Single-Chip Microcontrollers**

μPD780143 μPD780144 μPD780146 μPD780148 μPD78F0148

Document No. U15947EJ1V1UD00 (1st edition) Date Published July 2002 N CP(K)

© NEC Corporation 2002 Printed in Japan [MEMO]

#### **①** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

#### **②** HANDLING OF UNUSED INPUT PINS FOR CMOS

#### Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

#### **③** STATUS BEFORE INITIALIZATION OF MOS DEVICES

#### Note:

Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

Windows and Windows NT are either registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries.

PC/AT is a trademark of International Business Machines Corporation.

HP9000 series 700 and HP-UX are trademarks of Hewlett-Packard Company.

SPARCstation is a trademark of SPARC International, Inc.

Solaris and SunOS are trademarks of Sun Microsystems, Inc.

Ethernet is a trademark of Xerox Corp.

OSF/Motif is a trademark of Open Software Foundation, Inc.

TRON stands for The Realtime Operating system Nucleus.

ITRON is an abbreviation of Industrial TRON.

The export of these products from Japan is regulated by the Japanese government. The export of some or all of these products may be prohibited without governmental license. To export or re-export some or all of these products from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative.

#### License not needed: µPD78F0148

The customer must judge the need for a license:  $\mu$ PD780143, 780144, 780146, and 780148

- The information contained in this document is being issued in advance of the production cycle for the device. The parameters for the device may change before final production or NEC Corporation, at its own discretion, may withdraw the device prior to its production.
- Not all devices/types available in every country. Please check with local NEC representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.
- NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property
  rights of third parties by or arising from use of a device described herein or any other liability arising from use
  of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other
  intellectual property rights of NEC Corporation or others.
- Descriptions of circuits, software, and other related information in this document are provided for illustrative purposes in semiconductor product operation and application examples. The incorporation of these circuits, software, and information in the design of the customer's equipment shall be done under the full responsibility of the customer. NEC Corporation assumes no responsibility for any losses incurred by the customer or third parties arising from the use of these circuits, software, and information.
- While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.
- NEC devices are classified into the following three quality grades:

"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

- Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
- Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
- Specific: Aircraft, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.

# **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- · Device availability
- · Ordering information
- Product release schedule
- Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

#### **NEC Electronics Inc. (U.S.)**

Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288

#### NEC do Brasil S.A.

Electron Devices Division Guarulhos-SP, Brasil Tel: 11-6462-6810 Fax: 11-6462-6829

#### NEC Electronics (Europe) GmbH

Duesseldorf, Germany Tel: 0211-65 03 01 Fax: 0211-65 03 327

- Sucursal en España Madrid, Spain Tel: 091-504 27 87 Fax: 091-504 28 60
- Succursale Française Vélizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

- Filiale Italiana Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99
- Branch The Netherlands Eindhoven, The Netherlands Tel: 040-244 58 45 Fax: 040-244 45 80
- Branch Sweden Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388
- United Kingdom Branch Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290

#### NEC Electronics Hong Kong Ltd. Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

NEC Electronics Hong Kong Ltd. Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411

#### NEC Electronics Shanghai, Ltd.

Shanghai, P.R. China Tel: 021-6841-1138 Fax: 021-6841-1137

#### **NEC Electronics Taiwan Ltd.**

Taipei, Taiwan Tel: 02-2719-2377 Fax: 02-2719-5951

#### NEC Electronics Singapore Pte. Ltd.

Novena Square, Singapore Tel: 253-8311 Fax: 250-3583

# Major Revisions in This Edition

| Page                   | Description                                                                                                                                                                                                                               |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| p.73<br>p.74<br>p.76   | Modification of reset value of the following registers in <b>Table 3-5 Special Function Register List</b><br>• Serial I/O shift register 10 (SIO10)<br>• Serial I/O shift register 11 (SIO11)<br>• Interrupt mask flag register 1H (MK1H) |
| p.75                   | Modification of manipulatable bit unit of the following register in Table 3-5 Special Function Register List     Oscillation stabilization time counter status register (OSTC)                                                            |
| p.139                  | Modification of manipulatable bit unit and clear condition in 6.3 (5) Oscillation stabilization time counter status register (OSTC)                                                                                                       |
| pp.146 to 149          | Modification of Figure 6-13 Status Transition Diagram                                                                                                                                                                                     |
| p.150                  | Modification of Table 6-4 Oscillation Control Flags and Clock Oscillation Status                                                                                                                                                          |
| p.162                  | Modification of reset value in 7.2 (2) 16-bit timer capture/compare register 00n (CR00n) and (3) 16-bit timer capture/compare register 01n (CR01n)                                                                                        |
| p.170                  | Modification of manipulatable bit unit in 7.3 (4) Prescaler mode register 0n (PRM0n)                                                                                                                                                      |
| p.276                  | Addition of caution description in 13.6 (10) A/D conversion result register (ADCR) read operation                                                                                                                                         |
| p.347                  | Modification of reset value in 16.2 (2) Serial I/O shift register 1n (SIO1n)                                                                                                                                                              |
| p.435                  | Modification of reset value in 19.3 (2) Interrupt mask flag register (MK1H)                                                                                                                                                               |
| p.450                  | Modification of manipulatable bit unit and clear condition in 21.1.2 (1) Oscillation stabilization time counter status register (OSTC)                                                                                                    |
| pp.452, 453            | Modification of A/D converter item in Table 21-2 Operating Statuses in HALT Mode                                                                                                                                                          |
| pp.466, 468            | Modification of stop condition of clock monitor in 23.1 Functions of Clock Monitor and 23.4 Operation o<br>Clock Monitor                                                                                                                  |
| pp.474, 475            | Addition of 24.4 Cautions for Power-on-Clear Circuit                                                                                                                                                                                      |
| p.479                  | Modification of Figure 25-3 Format of Low-Voltage Detection Level Selection Register (LVIS)                                                                                                                                               |
| pp.484 to 487          | Addition of 25.5 Cautions for Low-Voltage Detector                                                                                                                                                                                        |
| p.488                  | Modification of description in 26.1 Outline of Regulator                                                                                                                                                                                  |
|                        | Modification of the following contents in CHAPTER 30 ELECTRICAL SPECIFICATIONS (TARGET VALUES)                                                                                                                                            |
| pp.515, 516            | Absolute Maximum Ratings     X1 Opsillator Observatoristics                                                                                                                                                                               |
| p.517                  | X1 Oscillator Characteristics     Subsystem Clock Oscillator Characteristics                                                                                                                                                              |
| p.518<br>pp.519 to 522 | Characteristics                                                                                                                                                                                                                           |
| p.534                  | A/D Converter Characteristics                                                                                                                                                                                                             |
| p.534                  | POC Circuit Characteristics                                                                                                                                                                                                               |
| p.535                  | LVI Circuit Characteristics                                                                                                                                                                                                               |
| p.535                  | Data Memory STOP Mode Low Supply Voltage Data Retention Characteristics (deletion of data retention supply current)                                                                                                                       |
| p.535                  | Deletion of Ring-OSC Characteristics                                                                                                                                                                                                      |
| pp.536, 537            | Flash Memory Programming Characteristics                                                                                                                                                                                                  |
| pp.540 to 542          | Modification from CHAPTER 32 RETRY to CHAPTER 32 CAUTIONS FOR WAIT                                                                                                                                                                        |

The mark  $\star$  shows major revised points.

#### INTRODUCTION

| Readers<br>Purpose      | <ul> <li>78K0/KF1 Series and design and develop devices.</li> <li>The target products are as follows.</li> <li>78K0/KF1 Series: μPD780143, 780144, 78</li> </ul>                                                                                                                                           | s who wish to understand the functions of the<br>application systems and programs for these<br>80146, 780148, and 78F0148<br>nderstanding of the functions described in the |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | Organization below.                                                                                                                                                                                                                                                                                        |                                                                                                                                                                             |
| Organization            | The 78K0/KF1 Series manual is separa instructions edition (common to the 78K/0 \$                                                                                                                                                                                                                          | ated into two parts: this manual and the Series).                                                                                                                           |
|                         | 78K0/KF1<br>User's Manual<br>(This Manual)                                                                                                                                                                                                                                                                 | 78K/0 Series<br>User's Manual<br>Instructions                                                                                                                               |
|                         | <ul> <li>Pin functions</li> <li>Internal block functions</li> <li>Interrupts</li> <li>Other on-chip peripheral functions</li> <li>Electrical specifications</li> </ul>                                                                                                                                     | <ul><li>CPU functions</li><li>Instruction set</li><li>Explanation of each instruction</li></ul>                                                                             |
| How to Read This Manual | It is assumed that the readers of this mengineering, logic circuits, and microcontro                                                                                                                                                                                                                       |                                                                                                                                                                             |
|                         | → Only the quality grade differs betw<br>products. Read the part number as f<br>• $\mu$ PD780143 → $\mu$ PD780143(A), 780<br>• $\mu$ PD780144 → $\mu$ PD780144(A), 780<br>• $\mu$ PD780146 → $\mu$ PD780146(A), 780<br>• $\mu$ PD780148 → $\mu$ PD780148(A), 780<br>• $\mu$ PD78F0148 → $\mu$ PD78F0148(A) | 0143(A1)<br>0144(A1)<br>0146(A1)                                                                                                                                            |
|                         | •                                                                                                                                                                                                                                                                                                          | CONTENTS.<br>e, the bit name is defined as a reserved word<br>ined in the header file named sfrbit.h in the C<br>you know the register name.                                |

|             | • To know details of the 78   | 3K/0 Series inst             | ructions.                                                                                                                  |
|-------------|-------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------|
|             | ightarrow Refer to the separa | te document 7                | '8K/0 Series Instructions User's Manual                                                                                    |
|             | (U12326E).                    |                              |                                                                                                                            |
|             | general electro               | nics. When<br>y grade, revie | nploy the "standard" quality grade for<br>using examples in this manual for the<br>w the quality grade of each part and/or |
| Conventions | Data significance:            | Higher digits o              | n the left and lower digits on the right                                                                                   |
|             | Active low representations:   | xxx (overscore               | e over pin and signal name)                                                                                                |
|             | Note:                         | Footnote for ite             | em marked with <b>Note</b> in the text.                                                                                    |
|             | Caution:                      | Information red              | quiring particular attention                                                                                               |
|             | Remark:                       | Supplementar                 | y information                                                                                                              |
|             | Numerical representations:    | Binary                       | ···×××× or ××××B                                                                                                           |
|             |                               | Decimal                      | ····××××                                                                                                                   |
|             |                               | Hexadecimal                  | ···××××H                                                                                                                   |
|             |                               |                              |                                                                                                                            |

Related DocumentsThe related documents indicated in this publication may include preliminary versions.However, preliminary versions are not marked as such.

#### **Documents Related to Devices**

| Document Name                           | Document No. |
|-----------------------------------------|--------------|
| 78K0/KF1 User's Manual                  | This manual  |
| 78K/0 Series Instructions User's Manual | U12326E      |

#### Documents Related to Development Tools (Software) (User's Manuals)

| Document Name                                       |                                                     | Document No. |
|-----------------------------------------------------|-----------------------------------------------------|--------------|
| RA78K0 Assembler Package                            | Operation                                           | U14445E      |
|                                                     | Language                                            | U14446E      |
|                                                     | Structured Assembly Language                        | U11789E      |
| CC78K0 C Compiler                                   | Operation                                           | U14297E      |
|                                                     | Language                                            | U14298E      |
| SM78K0S, SM78K0 System Simulator Ver. 2.10 or Later | Operation (Windows <sup>™</sup> Based)              | U14611E      |
| SM78K Series System Simulator Ver. 2.10 or Later    | External Part User Open Interface<br>Specifications | U15006E      |
| ID78K0-NS Integrated Debugger Ver. 2.00 or Later    | Operation (Windows Based)                           | U14379E      |
| ID78K0 Integrated Debugger Windows Based            | Reference                                           | U11539E      |
|                                                     | Guide                                               | U11649E      |
| RX78K0 Real-Time OS                                 | Fundamentals                                        | U11537E      |
|                                                     | Installation                                        | U11536E      |
| Project Manager Ver. 3.12 or Later (Windows Based)  |                                                     | U14610E      |

# Caution The related documents listed above are subject to change without notice. Be sure to use the latest version of each document when designing.

#### Documents Related to Development Tools (Hardware) (User's Manuals)

| Document Name                    | Document No.   |
|----------------------------------|----------------|
| IE-78K0-NS In-Circuit Emulator   | U13731E        |
| IE-78K0-NS-A In-Circuit Emulator | U14889E        |
| IE-780148-NS-EM1 Emulation Board | To be prepared |

#### **Documents Related to Flash Memory Programming**

| Document Name                                | Document No. |
|----------------------------------------------|--------------|
| PG-FP3 Flash Memory Programmer User's Manual | U13502E      |

#### **Other Documents**

| Document Name                                                                      | Document No. |
|------------------------------------------------------------------------------------|--------------|
| SEMICONDUCTOR SELECTION GUIDE – Product & Packages –                               | X13769E      |
| Semiconductor Device Mounting Technology Manual                                    | C10535E      |
| Quality Grades on NEC Semiconductor Devices                                        | C11531E      |
| NEC Semiconductor Device Reliability/Quality Control System                        | C10983E      |
| Guide to Prevent Damage for Semiconductor Devices by Electrostatic Discharge (ESD) | C11892E      |

# Caution The related documents listed above are subject to change without notice. Be sure to use the latest version of each document when designing.

#### CONTENTS

| CHAPTE | R 1 OUTLINE                                                | 28 |
|--------|------------------------------------------------------------|----|
| 1.1 F  | eatures                                                    | 28 |
| 1.2 A  | Applications                                               | 29 |
| 1.3 C  | Ordering Information                                       | 29 |
|        | Quality Grade                                              |    |
| 1.5 F  | Pin Configuration (Top View)                               | 34 |
| 1.6 7  | '8K0/Kxx Series Lineup                                     | 37 |
|        | Block Diagram                                              |    |
| 1.8 C  | Dutline of Functions                                       | 39 |
|        |                                                            |    |
|        | R 2 PIN FUNCTIONS                                          |    |
|        | Pin Function List                                          |    |
|        | Description of Pin Functions                               |    |
|        | 2.2.1 P00 to P06 (port 0)                                  |    |
|        | 2.2.2 P10 to P17 (port 1)                                  |    |
|        | 2.2.3 P20 to P27 (port 2)                                  |    |
|        | 2.2.4 P30 to P33 (port 3)                                  |    |
|        | 2.2.5 P40 to P47 (port 4)                                  |    |
|        | 2.2.6 P50 to P57 (port 5)                                  |    |
|        | 2.2.7 P60 to P67 (port 6)<br>2.2.8 P70 to P77 (port 7)     |    |
|        | 2.2.9 P120 (port 12)                                       |    |
|        | 2.2.10 P130 (port 13)                                      |    |
|        | 2.2.11 P140 to P145 (port 14)                              |    |
|        | 2.2.12 AV <sub>REF</sub>                                   |    |
|        | 2.2.13 AVNEF                                               |    |
|        | 2.2.14 RESET                                               |    |
|        | 2.2.15 REGC                                                |    |
|        | 2.2.16 X1 and X2                                           |    |
|        | 2.2.17 XT1 and XT2                                         |    |
|        | 2.2.18 Vpd and EVpd                                        |    |
|        | 2.2.19 Vss and EVss                                        |    |
|        | 2.2.20 VPP (flash memory versions only)                    |    |
|        | 2.2.21 IC (mask ROM versions only)                         |    |
|        | Pin I/O Circuits and Recommended Connection of Unused Pins |    |
|        |                                                            |    |
| CHAPTE | R 3 CPU ARCHITECTURE                                       | 55 |
| 3.1 N  | lemory Space                                               | 55 |
|        | 3.1.1 Internal program memory space                        | 61 |
|        | 3.1.2 Internal data memory space                           | 62 |
|        | 3.1.3 Special function register (SFR) area                 | 62 |
|        | 3.1.4 Data memory addressing                               |    |
| 3.2 F  | Processor Registers                                        | 68 |
|        | 3.2.1 Control registers                                    | 68 |
|        | 3.2.2 General-purpose registers                            | 71 |

|          | 3.2.3 Special Function Registers (SFRs)                                                                       | 70  |
|----------|---------------------------------------------------------------------------------------------------------------|-----|
| 2 2      | Instruction Address Addressing                                                                                |     |
| 3.3      | 3.3.1 Relative addressing                                                                                     |     |
|          | 3.3.2 Immediate addressing                                                                                    |     |
|          | C C                                                                                                           |     |
|          | 3.3.3 Table indirect addressing                                                                               |     |
| 2.4      | 3.3.4 Register addressing Operand Address Addressing                                                          |     |
| 3.4      | 3.4.1 Implied addressing                                                                                      |     |
|          | 3.4.1 Implied addressing                                                                                      |     |
|          | 3.4.2 Direct addressing                                                                                       |     |
|          | 3.4.4 Short direct addressing                                                                                 |     |
|          | -                                                                                                             |     |
|          | <ul><li>3.4.5 Special function register (SFR) addressing</li><li>3.4.6 Register indirect addressing</li></ul> |     |
|          | 3.4.7 Based addressing                                                                                        |     |
|          | 3.4.8 Based indexed addressing                                                                                |     |
|          | 3.4.9 Stack addressing                                                                                        |     |
|          | 3.4.9 Stack addressing                                                                                        |     |
| снарт    | ER 4 PORT FUNCTIONS                                                                                           | 88  |
|          | Port Functions                                                                                                |     |
|          | Port Configuration                                                                                            |     |
| 7.2      | 4.2.1 Port 0                                                                                                  |     |
|          | 4.2.2 Port 1                                                                                                  | -   |
|          | 4.2.3 Port 2                                                                                                  |     |
|          | 4.2.4 Port 3                                                                                                  |     |
|          | 4.2.5 Port 4                                                                                                  |     |
|          | 4.2.6 Port 5                                                                                                  |     |
|          | 4.2.7 Port 6                                                                                                  |     |
|          | 4.2.8 Port 7                                                                                                  |     |
|          | 4.2.9 Port 12                                                                                                 |     |
|          | 4.2.10 Port 13                                                                                                |     |
|          | 4.2.10 Port 13                                                                                                |     |
| 13       | Registers Controlling Port Function                                                                           |     |
|          | Port Function Operations                                                                                      |     |
|          | 4.4.1 Writing to I/O port                                                                                     |     |
|          | 4.4.2 Reading from I/O port                                                                                   |     |
|          | 4.4.3 Operations on I/O port                                                                                  |     |
|          |                                                                                                               |     |
| СНАРТ    | ER 5 EXTERNAL BUS INTERFACE                                                                                   | 122 |
|          | External Bus Interface                                                                                        |     |
|          | Registers Controlling External Bus Interface                                                                  |     |
|          | External Bus Interface Function Timing                                                                        |     |
|          | Example of Connection with Memory                                                                             |     |
| 5.4      |                                                                                                               |     |
| СНАРТ    | ER 6 CLOCK GENERATOR                                                                                          | 133 |
|          | Functions of Clock Generator                                                                                  |     |
|          | Configuration of Clock Generator                                                                              |     |
|          | Registers Controlling Clock Generator                                                                         |     |
|          | System Clock Oscillator                                                                                       |     |
| <b>.</b> | -,                                                                                                            |     |

|       | 6.4.1 X1 oscillator                                                  | 141 |
|-------|----------------------------------------------------------------------|-----|
|       | 6.4.2 Subsystem clock oscillator                                     | 141 |
|       | 6.4.3 When subsystem clock is not used                               | 144 |
|       | 6.4.4 Ring-OSC oscillator                                            | 144 |
|       | 6.4.5 Prescaler                                                      |     |
| 6.5   | Clock Generator Operation                                            | 144 |
| 6.6   | Time Required to Switch Between Ring-OSC Clock and X1 Input Clock    | 151 |
| 6.7   | Changing System Clock and CPU Clock Settings                         | 152 |
|       | 6.7.1 Time required for switching between system clock and CPU clock | 152 |
| 6.8   | Clock Switching Flowchart and Register Setting                       | 153 |
|       | 6.8.1 Switching from Ring-OSC clock to X1 input clock                | 153 |
|       | 6.8.2 Switching from X1 input clock to Ring-OSC clock                | 154 |
|       | 6.8.3 Switching from X1 input clock to subsystem clock               | 155 |
|       | 6.8.4 Switching from subsystem clock to X1 input clock               | 156 |
|       | 6.8.5 Register settings                                              | 157 |
| СНАРТ | FER 7 16-BIT TIMER/EVENT COUNTERS 00 AND 01                          | 158 |
| 7.1   | Functions of 16-Bit Timer/Event Counters 00 and 01                   | 158 |
|       | Configuration of 16-Bit Timer/Event Counters 00 and 01               |     |
|       | Registers Controlling 16-Bit Timer/Event Counters 00 and 01          |     |
| 7.4   | Operation of 16-Bit Timer/Event Counters 00 and 01                   | 174 |
|       | 7.4.1 Interval timer operation                                       | 174 |
|       | 7.4.2 PPG output operations                                          | 176 |
|       | 7.4.3 Pulse width measurement operations                             | 178 |
|       | 7.4.4 External event counter operation                               | 185 |
|       | 7.4.5 Square-wave output operation                                   | 187 |
|       | 7.4.6 One-shot pulse output operation                                |     |
| 7.5   | Cautions for 16-Bit Timer/Event Counters 00 and 01                   | 193 |
|       | TER 8 8-BIT TIMER/EVENT COUNTERS 50 AND 51                           |     |
|       | Functions of 8-Bit Timer/Event Counters 50 and 51                    |     |
|       | Configuration of 8-Bit Timer/Event Counters 50 and 51                |     |
|       | Registers Controlling 8-Bit Timer/Event Counters 50 and 51           |     |
| 8.4   | Operations of 8-Bit Timer/Event Counters 50 and 51                   |     |
|       | 8.4.1 Operation as interval timer                                    |     |
|       | 8.4.2 Operation as external event counter                            |     |
|       | 8.4.3 Square-wave output operation                                   |     |
|       | 8.4.4 PWM output operation                                           |     |
| 8.5   | Cautions for 8-Bit Timer/Event Counters 50 and 51                    | 212 |
|       | TER 9 8-BIT TIMERS H0 AND H1                                         |     |
|       | Functions of 8-Bit Timers H0 and H1                                  |     |
|       | Configuration of 8-Bit Timers H0 and H1                              |     |
|       | Registers Controlling 8-Bit Timers H0 and H1                         |     |
| 9.4   | Operation of 8-Bit Timers H0 and H1                                  |     |
|       | 9.4.1 Operation as interval timer                                    |     |
|       | 9.4.2 Operation as PWM pulse generator                               |     |
|       | 9.4.3 Carrier generator mode operation (8-bit timer H1 only)         | 228 |

| CHAPIE                                                                                   | R 10 WATCH TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 235                                                                                                                                             |
|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 10.1                                                                                     | Functions of Watch Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 235                                                                                                                                             |
| 10.2                                                                                     | Configuration of Watch Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 237                                                                                                                                             |
| 10.3                                                                                     | Register Controlling Watch Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 237                                                                                                                                             |
| 10.4                                                                                     | Watch Timer Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 239                                                                                                                                             |
|                                                                                          | 10.4.1 Watch timer operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 239                                                                                                                                             |
|                                                                                          | 10.4.2 Interval timer operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 240                                                                                                                                             |
|                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                 |
| CHAPTE                                                                                   | R 11 WATCHDOG TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 242                                                                                                                                             |
| 11.1                                                                                     | Functions of Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 242                                                                                                                                             |
| 11.2                                                                                     | Configuration of Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 243                                                                                                                                             |
| 11.3                                                                                     | Registers Controlling Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 244                                                                                                                                             |
| 11.4                                                                                     | Operation of Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 246                                                                                                                                             |
|                                                                                          | 11.4.1 Watchdog timer operation when "Ring-OSC cannot be stopped" is selected by mask option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 246                                                                                                                                             |
|                                                                                          | 11.4.2 Watchdog timer operation when "Ring-OSC can be stopped by software" is selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                 |
|                                                                                          | by mask option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 247                                                                                                                                             |
|                                                                                          | 11.4.3 Watchdog timer operation in STOP mode (when "Ring-OSC can be stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                 |
|                                                                                          | by software" is selected by mask option)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 248                                                                                                                                             |
|                                                                                          | 11.4.4 Watchdog timer operation in HALT mode (when "Ring-OSC can be stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                 |
|                                                                                          | by software" is selected by mask option)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 251                                                                                                                                             |
|                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                 |
| CHAPTE                                                                                   | R 12 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 252                                                                                                                                             |
|                                                                                          | Functions of Clock Output/Buzzer Output Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                 |
|                                                                                          | Configuration of Clock Output/Buzzer Output Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                 |
|                                                                                          | Register Controlling Clock Output/Buzzer Output Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 253                                                                                                                                             |
|                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                 |
| 12.4                                                                                     | Clock Output/Buzzer Output Controller Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                 |
| 12.4                                                                                     | Clock Output/Buzzer Output Controller Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 256                                                                                                                                             |
| 12.4                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>256</b><br>256                                                                                                                               |
|                                                                                          | <ul><li>12.4.1 Clock output operation</li><li>12.4.2 Operation as buzzer output</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>256</b><br>256<br>256                                                                                                                        |
| СНАРТЕ                                                                                   | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>256<br>257                                                                                                                        |
| CHAPTE<br>13.1                                                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>256<br>257<br>257                                                                                                                 |
| CHAPTE<br>13.1<br>13.2                                                                   | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>256<br>257<br>257<br>259                                                                                                          |
| CHAPTE<br>13.1<br>13.2<br>13.3                                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>259<br>261                                                                                                   |
| CHAPTE<br>13.1<br>13.2<br>13.3                                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>259<br>261<br>265                                                                                                   |
| CHAPTE<br>13.1<br>13.2<br>13.3                                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>259<br>261<br>265                                                                                            |
| CHAPTE<br>13.1<br>13.2<br>13.3                                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>265<br>265<br>267                                                                                            |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4                                                   | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>259<br>265<br>265<br>265<br>267<br>268                                                                       |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>265<br>265<br>267<br>268<br>268<br>271                                                                       |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5                                           | 12.4.1 Clock output operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 256<br>256<br>257<br>257<br>257<br>265<br>265<br>267<br>268<br>268<br>271                                                                       |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.5                                   | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         ER 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter         Cautions for A/D Converter                                                                                                                                                                                                                                                                          | 256<br>256<br>257<br>257<br>257<br>257<br>265<br>265<br>265<br>267<br>268<br>271<br>273                                                         |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE                         | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         ER 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter Characteristics Table         Cautions for A/D Converter         ER 14 SERIAL INTERFACE UART0                                                                                                                                                                                                               | 256<br>256<br>257<br>257<br>257<br>257<br>265<br>265<br>267<br>268<br>271<br>273<br>278                                                         |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE<br>14.1                 | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output <b>R</b> 13 A/D CONVERTER <b>Functions of A/D Converter Configuration of A/D Converter Registers Controlling A/D Converter A/D Converter Operations</b> 13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter         Cautions for A/D Converter <b>R</b> 14 SERIAL INTERFACE UART0 <b>Functions of Serial Interface UART0</b>                                                                                                                                                                                                                               | 256<br>256<br>257<br>257<br>257<br>259<br>265<br>265<br>265<br>267<br>268<br>271<br>273<br>278                                                  |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE<br>14.1<br>14.2         | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         IR 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter         Cautions for A/D Converter         Image: R 14 SERIAL INTERFACE UART0         Functions of Serial Interface UART0         Configuration of Serial Interface UART0                                                                                  | 256<br>256<br>257<br>257<br>257<br>259<br>265<br>265<br>265<br>267<br>268<br>271<br>273<br>278<br>278<br>278<br>279                             |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE<br>14.1<br>14.2<br>14.3 | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         IR 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter Characteristics Table         Cautions for A/D Converter         Image: R 14 SERIAL INTERFACE UART0         Functions of Serial Interface UART0         Configuration of Serial Interface UART0         Registers Controlling Serial Interface UART0                                                        | 256<br>256<br>257<br>257<br>257<br>257<br>265<br>265<br>267<br>268<br>271<br>278<br>278<br>278<br>278<br>278<br>278<br>278                      |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE<br>14.1<br>14.2<br>14.3 | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         ER 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter         Cautions for A/D Converter         ER 14 SERIAL INTERFACE UARTO         Configuration of Serial Interface UARTO         Configuration of Serial Interface UARTO         Operation of Serial Interface UARTO         Operation of Serial Interface UARTO         Operation of Serial Interface UARTO | 256<br>256<br>257<br>257<br>257<br>259<br>265<br>265<br>265<br>267<br>268<br>271<br>273<br>278<br>278<br>278<br>278<br>278<br>278<br>282<br>286 |
| CHAPTE<br>13.1<br>13.2<br>13.3<br>13.4<br>13.5<br>13.6<br>CHAPTE<br>14.1<br>14.2<br>14.3 | 12.4.1 Clock output operation         12.4.2 Operation as buzzer output         IR 13 A/D CONVERTER         Functions of A/D Converter         Configuration of A/D Converter         Registers Controlling A/D Converter         A/D Converter Operations         13.4.1 Basic operations of A/D converter         13.4.2 Input voltage and conversion results         13.4.3 A/D converter operation mode         How to Read A/D Converter Characteristics Table         Cautions for A/D Converter         Image: R 14 SERIAL INTERFACE UART0         Functions of Serial Interface UART0         Configuration of Serial Interface UART0         Registers Controlling Serial Interface UART0                                                        | 256<br>256<br>257<br>257<br>257<br>257<br>265<br>265<br>267<br>268<br>271<br>273<br>278<br>278<br>278<br>278<br>278<br>286<br>286               |

| 14.4.3 Dedicated baud rate generator                                   | 295 |
|------------------------------------------------------------------------|-----|
|                                                                        |     |
| CHAPTER 15 SERIAL INTERFACE UART6                                      |     |
| 15.1 Functions of Serial Interface UART6                               |     |
| 15.2 Configuration of Serial Interface UART6                           |     |
| 15.3 Registers Controlling Serial Interface UART6                      |     |
| 15.4 Operation of Serial Interface UART6                               |     |
| 15.4.1 Operation stop mode                                             | 316 |
| 15.4.2 Asynchronous serial interface (UART) mode                       | 317 |
| 15.4.3 Dedicated baud rate generator                                   | 335 |
| CHAPTER 16 SERIAL INTERFACES CSI10 AND CSI11                           |     |
| 16.1 Functions of Serial Interfaces CSI10 and CSI11                    |     |
| 16.2 Configuration of Serial Interfaces CSI10 and CSI11                |     |
| 16.3 Registers Controlling Serial Interfaces CSI10 and CSI11           |     |
| 16.4 Operation of Serial Interfaces CSI10 and CSI11                    |     |
| 16.4.1 Operation stop mode                                             |     |
| 16.4.2 3-wire serial I/O mode                                          |     |
| 10.4.2 5-wire senar //O mode                                           |     |
| CHAPTER 17 SERIAL INTERFACE CSIA0                                      |     |
| 17.1 Functions of Serial Interface CSIA0                               |     |
| 17.2 Configuration of Serial Interface CSIA0                           |     |
| 17.3 Registers Controlling Serial Interface CSIA0                      |     |
| 17.4 Operation of Serial Interface CSIA0                               |     |
| 17.4.1 Operation stop mode                                             |     |
| 17.4.2 3-wire serial I/O mode                                          |     |
| 17.4.3 3-wire serial I/O mode with automatic transmit/receive function | 386 |
| CHAPTER 18 MULTIPLIER/DIVIDER                                          | 410 |
|                                                                        |     |
| 18.1 Functions of Multiplier/Divider                                   |     |
| 18.2 Configuration of Multiplier/Divider                               |     |
| 18.3 Register Controlling Multiplier/Divider                           |     |
| 18.4 Operations of Multiplier/Divider                                  |     |
| 18.4.1 Multiplication operation                                        |     |
| 18.4.2 Division operation                                              | 423 |
| CHAPTER 19 INTERRUPT FUNCTIONS                                         | 428 |
| 19.1 Interrupt Function Types                                          |     |
| 19.2 Interrupt Sources and Configuration                               |     |
| 19.3 Registers Controlling Interrupt Functions                         |     |
| 19.4 Interrupt Servicing Operations                                    |     |
| 19.4.1 Maskable interrupt request acknowledgement                      |     |
| 19.4.2 Software interrupt request acknowledgement                      |     |
| 19.4.3 Multiple interrupt servicing                                    |     |
| 19.4.4 Interrupt request hold                                          |     |
|                                                                        |     |
| CHAPTER 20 KEY INTERRUPT FUNCTION                                      |     |
| 20.1 Functions of Key Interrupt                                        |     |

| 20.2 Configuration of Key Interrupt                                   |     |
|-----------------------------------------------------------------------|-----|
| 20.3 Register Controlling Key Interrupt                               | 44  |
| CHAPTER 21 STANDBY FUNCTION                                           |     |
| 21.1 Standby Function and Configuration                               |     |
| 21.1.1 Standby function                                               |     |
| 21.1.2 Registers controlling standby function                         |     |
| 21.2 Standby Function Operation                                       |     |
| 21.2.1 HALT mode                                                      |     |
| 21.2.2 STOP mode                                                      | 450 |
| CHAPTER 22 RESET FUNCTION                                             | 459 |
| 22.1 Register for Confirming Reset Source                             | 465 |
| CHAPTER 23 CLOCK MONITOR                                              | 466 |
| 23.1 Functions of Clock Monitor                                       | 466 |
| 23.2 Configuration of Clock Monitor                                   |     |
| 23.3 Registers Controlling Clock Monitor                              |     |
| 23.4 Operation of Clock Monitor                                       | 468 |
| CHAPTER 24 POWER-ON-CLEAR CIRCUIT                                     | 472 |
| 24.1 Functions of Power-on-Clear Circuit                              |     |
| 24.2 Configuration of Power-on-Clear Circuit                          |     |
| 24.3 Operation of Power-on-Clear Circuit                              |     |
| 24.4 Cautions for Power-on-Clear Circuit                              | 474 |
| CHAPTER 25 LOW-VOLTAGE DETECTOR                                       | 476 |
| 25.1 Functions of Low-Voltage Detector                                | 476 |
| 25.2 Configuration of Low-Voltage Detector                            |     |
| 25.3 Registers Controlling Low-Voltage Detector                       | 477 |
| 25.4 Operation of Low-Voltage Detector                                |     |
| 25.5 Cautions for Low-Voltage Detector                                | 484 |
| CHAPTER 26 REGULATOR                                                  | 488 |
| 26.1 Outline of Regulator                                             | 488 |
| CHAPTER 27 MASK OPTIONS                                               | 489 |
|                                                                       | 400 |
| CHAPTER 28 μPD78F0148<br>28.1 Internal Memory Size Switching Register |     |
| 28.2 Internal Expansion RAM Size Switching Register                   |     |
| 28.2 Internal Expansion RAM Size Switching Register                   |     |
|                                                                       |     |
| 28.3.1 Selection of communication mode                                |     |
| 28.3.2 Flash memory programming function                              |     |
| 28.3.3 Connecting Flashpro III                                        |     |
| 28.3.4 Connection on adapter for flash memory writing                 |     |

 $\star$ 

 $\star$ 

| CHAPTER 29 INSTRUCTION SET                                                 | 502 |
|----------------------------------------------------------------------------|-----|
| 29.1 Conventions Used in Operation List                                    | 502 |
| 29.1.1 Operand identifiers and specification methods                       | 502 |
| 29.1.2 Description of operation column                                     | 503 |
| 29.1.3 Description of flag operation column                                | 503 |
| 29.2 Operation List                                                        | 504 |
| 29.3 Instructions Listed by Addressing Type                                | 512 |
| CHAPTER 30 ELECTRICAL SPECIFICATIONS (TARGET VALUES)                       | 515 |
| CHAPTER 31 PACKAGE DRAWINGS                                                | 538 |
| * CHAPTER 32 CAUTIONS FOR WAIT                                             | 540 |
| 32.1 Cautions for Wait                                                     | 540 |
| 32.2 Peripheral Hardware That Generates Wait                               | 541 |
| 32.3 Example of Wait Occurrence                                            | 542 |
| APPENDIX A DEVELOPMENT TOOLS                                               | 543 |
| A.1 Software Package                                                       |     |
| A.2 Language Processing Software                                           | 546 |
| A.3 Flash Memory Writing Tools                                             | 547 |
| A.4 Debugging Tools                                                        | 548 |
| A.4.1 Hardware                                                             | 548 |
| A.4.2 Software                                                             | 549 |
| APPENDIX B EMBEDDED SOFTWARE                                               | 550 |
| APPENDIX C REGISTER INDEX                                                  | 551 |
| C.1 Register Index (In Alphabetical Order with Respect to Register Names)  | 551 |
| C.2 Register Index (In Alphabetical Order with Respect to Register Symbol) | 555 |

| Figure No. | Title                                      | Page |
|------------|--------------------------------------------|------|
| 2-1        | Pin I/O Circuit List                       | 53   |
| 21         |                                            |      |
| 3-1        | Метогу Мар (µPD780143)                     |      |
| 3-2        | Memory Map (μPD780144)                     |      |
| 3-3        | Memory Map (µPD780146)                     |      |
| 3-4        | Memory Map (μPD780148)                     |      |
| 3-5        | Memory Map (μPD78F0148)                    |      |
| 3-6        | Data Memory Addressing (µPD780143)         |      |
| 3-7        | Data Memory Addressing (µPD780144)         | 64   |
| 3-8        | Data Memory Addressing (µPD780146)         |      |
| 3-9        | Data Memory Addressing (µPD780148)         |      |
| 3-10       | Data Memory Addressing (µPD78F0148)        | 67   |
| 3-11       | Format of Program Counter                  |      |
| 3-12       | Format of Program Status Word              |      |
| 3-13       | Format of Stack Pointer                    | 70   |
| 3-14       | Data to Be Saved to Stack Memory           | 70   |
| 3-15       | Data to Be Restored from Stack Memory      | 70   |
| 3-16       | Configuration of General-Purpose Registers | 71   |
| 4-1        | Port Types                                 | 88   |
| 4-2        | Block Diagram of P00, P03, and P05         |      |
| 4-3        | Block Diagram of P01 and P06               |      |
| 4-4        | Block Diagram of P02                       |      |
| 4-5        | Block Diagram of P04                       |      |
| 4-6        | Block Diagram of P10                       |      |
| 4-7        | Block Diagram of P11 and P14               |      |
| 4-8        | Block Diagram of P12                       |      |
| 4-9        | Block Diagram of P13                       |      |
| 4-10       | Block Diagram of P15                       |      |
| 4-11       | Block Diagram of P16 and P17               |      |
| 4-12       | Block Diagram of P20 to P27                |      |
| 4-13       | Block Diagram of P30 to P32                |      |
| 4-14       | Block Diagram of P33                       |      |
| 4-15       | Block Diagram of P40 to P47                |      |
| 4-16       | Block Diagram of P50 to P57                |      |
| 4-17       | Block Diagram of P60 to P63                |      |
| 4-18       | Block Diagram of P64, P65, and P67         |      |
| 4-19       | Block Diagram of P66                       |      |
| 4-20       | Block Diagram of P70 to P77                |      |
| 4-21       | Block Diagram of P120                      |      |
| 4-22       | Block Diagram of P130                      |      |
| 4-23       | Block Diagram of P140 and P141             |      |
| 4-24       | Block Diagram of P142                      |      |
| 4-25       | Block Diagram of P143                      |      |

# LIST OF FIGURES (1/8)

# LIST OF FIGURES (2/8)

| Figure No. | Title                                                                   | Page |
|------------|-------------------------------------------------------------------------|------|
| 4-26       | Block Diagram of P144 and P145                                          | 115  |
| 4-27       | Format of Port Mode Register                                            |      |
| 4-28       | Format of Pull-up Resistor Option Register                              |      |
| 4-29       | Format of Input Switch Control Register (ISC)                           |      |
| 5-1        | Memory Map When Using External Bus Interface                            |      |
| 5-2        | Format of Memory Expansion Mode Register (MEM)                          |      |
| 5-3        | Format of Memory Expansion Wait Setting Register (MM)                   |      |
| 5-4        | Instruction Fetch from External Memory                                  |      |
| 5-5        | External Memory Read Timing                                             |      |
| 5-6        | External Memory Write Timing                                            |      |
| 5-7        | External Memory Read Modify Write Timing                                |      |
| 5-8        | Connection Example of $\mu$ PD780143 and Memory                         |      |
| 00         |                                                                         |      |
| 6-1        | Block Diagram of Clock Generator                                        | 134  |
| 6-2        | Subsystem Clock Feedback Resistor                                       |      |
| 6-3        | Format of Processor Clock Control Register (PCC)                        |      |
| 6-4        | Format of Ring-OSC Mode Register (RCM)                                  | 137  |
| 6-5        | Format of Main Clock Mode Register (MCM)                                |      |
| 6-6        | Format of Main OSC Control Register (MOC)                               |      |
| 6-7        | Format of Oscillation Stabilization Time Counter Status Register (OSTC) |      |
| 6-8        | Format of Oscillation Stabilization Time Select Register (OSTS)         | 140  |
| 6-9        | External Circuit of X1 Oscillator                                       | 141  |
| 6-10       | External Circuit of Subsystem Clock Oscillator                          | 141  |
| 6-11       | Examples of Incorrect Resonator Connection                              | 142  |
| 6-12       | Timing Diagram of CPU Default Start Using Ring-OSC                      | 145  |
| 6-13       | Status Transition Diagram                                               |      |
| 6-14       | Switching from Ring-OSC Clock to X1 Input Clock                         |      |
| 6-15       | Switching from X1 Input Clock to Ring-OSC Clock (Flowchart)             | 154  |
| 6-16       | Switching from X1 Input Clock to Subsystem Clock (Flowchart)            |      |
| 6-17       | Switching from Subsystem Clock to X1 Input Clock (Flowchart)            | 156  |
| 7-1        | Block Diagram of 16-Bit Timer/Event Counter 00                          | 159  |
| 7-2        | Block Diagram of 16-Bit Timer/Event Counter 01                          |      |
| 7-3        | Format of 16-Bit Timer Mode Control Register 00 (TMC00)                 |      |
| 7-4        | Format of 16-Bit Timer Mode Control Register 01 (TMC01)                 |      |
| 7-5        | Format of Capture/Compare Control Register 00 (CRC00)                   |      |
| 7-6        | Format of Capture/Compare Control Register 01 (CRC01)                   |      |
| 7-7        | Format of 16-Bit Timer Output Control Register 00 (TOC00)               |      |
| 7-8        | Format of 16-Bit Timer Output Control Register 01 (TOC01)               |      |
| 7-9        | Format of Prescaler Mode Register 00 (PRM00)                            |      |
| 7-10       | Format of Prescaler Mode Register 01 (PRM01)                            |      |
| 7-11       | Format of Port Mode Register 0 (PM0)                                    |      |
| 7-12       | Control Register Settings for Interval Timer Operation                  |      |

# LIST OF FIGURES (3/8)

| Figure No.   | Title                                                                                        | Page |
|--------------|----------------------------------------------------------------------------------------------|------|
| 7-13         | Interval Timer Configuration Diagram                                                         | 175  |
| 7-13         | Timing of Interval Timer Operation                                                           |      |
| 7-14         | Control Register Settings for PPG Output Operation                                           |      |
| 7-15         | Configuration of PPG Output                                                                  |      |
| 7-10         | PPG Output Operation Timing                                                                  |      |
| 7-17<br>7-18 | Control Register Settings for Pulse Width Measurement with Free-Running Counter              |      |
| 7 10         | and One Capture Register                                                                     | 178  |
| 7-19         | Configuration Diagram for Pulse Width Measurement with Free-Running Counter                  |      |
| 7-20         | Timing of Pulse Width Measurement Operation with Free-Running Counter                        |      |
| 1 20         | and One Capture Register (with Both Edges Specified)                                         |      |
| 7-21         | Control Register Settings for Measurement of Two Pulse Widths with Free-Running Counter      |      |
| 7-22         | CR01n Capture Operation with Rising Edge Specified                                           |      |
| 7-23         | Timing of Pulse Width Measurement Operation with Free-Running Counter                        |      |
|              | (with Both Edges Specified)                                                                  | 181  |
| 7-24         | Control Register Settings for Pulse Width Measurement with Free-Running Counter and          | -    |
|              | Two Capture Registers                                                                        | 182  |
| 7-25         | Timing of Pulse Width Measurement Operation with Free-Running Counter                        |      |
|              | and Two Capture Registers (with Rising Edge Specified)                                       | 183  |
| 7-26         | Control Register Settings for Pulse Width Measurement by Means of Restart                    |      |
| 7-27         | Timing of Pulse Width Measurement Operation by Means of Restart (with Rising Edge Specified) |      |
| 7-28         | Control Register Settings in External Event Counter Mode                                     |      |
| 7-29         | Configuration Diagram of External Event Counter                                              |      |
| 7-30         | External Event Counter Operation Timing (with Rising Edge Specified)                         |      |
| 7-31         | Control Register Settings in Square-Wave Output Mode                                         |      |
| 7-32         | Square-Wave Output Operation Timing                                                          |      |
| 7-33         | Control Register Settings for One-Shot Pulse Output with Software Trigger                    | 189  |
| 7-34         | Timing of One-Shot Pulse Output Operation with Software Trigger                              | 190  |
| 7-35         | Control Register Settings for One-Shot Pulse Output with External Trigger                    | 191  |
| 7-36         | Timing of One-Shot Pulse Output Operation with External Trigger (with Rising Edge Specified) | 192  |
| 7-37         | Start Timing of 16-Bit Timer Counter 0n (TM0n)                                               | 193  |
| 7-38         | Timings After Change of Compare Register During Timer Count Operation                        | 193  |
| 7-39         | Capture Register Data Retention Timing                                                       | 194  |
| 7-40         | Operation Timing of OVF0n Flag                                                               | 195  |
| 8-1          | Block Diagram of 8-Bit Timer/Event Counter 50                                                | 197  |
| 8-2          | Block Diagram of 8-Bit Timer/Event Counter 51                                                | 198  |
| 8-3          | Format of Timer Clock Selection Register 50 (TCL50)                                          |      |
| 8-4          | Format of Timer Clock Selection Register 51 (TCL51)                                          | 201  |
| 8-5          | Format of 8-Bit Timer Mode Control Register 50 (TMC50)                                       | 202  |
| 8-6          | Format of 8-Bit Timer Mode Control Register 51 (TMC51)                                       | 203  |
| 8-7          | Format of Port Mode Register 1 (PM1)                                                         | 204  |
| 8-8          | Format of Port Mode Register 3 (PM3)                                                         |      |
| 8-9          | Interval Timer Operation Timing                                                              |      |
| 8-10         | External Event Counter Operation Timing (with Rising Edge Specified)                         | 207  |

# LIST OF FIGURES (4/8)

| Figure No. | Title                                                                                   | Page |
|------------|-----------------------------------------------------------------------------------------|------|
|            |                                                                                         |      |
| 8-11       | Square-Wave Output Operation Timing                                                     |      |
| 8-12       | PWM Output Operation Timing                                                             |      |
| 8-13       | Timing of Operation with CR5n Changed.                                                  |      |
| 8-14       | 8-Bit Timer Counter 5n Start Timing                                                     | 212  |
| 9-1        | Block Diagram of 8-Bit Timer H0                                                         | 214  |
| 9-2        | Block Diagram of 8-Bit Timer H1                                                         | 214  |
| 9-3        | Format of 8-Bit Timer H Mode Register 0 (TMHMD0)                                        | 216  |
| 9-4        | Format of 8-Bit Timer H Mode Register 1 (TMHMD1)                                        | 217  |
| 9-5        | Format of 8-Bit Timer H Carrier Control Register 1 (TMCYC1)                             | 218  |
| 9-6        | Register Setting in Interval Timer Mode                                                 | 219  |
| 9-7        | Timing of Interval Timer Operation                                                      |      |
| 9-8        | Register Setting in PWM Pulse Generator Mode                                            | 222  |
| 9-9        | Operation Timing in PWM Pulse Generator Mode                                            |      |
| 9-10       | Example of Connection Between 8-Bit Timer H1 and 8-Bit Timer/Event Counter 51           |      |
| 9-11       | Transfer Timing                                                                         | 229  |
| 9-12       | Register Setting in Carrier Generator Mode                                              | 230  |
| 9-13       | Carrier Generator Mode Operation Timing                                                 |      |
| 10.1       |                                                                                         | 005  |
| 10-1       | Watch Timer Block Diagram                                                               |      |
| 10-2       | Format of Watch Timer Operation Mode Register (WTM)                                     |      |
| 10-3       | Operation Timing of Watch Timer/Interval Timer                                          | 241  |
| 11-1       | Block Diagram of Watchdog Timer                                                         | 244  |
| 11-2       | Format of Watchdog Timer Mode Register (WDTM)                                           | 245  |
| 11-3       | Format of Watchdog Timer Enable Register (WDTE)                                         | 246  |
| 11-4       | Operation in STOP Mode (CPU Clock and WDT Operation Clock: X1 Input Clock)              | 248  |
| 11-5       | Operation in STOP Mode (CPU Clock: X1 Input Clock, WDT Operation Clock: Ring-OSC Clock) | 249  |
| 11-6       | Operation in STOP Mode (CPU Clock: Ring-OSC Clock, WDT Operation Clock: X1 Input Clock) | 250  |
| 11-7       | Operation in STOP Mode (CPU Clock and WDT Operation Clock: Ring-OSC Clock)              | 251  |
| 11-8       | Operation in HALT Mode                                                                  | 251  |
| 12-1       | Block Diagram of Clock Output/Buzzer Output Controller                                  | 252  |
| 12-1       | Format of Clock Output Selection Register (CKS)                                         |      |
| 12-2       | Format of Port Mode Register 14 (PM14)                                                  |      |
| 12-4       | Remote Control Output Application Example                                               |      |
|            |                                                                                         |      |
| 13-1       | Block Diagram of A/D Converter                                                          |      |
| 13-2       | Block Diagram of Power-Fail Detection Function                                          |      |
| 13-3       | Format of A/D Conversion Register (ADCR)                                                |      |
| 13-4       | Format of A/D Converter Mode Register (ADM)                                             |      |
| 13-5       | Timing Chart When Boost Reference Voltage Generator Is Used                             | 262  |
| 13-6       | Format of Analog Input Channel Specification Register (ADS)                             |      |
| 13-7       | Format of Power-Fail Comparison Mode Register (PFM)                                     | 264  |

# LIST OF FIGURES (5/8)

| gure No. | Title                                                                             | Page |
|----------|-----------------------------------------------------------------------------------|------|
| 13-8     | Format of Power-Fail Comparison Threshold Register (PFT)                          | 264  |
| 13-9     | Basic Operation of A/D Converter                                                  |      |
| 13-10    | Relationship Between Analog Input Voltage and A/D Conversion Result               |      |
| 13-11    | A/D Conversion Operation                                                          |      |
| 13-12    | Power-Fail Detection (When PFEN = 1 and PFCM = 0)                                 |      |
| 13-13    | Overall Error                                                                     |      |
| 13-14    | Quantization Error                                                                |      |
| 13-15    | Zero-Scale Error                                                                  |      |
| 13-16    | Full-Scale Error                                                                  |      |
| 13-17    | Integral Linearity Error                                                          |      |
| 13-18    | Differential Linearity Error                                                      |      |
| 13-19    | Example of Method of Reducing Current Consumption in Standby Mode                 |      |
| 13-20    | Storing Conversion Result in ADCR and Timing of Data Read from ADCR               |      |
| 13-21    | Analog Input Pin Connection                                                       |      |
| 13-22    | Timing of A/D Conversion End Interrupt Request Generation                         |      |
| 13-23    | Timing of A/D Converter Sampling and A/D Conversion Start Delay                   |      |
| 10 20    |                                                                                   |      |
| 14-1     | Block Diagram of Serial Interface UART0                                           |      |
| 14-2     | Format of Asynchronous Serial Interface Operation Mode Register 0 (ASIM0)         |      |
| 14-3     | Format of Asynchronous Serial Interface Reception Error Status Register 0 (ASIS0) |      |
| 14-4     | Format of Baud Rate Generator Control Register 0 (BRGC0)                          |      |
| 14-5     | Format of Normal UART Transmit/Receive Data                                       |      |
| 14-6     | Example of Normal UART Transmit/Receive Data Format                               |      |
| 14-7     | Normal Transmission Completion Interrupt Request Timing                           |      |
| 14-8     | Reception Completion Interrupt Request Timing                                     | 293  |
| 14-9     | Noise Filter Circuit                                                              | 294  |
| 14-10    | Configuration of Baud Rate Generator                                              |      |
| 14-11    | Permissible Baud Rate Range During Reception                                      | 299  |
| 15-1     | LIN Transmission Operation                                                        |      |
| 15-2     | LIN Reception Operation                                                           |      |
| 15-3     | Port Configuration for LIN Reception Operation                                    |      |
| 15-4     | Block Diagram of Serial Interface UART6                                           |      |
| 15-5     | Format of Asynchronous Serial Interface Operation Mode Register 6 (ASIM6)         |      |
| 15-6     | Format of Asynchronous Serial Interface Reception Error Status Register 6 (ASIS6) |      |
| 15-7     | Format of Asynchronous Serial Interface Transmission Status Register 6 (ASIF6)    |      |
| 15-8     | Format of Clock Selection Register 6 (CKSR6)                                      |      |
| 15-9     | Format of Baud Rate Generator Control Register 6 (BRGC6)                          |      |
| 15-10    | Format of Asynchronous Serial Interface Control Register 6 (ASICL6)               |      |
| 15-11    | Format of Normal UART Transmit/Receive Data                                       |      |
| 15-12    | Example of Normal UART Transmit/Receive Data Format                               |      |
| 15-13    | Normal Transmission Completion Interrupt Request Timing                           |      |
| 15-14    | Processing Flow of Continuous Transmission                                        |      |
| 15-15    | Timing of Starting Continuous Transmission                                        |      |

# LIST OF FIGURES (6/8)

| Figure No.     | Title                                                                                     | Page |
|----------------|-------------------------------------------------------------------------------------------|------|
| 15-16          | Timing of Ending Continuous Tronomission                                                  | 220  |
| 15-16          | Timing of Ending Continuous Transmission<br>Reception Completion Interrupt Request Timing |      |
| -              |                                                                                           |      |
| 15-18          | Reception Error Interrupt                                                                 |      |
| 15-19          | Noise Filter Circuit                                                                      |      |
| 15-20          | SBF Transmission                                                                          |      |
| 15-21          | SBF Reception                                                                             |      |
| 15-22<br>15-23 | Configuration of Baud Rate Generator<br>Permissible Baud Rate Range During Reception      |      |
|                |                                                                                           |      |
| 15-24          | Transfer Rate During Continuous Transmission                                              |      |
| 16-1           | Block Diagram of Serial Interface CSI10                                                   |      |
| 16-2           | Block Diagram of Serial Interface CSI11 (µPD780146, 780148, and 78F0148 Only)             | 345  |
| 16-3           | Format of Serial Operation Mode Register 10 (CSIM10)                                      |      |
| 16-4           | Format of Serial Operation Mode Register 11 (CSIM11)                                      |      |
| 16-5           | Format of Serial Clock Selection Register 10 (CSIC10)                                     | 350  |
| 16-6           | Format of Serial Clock Selection Register 11 (CSIC11)                                     | 351  |
| 16-7           | Timing in 3-Wire Serial I/O Mode                                                          |      |
| 16-8           | Timing of Clock/Data Phase                                                                |      |
| 16-9           | Output Operation of First Bit                                                             |      |
| 16-10          | Output Value of SO1n Pin (Last Bit)                                                       |      |
|                | Plack Discuss of Cariel Istarface COIAC                                                   | 000  |
| 17-1           | Block Diagram of Serial Interface CSIA0                                                   |      |
| 17-2           | Format of Automatic Data Transfer Address Count Register 0 (ADTC0)                        |      |
| 17-3           | Format of Serial Operation Mode Specification Register 0 (CSIMA0)                         |      |
| 17-4           | Format of Serial Status Register 0 (CSIS0)                                                |      |
| 17-5           | Format of Serial Trigger Register 0 (CSIT0)                                               |      |
| 17-6           | Format of Divisor Selection Register 0 (BRGCA0).                                          |      |
| 17-7           | Format of Automatic Data Transfer Address Point Specification Register 0 (ADTP0)          |      |
| 17-8           | Format of Automatic Data Transfer Interval Specification Register 0 (ADTI0)               |      |
| 17-9           | 3-Wire Serial I/O Mode Timing                                                             |      |
| 17-10          | Format of Transmit/Receive Data                                                           |      |
| 17-11          | Transfer Bit Order Switching Circuit                                                      |      |
| 17-12          | Automatic Transmission/Reception Mode Operation Timings                                   |      |
| 17-13          | Automatic Transmission/Reception Mode Flowchart                                           |      |
| 17-14          | Internal Buffer RAM Operation in 6-Byte Transmission/Reception                            |      |
|                | (in Automatic Transmission/Reception Mode)                                                |      |
| 17-15          | Automatic Transmission Mode Operation Timing                                              |      |
| 17-16          | Automatic Transmission Mode Flowchart                                                     |      |
| 17-17          | Internal Buffer RAM Operation in 6-Byte Transmission (in Automatic Transmission Mode)     |      |
| 17-18          | Repeat Transmission Mode Operation Timing                                                 |      |
| 17-19          | Repeat Transmission Mode Flowchart                                                        | 403  |
| 17-20          | Internal Buffer RAM Operation in 6-Byte Transmission (in Repeat Transmission Mode)        | 404  |
| 17-21          | Format of CSIA0 Transmit/Receive Data                                                     |      |
| 17-22          | Automatic Transmission/Reception Suspension and Restart                                   | 407  |

# LIST OF FIGURES (7/8)

| Figure No.    | Title                                                                                                               | Page |
|---------------|---------------------------------------------------------------------------------------------------------------------|------|
| 17-23         | System Configuration When Busy Control Option Is Used                                                               | 408  |
| 17-24         | Operation Timing When Busy Control Option Is Used (When BUSYLV0 = 1)                                                |      |
| 17-25         | Busy Signal and Wait Release (When BUSYLV0 = 1)                                                                     |      |
| 17-26         | Operation Timing When Busy & Strobe Control Options Are Used (When BUSYLV0 = 1)                                     |      |
| 17-27         | Operation Timing of Bit Shift Detection Function by Busy Signal (When BUSYLV0 = 0)                                  |      |
| 17-28         | Automatic Data Transmit/Receive Interval Time                                                                       |      |
| 18-1          | Block Diagram of Multiplier/Divider                                                                                 | 414  |
| 18-2          | Format of Remainder Data Register 0 (SDR0)                                                                          |      |
| 18-3          | Format of Multiplication/Division Data Register A0 (MDA0H, MDA0L)                                                   |      |
| 18-4          | Format of Multiplication/Division Data Register B0 (MDB0)                                                           |      |
| 18-5          | Format of Multiplier/Divider Control Register 0 (DMUC0)                                                             |      |
| 18-6          | Timing Chart of Multiplication Operation (00DAH × 0093H)                                                            |      |
| 18-7          | Timing Chart When Multiplication Is Executed Successively (00DAH $\times$ 0093H $\rightarrow$ FFFH $\times$ FFFFH). |      |
| 18-8          | Example of Multiplication Operation by Multiplier/Divider (4 Bits × 4 Bits (0111B × 0101B))                         |      |
| 18-9          | Timing Chart of Division Operation (DCBA2586H ÷ 0018H)                                                              |      |
| 18-10         | Timing Chart When Division Is Executed Successively                                                                 |      |
|               | (DCBA2586 ÷ 0018H → FFFFFFFH ÷ FFFFH)                                                                               | 426  |
| 18-11         | Example of Division Operation by Multiplier/Divider (4 Bits ÷ 2 Bits (1001B ÷ 10B))                                 |      |
| 19-1          | Basic Configuration of Interrupt Function                                                                           | 131  |
| 19-1          | Format of Interrupt Request Flag Registers (IF0L, IF0H, IF1L, IF1H)                                                 |      |
| 19-2          | Format of Interrupt Mask Flag Registers (MK0L, MK0H, MK1L, MK1H)                                                    |      |
| 19-3<br>19-4  | Format of Priority Specification Flag Registers (PR0L, PR0H, PR1L, PR1H)                                            |      |
| 19-4          | Format of External Interrupt Rising Edge Enable Register (EGP)                                                      | 400  |
| 19-5          | and External Interrupt Falling Edge Enable Register (EGN)                                                           | 137  |
| 19-6          | Format of Program Status Word                                                                                       |      |
| 19-0<br>19-7  | Interrupt Request Acknowledgement Processing Algorithm                                                              |      |
| 19-7          | Interrupt Request Acknowledgement Timing (Minimum Time)                                                             |      |
| 19-0<br>19-9  | Interrupt Request Acknowledgement Timing (Maximum Time)                                                             |      |
| 19-9<br>19-10 | Examples of Multiple Interrupt Servicing.                                                                           |      |
| 19-10         | Interrupt Request Hold                                                                                              |      |
| 20-1          | Block Diagram of Key Interrupt                                                                                      | 446  |
| 20-2          | Format of Key Return Mode Register (KRM)                                                                            |      |
| 21-1          | Operation Timing When STOP Mode Is Released                                                                         | 449  |
| 21-2          | Format of Oscillation Stabilization Time Counter Status Register (OSTC)                                             |      |
| 21-3          | Format of Oscillation Stabilization Time Select Register (OSTS)                                                     |      |
| 21-4          | HALT Mode Release by Interrupt Request Generation                                                                   |      |
| 21-5          | HALT Mode Release by RESET Input                                                                                    |      |
| 21-6          | STOP Mode Release by Interrupt Request Generation                                                                   |      |
| 21-7          | STOP Mode Release by RESET Input                                                                                    |      |

# LIST OF FIGURES (8/8)

| <u> </u> | Figure No. | Title                                                                                          | Page |
|----------|------------|------------------------------------------------------------------------------------------------|------|
|          | 22-1       | Block Diagram of Reset Function                                                                |      |
|          | 22-2       | Timing of Reset by RESET Input                                                                 |      |
|          | 22-3       | Timing of Reset Due to Watchdog Timer Overflow                                                 |      |
|          | 22-4       | Timing of Reset in STOP Mode by RESET Input.                                                   |      |
|          | 22-5       | Format of Reset Control Flag Register (RESF)                                                   |      |
|          | 23-1       | Block Diagram of Clock Monitor                                                                 | 466  |
|          | 23-2       | Format of Clock Monitor Mode Register (CLM)                                                    | 467  |
|          | 23-3       | Timing of Clock Monitor                                                                        | 469  |
|          | 24-1       | Block Diagram of Power-on-Clear Circuit                                                        | 473  |
|          | 24-2       | Timing of Internal Reset Signal Generation in Power-on-Clear Circuit                           | 473  |
| *        | 24-3       | Example of Software Processing After Release of Reset                                          | 474  |
|          | 25-1       | Block Diagram of Low-Voltage Detector                                                          | 476  |
|          | 25-2       | Format of Low-Voltage Detection Register (LVIM)                                                | 478  |
|          | 25-3       | Format of Low-Voltage Detection Level Selection Register (LVIS)                                | 479  |
|          | 25-4       | Timing of Low-Voltage Detector Internal Reset Signal Generation                                | 481  |
|          | 25-5       | Timing of Low-Voltage Detector Interrupt Signal Generation                                     | 483  |
| *        | 25-6       | Example of Software Processing After Release of Reset                                          | 485  |
| *        | 25-7       | Example of Software Processing of LVI Interrupt                                                | 487  |
|          | 26-1       | Block Diagram of Regulator Periphery                                                           | 488  |
|          | 28-1       | Format of Internal Memory Size Switching Register (IMS)                                        | 491  |
|          | 28-2       | Format of Internal Expansion RAM Size Switching Register (IXS)                                 | 492  |
|          | 28-3       | Communication Mode Selection Format                                                            | 494  |
|          | 28-4       | Connection of Flashpro III in 3-Wire Serial I/O Mode                                           | 495  |
|          | 28-5       | Connection of Flashpro III in 3-Wire Serial I/O Mode (Using Handshake)                         | 495  |
|          | 28-6       | Connection of Flashpro III in UART (UART0) Mode                                                | 496  |
|          | 28-7       | Connection of Flashpro III in UART (UART0) Mode (Using Handshake)                              | 496  |
|          | 28-8       | Connection of Flashpro III in UART (UART6) Mode                                                | 496  |
|          | 28-9       | Example of Wiring Adapter for Flash Memory Writing in 3-Wire Serial I/O Mode                   | 497  |
|          | 28-10      | Example of Wiring Adapter for Flash Memory Writing in 3-Wire Serial I/O Mode (Using Handshake) | 498  |
|          | 28-11      | Example of Wiring Adapter for Flash Memory Writing in UART (UART0) Mode                        | 499  |
|          | 28-12      | Example of Wiring Adapter for Flash Memory Writing in UART (UART0) Mode (Using Handshake)      | 500  |
|          | 28-13      | Example of Wiring Adapter for Flash Memory Writing in UART (UART6) Mode                        | 501  |
|          | A-1        | Development Tool Configuration                                                                 | 544  |

# LIST OF TABLES (1/3)

| Table No. | Title                                                                         | Page |
|-----------|-------------------------------------------------------------------------------|------|
| 1-1       | Flash Memory Versions Corresponding to Mask Options of Mask ROM Versions      | 31   |
| 2-1       | Pin I/O Circuit Types                                                         | 51   |
| 3-1       | Set Values of Internal Memory Size Switching Register (IMS)                   |      |
| 01        | and Internal Expansion RAM Size Switching Register (IXS)                      | 55   |
| 3-2       | Internal Memory Capacity                                                      |      |
| 3-3       | Vector Table                                                                  |      |
| 3-4       | Internal Expansion RAM Capacity                                               |      |
| 3-5       | Special Function Register List                                                |      |
| 4-1       | Port Functions                                                                |      |
| 4-2       | Port Configuration                                                            |      |
| 4-3       | Pull-up Resistor of Port 6                                                    |      |
| 4-4       | Settings of Port Mode Register and Output Latch When Using Alternate Function | 117  |
| 5-1       | Pin Functions in External Memory Expansion Mode                               |      |
| 5-2       | State of Ports 4 to 6 Pins in External Memory Expansion Mode                  | 122  |
| 6-1       | Configuration of Clock Generator                                              | 133  |
| 6-2       | Relationship Between CPU Clock and Minimum Instruction Execution Time         | 137  |
| 6-3       | Relationship Between Operation Clocks in Each Operation Status                |      |
| 6-4       | Oscillation Control Flags and Clock Oscillation Status                        | 150  |
| 6-5       | Time Required to Switch Between Ring-OSC Clock and X1 Input Clock             | 151  |
| 6-6       | Maximum Time Required for CPU Clock Switchover                                | 152  |
| 6-7       | Clock and Register Setting                                                    | 157  |
| 7-1       | Configuration of 16-Bit Timer/Event Counters 00 and 01                        | 159  |
| 7-2       | TI00n Pin Valid Edge and CR00n, CR01n Capture Trigger                         |      |
| 7-3       | TI01n Pin Valid Edge and CR00n Capture Trigger                                | 161  |
| 8-1       | Configuration of 8-Bit Timer/Event Counters 50 and 51                         | 199  |
| 9-1       | Configuration of 8-Bit Timers H0 and H1                                       | 213  |
| 10-1      | Watch Timer Interrupt Time                                                    | 236  |
| 10-2      | Interval Timer Interval Time                                                  | 236  |
| 10-3      | Watch Timer Configuration                                                     | 237  |
| 10-4      | Watch Timer Interrupt Time                                                    | 239  |
| 10-5      | Interval Timer Interval Time                                                  | 240  |
| 11-1      | Loop Detection Time of Watchdog Timer                                         | 242  |
| 11-2      | Mask Option Setting and Watchdog Timer Operation Mode                         | 243  |
| 11-3      | Configuration of Watchdog Timer                                               | 243  |

# LIST OF TABLES (2/3)

| Table No.    | Title                                                                                 | Page |
|--------------|---------------------------------------------------------------------------------------|------|
| 12-1         | Clock Output/Buzzer Output Controller Configuration                                   | 253  |
| 13-1         | Configuration of A/D Converter                                                        | 250  |
| 13-1         | Settings of ADCS and ADCE                                                             |      |
| 13-2         | A/D Converter Sampling Time and A/D Conversion Start Delay Time (ADM Set Value)       |      |
|              |                                                                                       |      |
| 14-1         | Configuration of Serial Interface UART0                                               |      |
| 14-2         | Cause of Reception Error                                                              |      |
| 14-3         | Set Data of Baud Rate Generator                                                       |      |
| 14-4         | Maximum/Minimum Permissible Baud Rate Error                                           |      |
| 15-1         | Configuration of Serial Interface UART6                                               |      |
| 15-2         | Write Processing and Writing to TXB6 During Execution of Continuous Transmission      | 327  |
| 15-3         | Cause of Reception Error                                                              |      |
| 15-4         | Set Data of Baud Rate Generator                                                       | 340  |
| 15-5         | Maximum/Minimum Permissible Baud Rate Error                                           | 342  |
| 16-1         | Configuration of Serial Interfaces CSI10 and CSI11                                    |      |
| 16-2         | SO1n Pin Status                                                                       |      |
| 474          |                                                                                       | 000  |
| 17-1         | Configuration of Serial Interface CSIA0                                               |      |
| 17-2         | Relationship Between Buffer RAM Address Values and ADTP0 Setting Values               | 376  |
| 18-1         | Configuration of Multiplier/Divider                                                   | 413  |
| 18-2         | Functions of MDA0 During Operation Execution                                          | 415  |
| 19-1         | Interrupt Source List                                                                 | 429  |
| 19-2         | Flags Corresponding to Interrupt Request Sources                                      |      |
| 19-3         | Ports Corresponding to EGPn and EGNn                                                  |      |
| 19-4         | Time from Generation of Maskable Interrupt Request Until Servicing                    |      |
| 19-5         | Interrupt Request Enabled for Multiple Interrupt Servicing During Interrupt Servicing |      |
| 20-1         | Assignment of Key Interrupt Detection Pins                                            | 116  |
| 20-1<br>20-2 | Configuration of Key Interrupt                                                        |      |
| 202          |                                                                                       |      |
| 21-1         | Relationship Between HALT Mode, STOP Mode, and Clock                                  | 448  |
| 21-2         | Operating Statuses in HALT Mode                                                       | 452  |
| 21-3         | Operation After HALT Mode Release                                                     | 455  |
| 21-4         | Operating Statuses in STOP Mode                                                       | 456  |
| 21-5         | Operation After STOP Mode Release                                                     | 458  |
| 22-1         | Hardware Statuses After Reset                                                         |      |
| 22-2         | RESF Status When Reset Request Is Generated                                           |      |
| <b>_</b>     |                                                                                       |      |
| 23-1         | Configuration of Clock Monitor                                                        | 466  |

# LIST OF TABLES (3/3)

| Table No. | Title                                                                                       | Page |
|-----------|---------------------------------------------------------------------------------------------|------|
|           |                                                                                             |      |
| 23-2      | Operation Status of Clock Monitor (When CLME = 1)                                           | 468  |
| 27-1      | Flash Memory Versions Supporting Mask Options of Mask ROM Versions                          | 489  |
| 28-1      | Differences Between $\mu$ PD78F0148 and Mask ROM Versions                                   | 490  |
| 28-2      | Internal Memory Size Switching Register Settings                                            | 491  |
| 28-3      | Internal Expansion RAM Size Switching Register Settings                                     | 492  |
| 28-4      | Communication Mode List                                                                     | 493  |
| 28-5      | Main Functions of Flash Memory Programming                                                  | 494  |
| 29-1      | Operand Identifiers and Specification Methods                                               | 502  |
| 32-1      | Registers That Generate Wait and Number of CPU Wait Clocks                                  | 541  |
| 32-2      | Number of Wait Clocks and Number of Execution Clocks on Occurrence of Wait (A/D Converter). | 542  |

#### 1.1 Features

O ROM, RAM capacities

|             | Item | Program      | Memory                | Data M                  | lemory                     |
|-------------|------|--------------|-----------------------|-------------------------|----------------------------|
| Part Number |      | (ROM)        |                       | Internal High-Speed RAM | Internal Expansion RAM     |
| μPD780143   |      | Mask ROM     | 24 KB                 | 1024 bytes              | _                          |
| μPD780144   |      |              | 32 KB                 |                         |                            |
| μPD780146   |      |              | 48 KB                 |                         | 1024 bytes                 |
| μPD780148   |      |              | 60 KB                 |                         |                            |
| μPD78F0148  |      | Flash memory | 60 KB <sup>Note</sup> |                         | 1024 bytes <sup>Note</sup> |

**Note** The internal flash memory and internal expansion RAM capacities can be changed using the internal memory size switching register (IMS) and the internal expansion RAM size switching register (IXS).

- O Buffer RAM: 32 bytes
- O External memory expansion space: 64 KB
- O On-chip power-on-clear (POC) circuit and low-voltage detector (LVI)
- O Short startup is possible via the CPU default start using the on-chip Ring-OSC
- O On-chip clock monitor function using on-chip Ring-OSC
- O On-chip watchdog timer (operable with Ring-OSC clock)
- O On-chip UART supporting LIN (Local Interconnect Network) bus
- O On-chip multiplier/divider
- O On-chip key interrupt function
- O On-chip external bus interface function
- O On-chip clock output/buzzer output controller
- O On-chip regulator
- O Minimum instruction execution time can be changed from high speed (0.2  $\mu$ s: @ 10 MHz operation with X1 input clock) to ultra low-speed (122  $\mu$ s: @ 32.768 kHz operation with subsystem clock)
- O I/O ports: 67 (N-ch open drain: 4)
- O Timer
  - μPD780143, 780144: 7 channels

µPD780146, 780148, 78F0148: 8 channels

- O Serial interface
  - µPD780143, 780144: 3 channels

(UART: 1 channel, CSI/UART<sup>Note</sup>: 1 channel, CSI with automatic transmit/receive function: 1 channel)

μPD780146, 780148, 78F0148: 4 channels

(UART: 1 channel, CSI: 1 channel, CSI/UART<sup>Note</sup>: 1 channel, CSI with automatic transmit/receive function: 1 channel)

- O 10-bit resolution A/D converter: 8 channels
- O Supply voltage:  $V_{DD} = 2.7$  to 5.5 V
- $\star$  **Note** Select either of the functions of these alternate-function pins.

#### **1.2 Applications**

- O Automotive equipment
  - System control for body electricals (power windows, keyless entry reception, etc.)
  - Sub-microcontrollers for control
- O Home audio, car audio
- O AV equipment
- O PC peripheral equipment (keyboards, etc.)
- O Household electrical appliances
  - Outdoor air conditioner units
  - Microwave ovens, electric rice cookers
- O Industrial equipment
  - Pumps
  - Vending machines
  - FA

#### 1.3 Ordering Information

#### (1) Mask ROM version

| Part Number             | Package                                          |
|-------------------------|--------------------------------------------------|
| μPD780143GK-×××-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780143GC-×××-8BT     | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780144GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780144GC-×××-8BT     | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780146GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780146GC-×××-8BT     | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780148GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780148GC-xxx-8BT     | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780143GK(A)-xxx-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780143GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780144GK(A)-xxx-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780144GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780146GK(A)-xxx-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780146GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780148GK(A)-xxx-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780148GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780143GK(A1)-xxx-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780143GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780144GK(A1)-xxx-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780144GC(A1)-xxx-8BT | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780146GK(A1)-xxx-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780146GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)               |
| μPD780148GK(A1)-xxx-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12) |
| μPD780148GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)               |
|                         |                                                  |

**Remark** ××× indicates ROM code suffix.

#### (2) Flash memory

| Part Number                | Package                                           |
|----------------------------|---------------------------------------------------|
| μPD78F0148M1GK-9EU         | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) |
| μPD78F0148M1GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M2GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M2GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M3GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M3GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M4GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M4GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M5GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) |
| $\mu$ PD78F0148M5GC-8BT    | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M6GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M6GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M1GK(A)-9EU | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) |
| μPD78F0148M1GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M2GK(A)-9EU | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) |
| μPD78F0148M2GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
| μPD78F0148M3GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M3GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
| $\mu$ PD78F0148M4GK(A)-9EU | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) |
| μPD78F0148M4GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
| μPD78F0148M5GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| µPD78F0148M5GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
| μPD78F0148M6GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  |
| μPD78F0148M6GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                |
|                            |                                                   |

Mask ROM versions ( $\mu$ PD780143, 780144, 780146, and 780148) include mask options. When ordering, it is possible to select "Power-on-clear (POC) circuit can be used/cannot be used", "Ring-OSC clock can be stopped/cannot be stopped by software" and "Pull-up resistor incorporated/not incorporated in 1-bit units (P60 to P63)".

Flash memory versions corresponding to the mask options of the mask ROM versions are as follows.

| Mas                                               | Flash Memory Versions      |                                                                                            |
|---------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------|
| POC Circuit                                       | Ring-OSC                   | (Part Number)                                                                              |
| POC cannot be used                                | Cannot be stopped          | μPD78F0148M1GK-9EU<br>μPD78F0148M1GC-8BT<br>μPD78F0148M1GK(A)-9EU<br>μPD78F0148M1GC(A)-8BT |
|                                                   | Can be stopped by software | μPD78F0148M2GK-9EU<br>μPD78F0148M2GC-8BT<br>μPD78F0148M2GK(A)-9EU<br>μPD78F0148M2GC(A)-8BT |
| POC used (V <sub>POC</sub> = 2.85 V $\pm 0.15$ V) | Cannot be stopped          | μPD78F0148M3GK-9EU<br>μPD78F0148M3GC-8BT<br>μPD78F0148M3GK(A)-9EU<br>μPD78F0148M3GC(A)-8BT |
|                                                   | Can be stopped by software | μPD78F0148M4GK-9EU<br>μPD78F0148M4GC-8BT<br>μPD78F0148M4GK(A)-9EU<br>μPD78F0148M4GC(A)-8BT |
| POC used (V <sub>POC</sub> = 3.5 V $\pm$ 0.2 V)   | Cannot be stopped          | μPD78F0148M5GK-9EU<br>μPD78F0148M5GC-8BT<br>μPD78F0148M5GK(A)-9EU<br>μPD78F0148M5GC(A)-8BT |
|                                                   | Can be stopped by software | μPD78F0148M6GK-9EU<br>μPD78F0148M6GC-8BT<br>μPD78F0148M6GK(A)-9EU<br>μPD78F0148M6GC(A)-8BT |

Table 1-1. Flash Memory Versions Corresponding to Mask Options of Mask ROM Versions

#### 1.4 Quality Grade

#### (1) Mask ROM version

| Part Number             | Package                                           | Quality Grade |
|-------------------------|---------------------------------------------------|---------------|
| μPD780143GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) | Standard      |
| μPD780143GC-×××-8BT     | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| μPD780144GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| μPD780144GC-×××-8BT     | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| μPD780146GK-xxx-9EU     | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) | Standard      |
| μPD780146GC-×××-8BT     | 80-pin plastic QFP (14 $\times$ 14)               | Standard      |
| μPD780148GK-×××-9EU     | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| μPD780148GC-×××-8BT     | 80-pin plastic QFP (14 $\times$ 14)               | Standard      |
| μPD780143GK(A)-×××-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780143GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780144GK(A)-×××-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780144GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780146GK(A)-×××-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780146GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780148GK(A)-×××-9EU  | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780148GC(A)-×××-8BT  | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780143GK(A1)-×××-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780143GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780144GK(A1)-×××-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780144GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780146GK(A1)-×××-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780146GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD780148GK(A1)-×××-9EU | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD780148GC(A1)-×××-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |

**Remark** ××× indicates ROM code suffix.

Please refer to "Quality Grades on NEC Semiconductor Devices" (Document No. C11531E) published by NEC Corporation to know the specification of quality grade on the devices and its recommended applications.

#### (2) Flash memory version

| Part Number                | Package                                           | Quality Grade |
|----------------------------|---------------------------------------------------|---------------|
| μPD78F0148M1GK-9EU         | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| μPD78F0148M1GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| $\mu$ PD78F0148M2GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| μPD78F0148M2GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| $\mu$ PD78F0148M3GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| μPD78F0148M3GC-8BT         | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| $\mu$ PD78F0148M4GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| $\mu$ PD78F0148M4GC-8BT    | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| $\mu$ PD78F0148M5GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| $\mu$ PD78F0148M5GC-8BT    | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| $\mu$ PD78F0148M6GK-9EU    | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Standard      |
| $\mu$ PD78F0148M6GC-8BT    | 80-pin plastic QFP (14 $	imes$ 14)                | Standard      |
| μPD78F0148M1GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD78F0148M1GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD78F0148M2GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| μPD78F0148M2GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD78F0148M3GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $	imes$ 12)  | Special       |
| $\mu$ PD78F0148M3GC(A)-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD78F0148M4GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) | Special       |
| μPD78F0148M4GC(A)-8BT      | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| μPD78F0148M5GK(A)-9EU      | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) | Special       |
| $\mu$ PD78F0148M5GC(A)-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |
| $\mu$ PD78F0148M6GK(A)-9EU | 80-pin plastic TQFP (fine pitch) (12 $\times$ 12) | Special       |
| $\mu$ PD78F0148M6GC(A)-8BT | 80-pin plastic QFP (14 $	imes$ 14)                | Special       |

Please refer to "Quality Grades on NEC Semiconductor Devices" (Document No. C11531E) published by NEC Corporation to know the specification of quality grade on the devices and its recommended applications.

#### 1.5 Pin Configuration (Top View)

80-pin plastic TQFP (fine pitch) (12 × 12)
 μPD780143GK-xxx-9EU, 780144GK-xxx-9EU, 780146GK-xxx-9EU, 780148GK-xxx-9EU,
 μPD780143GK(A)-xxx-9EU, 780144GK(A)-xxx-9EU, 780146GK(A)-xxx-9EU,
 μPD780148GK(A)-xxx-9EU, 780143GK(A1)-xxx-9EU, 780144GK(A1)-xxx-9EU,
 μPD780146GK(A1)-xxx-9EU, 780148GK(A1)-xxx-9EU,
 μPD780146GK(A1)-xxx-9EU, 780148GK(A1)-xxx-9EU,
 μPD780146GK(A1)-xxx-9EU, 780148GK(A1)-xxx-9EU,
 μPD780146GK(A1)-xxx-9EU, 780148GK(A1)-xxx-9EU,
 μPD780146GK(A1)-xxx-9EU, 780148GK(A1)-xxx-9EU,
 μPD78F0148M1GK-9EU, 78F0148M2GK-9EU, 78F0148M3GK-9EU, 78F0148M4GK-9EU,
 μPD78F0148M3GK(A)-9EU, 78F0148M4GK(A)-9EU, 78F0148M5GK(A)-9EU,
 μPD78F0148M3GK(A)-9EU, 78F0148M4GK(A)-9EU, 78F0148M5GK(A)-9EU,
 μPD78F0148M3GK(A)-9EU, 78F0148M4GK(A)-9EU, 78F0148M5GK(A)-9EU,
 μPD78F0148M3GK(A)-9EU, 78F0148M4GK(A)-9EU, 78F0148M5GK(A)-9EU,
 μPD78F0148M3GK(A)-9EU, 78F0148M4GK(A)-9EU,
 μPD78F0148M3GK(A)-9EU,
 γ8F0148M4GK(A)-9EU,
 γ8F0148M6GK(A)-9EU,
 γ8F0148M6GK(A)-9EU
 γ

µPD78F0148M3GC(A)-8BT, 78F0148M4GC(A)-8BT, 78F0148M5GC(A)-8BT, 78F0148M6GC(A)-8BT

 80-pin plastic QFP (14 × 14)
 μPD780143GC-xxx-8BT, 780144GC-xxx-8BT, 780146GC-xxx-8BT, 780148GC-xxx-8BT,
 μPD780143GC(A)-xxx-8BT, 780144GC(A)-xxx-8BT, 780146GC(A)-xxx-8BT,
 μPD780148GC(A)-xxx-8BT, 780143GC(A1)-xxx-8BT, 780144GC(A1)-xxx-8BT,
 μPD780146GC(A1)-xxx-8BT, 780148GC(A1)-xxx-8BT,
 μPD78F0148M1GC-8BT, 78F0148M2GC-8BT, 78F0148M3GC-8BT, 78F0148M4GC-8BT,
 μPD78F0148M5GC-8BT, 78F0148M6GC-8BT, 78F0148M1GC(A)-8BT, 78F0148M2GC(A)-8BT,



**Note** SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

Cautions 1. Connect the IC (Internally Connected) pin directly to Vss.

- 2. Connect the AVREF pin to VDD.
- 3. Connect the AVss pin to Vss.
- 4. When using the regulator, connect the REGC pin to Vss via 0.1  $\mu$ F capacitor. When the regulator is not used, connect the REGC pin directly to VDD.

**Remark** Figures in parentheses apply only to the  $\mu$ PD78F0148.

#### **Pin Identification**

| A8 to A15:      | Address bus               | REGC:                                           | Regulator capacitance              |
|-----------------|---------------------------|-------------------------------------------------|------------------------------------|
| AD0 to AD7:     | Address/data bus          | RESET:                                          | Reset                              |
| ANI0 to ANI7:   | Analog input              | RxD0, RxD6:                                     | Receive data                       |
| ASTB:           | Address strobe            | RD:                                             | Read strobe                        |
| AVREF:          | Analog reference voltage  | SCK10, SCK11 <sup>Note</sup> ,                  |                                    |
| AVss:           | Analog ground             | SCKA0:                                          | Serial clock input/output          |
| BUSY0:          | Serial busy input         | SI10, SI11 <sup>Note</sup> , SIA0:              | Serial data input                  |
| BUZ:            | Buzzer output             | SO10, SO11 <sup>Note</sup> ,                    |                                    |
| EVDD:           | Power supply for port     | SOA1:                                           | Serial data output                 |
| EVss:           | Ground for port           | SSI11 <sup>Note</sup> :                         | Serial interface chip select input |
| IC:             | Internally connected      | STB0:                                           | Serial strobe                      |
| INTP0 to INTP7: | External interrupt input  | TI000, TI010,                                   |                                    |
| KR0 to KR7:     | Key return                | TI001 <sup>Note</sup> , TI011 <sup>Note</sup> , |                                    |
| P00 to P06:     | Port 0                    | TI50, TI51:                                     | Timer input                        |
| P10 to P17:     | Port 1                    | TO00, TO01 <sup>Note</sup> ,                    |                                    |
| P20 to P27:     | Port 2                    | TO50, TO51,                                     |                                    |
| P30 to P33:     | Port 3                    | TOH0, TOH1:                                     | Timer output                       |
| P40 to P47:     | Port 4                    | TxD0, TxD6:                                     | Transmit data                      |
| P50 to P57:     | Port 5                    | VDD:                                            | Power supply                       |
| P60 to P67:     | Port 6                    | VPP:                                            | Programming power supply           |
| P70 to P77:     | Port 7                    | Vss:                                            | Ground                             |
| P120:           | Port 12                   | WAIT:                                           | Wait                               |
| P130:           | Port 13                   | WR:                                             | Write strobe                       |
| P140 to P145:   | Port 14                   | X1, X2:                                         | Crystal (X1 input clock)           |
| PCL:            | Programmable clock output | XT1, XT2:                                       | Crystal (Subsystem clock)          |

**Note** SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the *μ*PD780146, 780148, and 78F0148.

# 1.6 78K0/Kxx Series Lineup

The lineup of products in the 78K0/Kxx Series (under development or in planning) is shown below.

78K0/KB1 Series: 30-pin (7.62 mm 0.65 mm pitch)



78K0/KC1 Series: 44-pin (10 × 10 mm 0.8 mm pitch)



78K0/KD1 Series: 52-pin (10 × 10 mm 0.65 mm pitch)



<u>78K0/KE1 Series: 64-pin (10  $\times$  10 mm 0.5 mm pitch, 12  $\times$  12 mm 0.65 mm pitch, 14  $\times$  14 mm 0.8 mm pitch)</u>



78K0/KF1 Series: 80-pin (12 × 12 mm 0.5 mm pitch, 14 × 14 mm 0.65 mm pitch)



## 1.7 Block Diagram





**Remark** Items in parentheses are available only in the  $\mu$ PD78F0148.

# 1.8 Outline of Functions

| It                                         | em                   | μPD780143                                                                                                                                                                             | μPD780144           | μPD780146                       | μPD780148                      | μPD78F0148                            |  |
|--------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------------|--------------------------------|---------------------------------------|--|
| Internal memory                            | ROM                  | 24 KB                                                                                                                                                                                 | 32 KB               | 48 KB                           | 60 KB                          | 60 KB <sup>№te</sup><br>(flash memory |  |
|                                            | High-speed RAM       | 1 KB                                                                                                                                                                                  | ·                   |                                 | ÷                              |                                       |  |
|                                            | Expansion RAM        |                                                                                                                                                                                       | -                   | 1 KB                            |                                | 1 KB <sup>Note</sup>                  |  |
|                                            | Buffer RAM           | 32 bytes                                                                                                                                                                              |                     |                                 |                                |                                       |  |
| Memory space                               |                      | 64 KB                                                                                                                                                                                 |                     |                                 |                                |                                       |  |
| X1 input clock (os                         | cillation frequency) | Ceramic/crystal/                                                                                                                                                                      | external clock osc  | llation                         |                                |                                       |  |
| REGC pin is di<br>V <sub>DD</sub>          | rectly connected to  | 10 MHz: V <sub>DD</sub> = 4                                                                                                                                                           | .0 to 5.5 V, 8.38 M | IHz: V <sub>DD</sub> = 3.3 to 5 | .5 V, 5 MHz: V <sub>DD</sub> = | = 2.7 to 5.5 V                        |  |
| 0.1 $\mu$ F capacito<br>REGC pin           | or is connected to   | 8.38 MHz: Vdd =                                                                                                                                                                       | = 3.3 to 5.5 V, 5 M | Hz: V <sub>DD</sub> = 2.7 to 5. | 5 V                            |                                       |  |
| Ring-OSC clock<br>(oscillation frequer     | ncy)                 | On-chip Ring os                                                                                                                                                                       | cillation (240 kHz  | (TYP.))                         |                                |                                       |  |
| Subsystem clock<br>(oscillation frequency) |                      | Crystal/external clock oscillation (32.768 kHz)                                                                                                                                       |                     |                                 |                                |                                       |  |
| General-purpose r                          | egisters             | 8 bits $\times$ 32 registers (8 bits $\times$ 8 registers $\times$ 4 banks)                                                                                                           |                     |                                 |                                |                                       |  |
| Minimum instruction                        | on execution time    | 0.2 μs/0.4 μs/0.8 μs/1.6 μs/3.2 μs (X1 input clock: @ fxP = 10 MHz operation)                                                                                                         |                     |                                 |                                |                                       |  |
|                                            |                      | 8.3 $\mu$ s/16.6 $\mu$ s/33.2 $\mu$ s/66.4 $\mu$ s/132.8 $\mu$ s (TYP.) (Ring-OSC clock: @ f <sub>R</sub> = 240 kHz (TYP.) operation)                                                 |                     |                                 |                                |                                       |  |
|                                            |                      | 122 μs (subsystem clock: @ fxτ = 32.768 kHz operation)                                                                                                                                |                     |                                 |                                |                                       |  |
| Instruction set                            |                      | <ul> <li>16-bit operation</li> <li>Multiply/divide (8 bits × 8 bits × 4 banks)</li> <li>Bit manipulate (set, reset, test, and Boolean operation)</li> <li>BCD adjust, etc.</li> </ul> |                     |                                 |                                |                                       |  |
| I/O ports                                  |                      | Total:                                                                                                                                                                                | 67                  |                                 |                                |                                       |  |
|                                            |                      | CMOS I/O                                                                                                                                                                              | 54                  |                                 |                                |                                       |  |
|                                            |                      | CMOS input                                                                                                                                                                            | 8                   |                                 |                                |                                       |  |
|                                            |                      | CMOS output                                                                                                                                                                           | 1                   |                                 |                                |                                       |  |
|                                            |                      | N-ch open-drain                                                                                                                                                                       | · · ·               |                                 |                                |                                       |  |
| Timers                                     |                      | • 16-bit timer/event counter: 2 channels (1 channel only in the µPD780143, 780144)                                                                                                    |                     |                                 |                                |                                       |  |
|                                            |                      | 8-bit timer/event counter: 2 channels     8-bit timer: 2 channels                                                                                                                     |                     |                                 |                                |                                       |  |
|                                            |                      | 8-bit timer: 2 channels     Watch timer 1 channel                                                                                                                                     |                     |                                 |                                |                                       |  |
|                                            |                      | Watchdog timer: 1 channel                                                                                                                                                             |                     |                                 |                                |                                       |  |
| Timer outputs                              |                      | 5 (PWM output: 3) 6 (PWM output: 3)                                                                                                                                                   |                     |                                 |                                |                                       |  |
| Clock output                               |                      | <ul> <li>78.125 kHz, 156.25 kHz, 312.5 kHz, 625 kHz, 1.25 MHz, 2.5 MHz, 5 MHz, 10 MHz (X1 input clock: 10 MHz)</li> <li>32.768 kHz (subsystem clock: 32.768 kHz)</li> </ul>           |                     |                                 |                                |                                       |  |
| Buzzer output                              |                      | 1.22 kHz, 2.44 kHz, 4.88 kHz, 9.77 kHz (X1 input clock: 10 MHz)                                                                                                                       |                     |                                 |                                |                                       |  |
| A/D converter                              |                      | 10-bit resolution × 8 channels                                                                                                                                                        |                     |                                 |                                |                                       |  |
|                                            |                      |                                                                                                                                                                                       |                     |                                 |                                |                                       |  |

**Note** The internal flash memory capacity and internal expansion RAM capacity can be changed using the internal memory size switching register (IMS) and the internal expansion RAM size switching register (IXS).

|                               |          |                                                                                        |                                              |           |                             | (2/2)      |  |
|-------------------------------|----------|----------------------------------------------------------------------------------------|----------------------------------------------|-----------|-----------------------------|------------|--|
| Item                          |          | μPD780143                                                                              | μPD780144                                    | μPD780146 | μPD780148                   | μPD78F0148 |  |
| Serial interface              |          | • UART mode su                                                                         | UART mode supporting LIN-bus: 1 channel      |           |                             | nnel       |  |
|                               |          | 3-wire serial I/C                                                                      |                                              |           | 1 cha                       | nnel       |  |
|                               |          | `                                                                                      | the $\mu$ PD780143, 7                        | ,         |                             |            |  |
|                               |          |                                                                                        | D mode with autom D mode/UART mode           |           | ve function: 1 cha<br>1 cha | -          |  |
| Multiplier/divider            |          |                                                                                        | s = 32 bits (multipl                         |           | 1 0114                      |            |  |
| Multiplier/divider            |          |                                                                                        | s = 32 bits (multiple)<br>s = 32 bits remain | ,         | sion)                       |            |  |
| Vectored interrupt            | Internal | 17 20                                                                                  |                                              |           |                             |            |  |
| sources External 9            |          |                                                                                        |                                              |           |                             |            |  |
| Key interrupt                 |          | Key interrupt (INTKR) occurs by detecting falling edge of key input pins (KR0 to KR7). |                                              |           |                             |            |  |
| Reset                         |          | Reset using RESET pin                                                                  |                                              |           |                             |            |  |
|                               |          | Internal reset by watchdog timer                                                       |                                              |           |                             |            |  |
|                               |          | Internal reset by clock monitor                                                        |                                              |           |                             |            |  |
|                               |          | Internal reset by power-on-reset                                                       |                                              |           |                             |            |  |
|                               |          | Internal reset by low-voltage detector                                                 |                                              |           |                             |            |  |
| Supply voltage                |          | V <sub>DD</sub> = 2.7 to 5.5 V                                                         |                                              |           |                             |            |  |
| Operating ambient temperature |          | Standard products, (A) products: $T_A = -40$ to $+85^{\circ}C$                         |                                              |           |                             |            |  |
|                               |          | (A1) products: $T_A = -40$ to +110°C (µPD780143, 780144, 780146, and 780148 only)      |                                              |           |                             |            |  |
| Package                       |          | • 80-pin plastic QFP (14 × 14)                                                         |                                              |           |                             |            |  |
|                               |          | • 80-pin plastic TQFP (fine pitch) ( $12 \times 12$ )                                  |                                              |           |                             |            |  |

**\* Note** Select either of the functions of these alternate-function pins.

An outline of the timer is shown below.

|           |                         | 16-Bit Timer/<br>Event Counters<br>00 and 01 <sup>Note 1</sup> | 8-Bit Timer/<br>Event Counters<br>50 and 51 | 8-Bit Timers H0<br>and H1 | Watch Timer                 | Watchdog Timer |
|-----------|-------------------------|----------------------------------------------------------------|---------------------------------------------|---------------------------|-----------------------------|----------------|
| Operation | Interval timer          | 2 channels                                                     | 2 channels                                  | 2 channels                | 1 channel <sup>Note 2</sup> | 1 channel      |
| mode      | External event counter  | 2 channels                                                     | 2 channels                                  | -                         | -                           | -              |
| Function  | Timer output            | 2 outputs                                                      | 2 outputs                                   | 2 outputs                 | -                           | -              |
|           | PPG output              | 2 outputs                                                      | _                                           | _                         | _                           | _              |
|           | PWM output              | _                                                              | 2 outputs                                   | 2 outputs                 | _                           | -              |
|           | Pulse width measurement | 4 inputs                                                       | _                                           | -                         | _                           | -              |
|           | Square-wave output      | 2 outputs                                                      | 2 outputs                                   | _                         | _                           | _              |
|           | Interrupt source        | 4                                                              | 2                                           | 2                         | 1                           | _              |

**Notes 1.** 16-bit timer/event counter 01 is available only in the  $\mu$ PD780146, 780148, and 78F0148.

2. In the watch timer, the watch timer function and interval timer function can be used simultaneously.

# **CHAPTER 2 PIN FUNCTIONS**

# 2.1 Pin Function List

# (1) Port pins (1/2)

| Pin Name   | I/O   | Function                                                                                                                                                     | After Reset | Alternate Function                           |
|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------|
| P00        | I/O   | Port 0.                                                                                                                                                      | Input       | TI000                                        |
| P01        |       | 7-bit I/O port.                                                                                                                                              |             | TI010/TO00                                   |
| P02        |       | Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a                                                    |             | SO11 <sup>Note</sup>                         |
| P03        |       | software setting.                                                                                                                                            |             | SI11 <sup>Note</sup>                         |
| P04        |       |                                                                                                                                                              |             | SCK11 <sup>Note</sup>                        |
| P05        |       |                                                                                                                                                              |             | SSI11 <sup>Note</sup> /TI001 <sup>Note</sup> |
| P06        |       |                                                                                                                                                              |             | TI011 <sup>Note</sup> /TO01 <sup>Note</sup>  |
| P10        | I/O   | Port 1.                                                                                                                                                      | Input       | SCK10/TxD0                                   |
| P11        |       | 8-bit I/O port.                                                                                                                                              |             | SI10/RxD0                                    |
| P12        |       | Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a                                                    |             | SO10                                         |
| P13        |       | software setting.                                                                                                                                            |             | TxD6                                         |
| P14        |       |                                                                                                                                                              |             | RxD6                                         |
| P15        |       |                                                                                                                                                              |             | ТОН0                                         |
| P16        |       |                                                                                                                                                              |             | TOH1/INTP5                                   |
| P17        |       |                                                                                                                                                              |             | TI50/TO50                                    |
| P20 to P27 | Input | Port 2.<br>8-bit input-only port.                                                                                                                            | Input       | ANI0 to ANI7                                 |
| P30 to P32 | I/O   | Port 3.<br>4-bit I/O port.<br>Input/output can be specified in 1-bit units.                                                                                  | Input       | INTP1 to INTP3                               |
| P33        |       | Use of an on-chip pull-up resistor can be specified by a software setting.                                                                                   |             | INTP4/TI51/TO51                              |
| P40 to P47 | I/O   | Port 4.<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting. | Input       | AD0 to AD7                                   |
| P50 to P57 | I/O   | Port 5.<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting. | Input       | A8 to A15                                    |

Note SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the μPD780146, 780148, and 78F0148.

# (1) Port pins (2/2)

| Pin Name   | I/O    | Fun                                                                                                                    | iction                                                                                                                                 | After Reset | Alternate Function  |
|------------|--------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|
| P60 to P63 | I/O    | Port 6.<br>8-bit I/O port.<br>Input/output can be specified<br>in 1-bit units.                                         | N-ch open-drain I/O port.<br>Use of an on-chip pull-up<br>resistor can be specified by a<br>mask option only for mask<br>ROM versions. | Input       | _                   |
| P64        |        |                                                                                                                        | Use of an on-chip pull-up                                                                                                              |             | RD                  |
| P65        |        |                                                                                                                        | resistor can be specified by a software setting.                                                                                       |             | WR                  |
| P66        |        |                                                                                                                        | sonware setting.                                                                                                                       |             | WAIT                |
| P67        |        |                                                                                                                        |                                                                                                                                        |             | ASTB                |
| P70 to P77 | I/O    | Port 7.<br>8-bit I/O port.<br>Input/output can be specified in<br>Use of an on-chip pull-up resis<br>software setting. |                                                                                                                                        | Input       | KR0 to KR7          |
| P120       | I/O    | Port 12.<br>1-bit I/O port.<br>Use of an on-chip pull-up resis<br>software setting.                                    | Port 12.<br>1-bit I/O port.<br>Use of an on-chip pull-up resistor can be specified by a                                                |             |                     |
| P130       | Output | Port 13.<br>1-bit output-only port.                                                                                    | Port 13.                                                                                                                               |             | -                   |
| P140       | I/O    | Port 14.                                                                                                               |                                                                                                                                        | Input       | PCL/INTP6           |
| P141       |        | 6-bit I/O port.<br>Input/output can be specified in                                                                    |                                                                                                                                        |             | BUZ/BUSY0/<br>INTP7 |
| P142       |        | Use of an on-chip pull-up resis software setting.                                                                      | tor can be specified by a                                                                                                              |             | SCKA0               |
| P143       |        | contraro conting.                                                                                                      |                                                                                                                                        |             | SIA0                |
| P144       |        |                                                                                                                        |                                                                                                                                        |             | SOA0                |
| P145       |        |                                                                                                                        |                                                                                                                                        |             | STB0                |

# (2) Non-port pins (1/2)

| Pin Name              | I/O    | Function                                                                                                                                                     | After Reset | Alternate Function        |
|-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------|
| INTP0                 | Input  | External interrupt request input for which the valid edge (rising                                                                                            | Input       | P120                      |
| INTP1 to INTP3        |        | edge, falling edge, or both rising and falling edges) can be                                                                                                 |             | P30 to P32                |
| INTP4                 |        | specified                                                                                                                                                    |             | P33/TI51/TO51             |
| INTP5                 |        |                                                                                                                                                              |             | P16/TOH1                  |
| INTP6                 |        |                                                                                                                                                              |             | P140/PCL                  |
| INTP7                 |        |                                                                                                                                                              |             | P141/BUZ/BUSY0            |
| SI10                  | Input  | Serial data input to serial interface                                                                                                                        | Input       | P11/RxD0                  |
| SI11 <sup>Note</sup>  |        |                                                                                                                                                              |             | P03                       |
| SIA0                  |        |                                                                                                                                                              |             | P143                      |
| SO10                  | Output | Serial data output from serial interface                                                                                                                     | Input       | P12                       |
| SO11 <sup>Note</sup>  |        |                                                                                                                                                              |             | P02                       |
| SOA0                  |        |                                                                                                                                                              |             | P144                      |
| SCK10                 | I/O    | Clock input/output for serial interface                                                                                                                      | Input       | P10/TxD0                  |
| SCK11 <sup>Note</sup> |        |                                                                                                                                                              |             | P04                       |
| SCKA0                 |        |                                                                                                                                                              |             | P142                      |
| SSI11 <sup>Note</sup> | Input  | Serial interface chip select input                                                                                                                           | Input       | P05/TI001                 |
| BUSY0                 | Input  | Serial interface busy input                                                                                                                                  | Input       | P141/BUZ/INTP7            |
| STB0                  | Output | Serial interface strobe output                                                                                                                               | Input       | P145                      |
| RxD0                  | Input  | Serial data input to asynchronous serial interface                                                                                                           | Input       | P11/SI10                  |
| RxD6                  | 1      |                                                                                                                                                              |             | P14                       |
| TxD0                  | Output | Serial data output from asynchronous serial interface                                                                                                        | Input       | P10/SCK10                 |
| TxD6                  | -      |                                                                                                                                                              |             | P13                       |
| TI000                 | Input  | External count clock input to 16-bit timer/event counter 00<br>Capture trigger input to capture registers (CR000, CR010) of<br>16-bit timer/event counter 00 | Input       | P00                       |
| TI001 <sup>Note</sup> |        | External count clock input to 16-bit timer/event counter 01<br>Capture trigger input to capture registers (CR001, CR011) of<br>16-bit timer/event counter 01 |             | P05/SSI11 <sup>Note</sup> |
| TI010                 |        | Capture trigger input to capture register (CR000) of 16-bit timer/event counter 00                                                                           |             | P01/TO00                  |
| TI011 <sup>Note</sup> |        | Capture trigger input to capture register (CR001) of 16-bit timer/event counter 01                                                                           |             | P06/TO01 <sup>Note</sup>  |
| TO00                  | Output | 16-bit timer/event counter 00 output                                                                                                                         | Input       | P01/TI010                 |
| TO01 <sup>Note</sup>  | 1      | 16-bit timer/event counter 01 output                                                                                                                         | ]           | P06/TI011 <sup>Note</sup> |
| TI50                  | Input  | External count clock input to 8-bit timer/event counter 50                                                                                                   | Input       | P17/TO50                  |
| TI51                  | 1      | External count clock input to 8-bit timer/event counter 51                                                                                                   | 1           | P33/TO51/INTP4            |
| TO50                  | Output | 8-bit timer/event counter 50 output                                                                                                                          | Input       | P17/TI50                  |
| TO51                  | 1      | 8-bit timer/event counter 51 output                                                                                                                          | 1           | P33/TI51/INTP4            |
|                       | 1      | 8-bit timer H0 output                                                                                                                                        | 1           | P15                       |
| TOH0                  |        |                                                                                                                                                              |             | 1 10                      |

Note SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

# (2) Non-port pins (2/2)

| Pin Name     | I/O    | Function                                                                                                                                            | After Reset | Alternate Function |
|--------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| PCL          | Output | Clock output (for trimming of X1 input clock, subsystem clock)                                                                                      | Input       | P140/INTP6         |
| BUZ          | Output | Buzzer output Input P14                                                                                                                             |             | P141/INTP7/BUSY0   |
| AD0 to AD7   | I/O    | Lower address/data bus for external memory expansion                                                                                                | Input       | P40 to P47         |
| A8 to A15    | Output | Higher address bus for external memory expansion                                                                                                    | Input       | P50 to P57         |
| RD           | Output | Strobe signal output for external memory read operation                                                                                             | Input       | P64                |
| WR           | Output | Strobe signal output for external memory write operation                                                                                            | Input       | P65                |
| WAIT         | Input  | Wait insertion on external memory access                                                                                                            | Input       | P66                |
| ASTB         | Output | Strobe output that externally latches address information output to ports 4 and 5 for access to external memory                                     | Input       | P67                |
| ANI0 to ANI7 | Input  | A/D converter analog input                                                                                                                          | Input       | P20 to P27         |
| AVREF        | Input  | A/D converter reference voltage input                                                                                                               | -           | -                  |
| AVss         | -      | A/D converter ground potential. Make the same potential as $EV_{SS}$ or $V_{SS}.$                                                                   | _           | -                  |
| KR0 to KR7   | Input  | Key interrupt input                                                                                                                                 | Input       | P70 to P77         |
| REGC         | -      | Connecting regulator output stabilization capacitor. When using the regulator, connect to Vss via a 0.1 $\mu$ F capacitor.                          | -           | _                  |
|              |        | When the regulator is not used, connect directly to VDD.                                                                                            |             |                    |
| RESET        | Input  | System reset input                                                                                                                                  | -           | -                  |
| X1           | Input  | Connecting crystal resonator for X1 input clock oscillation                                                                                         | -           | -                  |
| X2           | -      |                                                                                                                                                     | -           | -                  |
| XT1          | Input  | Connecting crystal resonator for subsystem clock oscillation                                                                                        | _           | -                  |
| XT2          | -      |                                                                                                                                                     | -           | -                  |
| Vdd          | -      | Positive power supply (except for ports)                                                                                                            | -           | -                  |
| EVDD         | _      | Positive power supply for ports                                                                                                                     | -           | -                  |
| Vss          | -      | Ground potential (except for ports)                                                                                                                 | -           | _                  |
| EVss         | -      | Ground potential for ports                                                                                                                          | -           | _                  |
| IC           | -      | Internally connected. Connect directly to EVss or Vss.                                                                                              | -           | _                  |
| Vpp          | -      | Flash memory programming mode setting. High-voltage application for program write/verify. Connect directly to EVss or Vss in normal operation mode. | -           | _                  |

#### 2.2 Description of Pin Functions

## 2.2.1 P00 to P06 (port 0)

P00 to P06 function as a 7-bit I/O port. These pins also function as timer I/O, serial interface data I/O, clock I/O, and chip select input.

The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P00 to P06 function as a 7-bit I/O port. P00 to P06 can be set to input or output in 1-bit units using port mode register 0 (PM0). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 0 (PU0).

## (2) Control mode

P00 to P06 function as timer I/O.

#### (a) TI000, TI001<sup>Note</sup>

These are the pins for inputting an external count clock to 16-bit timer/event counters 00 and 01 and are also for inputting a capture trigger signal to the capture registers (CR000, CR010 or CR001, CR011) of 16-bit timer/event counters 00 and 01.

## (b) TI010, TI011<sup>Note</sup>

These are the pins for inputting a capture trigger signal to the capture register (CR000 or CR001) of 16-bit timer/event counters 00 and 01.

## (c) TO00, TO01<sup>Note</sup>

These are timer output pins.

#### (d) SI11<sup>Note</sup>, SO11<sup>Note</sup>

These are serial interface serial data I/O pins.

#### (e) SCK11<sup>Note</sup>

This is the serial interface serial clock I/O pin.

## (f) SSI11<sup>Note</sup>

This is the serial interface chip select input pin.

**Note** SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the μPD780146, 780148, and 78F0148.

#### 2.2.2 P10 to P17 (port 1)

P10 to P17 function as an 8-bit I/O port. These pins also function as pins for external interrupt request input, serial interface data I/O, clock I/O, and timer I/O.

The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P10 to P17 function as an 8-bit I/O port. P10 to P17 can be set to input or output in 1-bit units using port mode register 1 (PM1). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 1 (PU1).

## (2) Control mode

P10 to P17 function as external interrupt request input, serial interface data I/O, clock I/O, and timer I/O.

#### (a) SI10, SO10

These are serial interface serial data I/O pins.

# (b) SCK10

This is the serial interface serial clock I/O pin.

## (c) RxD0, RxD6, TxD0, and TxD6

These are the serial data I/O pins of the asynchronous serial interface.

## (d) TI50

This is the pin for inputting an external count clock to 8-bit timer/event counter 50.

## (e) TO50, TOH0, and TOH1

These are timer output pins.

## (f) INTP5

This is an external interrupt request input pin for which the valid edge (rising edge, falling edge, or both rising and falling edges) can be specified.

# 2.2.3 P20 to P27 (port 2)

P20 to P27 function as an 8-bit input-only port. These pins also function as pins for A/D converter analog input. The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P20 to P27 function as an 8-bit input-only port.

#### (2) Control mode

P20 to P27 function as A/D converter analog input pins (ANI0 to ANI7).

# 2.2.4 P30 to P33 (port 3)

P30 to P33 function as a 4-bit I/O port. These pins also function as pins for external interrupt request input and timer I/O.

The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P30 to P33 function as a 4-bit I/O port. P30 to P33 can be set to input or output in 1-bit units using port mode register 3 (PM3). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 3 (PU3).

#### (2) Control mode

P30 to P33 function as external interrupt request input pins and timer I/O pins.

#### (a) INTP1 to INTP4

These are the external interrupt request input pins for which the valid edge (rising edge, falling edge, or both rising and falling edges) can be specified.

## (b) TI51

This is an external count clock input pin to 8-bit timer/event counter 51.

#### (c) TO51

This is a timer output pin.

#### 2.2.5 P40 to P47 (port 4)

P40 to P47 function as an 8-bit I/O port. These pins also function as address/data bus pins. The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P40 to P47 function as an 8-bit I/O port. P40 to P47 can be set to input or output in 1-bit units using port mode register 4 (PM4). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 4 (PU4).

#### (2) Control mode

P40 to P47 function as the pins for the lower address/data bus (AD0 to AD7) in external memory expansion mode.

#### 2.2.6 P50 to P57 (port 5)

P50 to P57 function as an 8-bit I/O port. These pins also function as address bus pins. The following operation modes can be specified in 1-bit units.

## (1) Port mode

P50 to P57 function as an 8-bit I/O port. P50 to P57 can be set to input or output in 1-bit units using port mode register 5 (PM5). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 5 (PU5).

#### (2) Control mode

P50 to P57 function as the pins for the higher address bus (A8 to A15) in external memory expansion mode.

#### 2.2.7 P60 to P67 (port 6)

P60 to P67 function as an 8-bit I/O port. These pins also function as control pins in external memory expansion mode.

The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P60 to P67 function as an 8-bit I/O port. P60 to P67 can be set to input port or output port in 1-bit units using port mode register 6 (PM6).

P60 to P63 are N-ch open-drain pins. Use of an on-chip pull-up resistor can be specified by a mask option only for mask ROM versions.

Use of an on-chip pull-up resistor can be specified for P64 to P67 by pull-up resistor option register 6 (PU6).

#### (2) Control mode

P64 to P67 function as control signal output pins (RD, WR, WAIT, ASTB) in external memory expansion mode.

Caution P66 functions as an I/O port if the external wait is not used in external memory expansion mode.

## 2.2.8 P70 to P77 (port 7)

P70 to P77 function as an 8-bit I/O port. These pins also function as key interrupt input pins. The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P70 to P77 function as an 8-bit I/O port. P70 to P77 can be set to input or output in 1-bit units using port mode register 7 (PM7). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 7 (PU7).

## (2) Control mode

P70 to P77 function as key interrupt input pins.

# 2.2.9 P120 (port 12)

P120 functions as a 1-bit I/O port. This pin also functions as a pin for external interrupt request input. The following operation modes can be specified.

#### (1) Port mode

P120 functions as a 1-bit I/O port. P120 can be set to input or output using port mode register 12 (PM12). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 12 (PU12).

## (2) Control mode

P120 functions as an external interrupt request input pin (INTP0) for which the valid edge (rising edge, falling edge, or both rising and falling edges) can be specified.

#### 2.2.10 P130 (port 13)

P130 functions as a 1-bit output-only port.

#### 2.2.11 P140 to P145 (port 14)

P140 to P145 function as a 6-bit I/O port. These pins also function as external interrupt request input, clock output, buzzer output, serial interface data I/O, clock I/O, busy input, and strobe output pins.

The following operation modes can be specified in 1-bit units.

#### (1) Port mode

P140 to P145 function as a 6-bit I/O port. P140 to P145 can be set to input or output in 1-bit units using port mode register 14 (PM14). Use of an on-chip pull-up resistor can be specified by pull-up resistor option register 14 (PU14).

#### (2) Control mode

P140 to P145 function as external interrupt request input, clock output, buzzer output, serial interface data I/O, clock I/O, busy input, and strobe output pins.

#### (a) INTP6, INTP7

These are the external interrupt request input pins for which the valid edge (rising edge, falling edge, or both rising and falling edges) can be specified.

## (b) PCL

This is a clock output pin.

## (c) BUZ

This is a buzzer output pin.

## (d) SIA0, SOA These are serial interface serial data I/O pins.

(e) SCKA0 This is the serial interface serial clock I/O pin.

# (f) BUSY0 This is the serial interface busy input pin.

# (g) STB0

This is the serial interface strobe output pin.

#### 2.2.12 AVREF

This is the A/D converter reference voltage input pin. When A/D converter is not used, connect this pin to  $V_{\text{DD}}$ .

## 2.2.13 AVss

This is the A/D converter ground potential pin. Even when the A/D converter is not used, always use this pin with the same potential as the EVss pin or Vss pin.

#### 2.2.14 RESET

This is the active-low system reset input pin.

## 2.2.15 REGC

This is the pin for connecting the capacitor for the regulator. When using the regulator, connect this pin to Vss via a 0.1  $\mu$ F capacitor. When the regulator is not used, connect this pin directly to V<sub>DD</sub> and use it with the same potential as V<sub>DD</sub> pin.

#### 2.2.16 X1 and X2

These are the pins for connecting a crystal resonator for X1 input clock oscillation. When supplying an external clock, input a signal to the X1 pin and input the inverse signal to the X2 pin.

## 2.2.17 XT1 and XT2

These are the pins for connecting a crystal resonator for subsystem clock oscillation. When supplying an external clock, input a signal to the XT1 pin and input the inverse signal to the XT2 pin.

#### 2.2.18 VDD and EVDD

 $V_{DD}$  is the positive power supply pin for other than ports. EV\_DD is the positive power supply pin for ports.

## 2.2.19 Vss and EVss

Vss is the ground potential pin for other than ports. EVss is the ground potential pin for ports.

## 2.2.20 VPP (flash memory versions only)

This is a pin for flash memory programming mode setting and high-voltage application for program write/verify. Connect directly to EVss or Vss in the normal operation mode.

## 2.2.21 IC (mask ROM versions only)

The IC (Internally Connected) pin is provided to set the test mode to check the 78K0/KF1 Series at shipment. Connect it directly to EVss or Vss pin with the shortest possible wire in the normal operation mode.

When a potential difference is produced between the IC pin and the EVss or Vss pin because the wiring between these two pins is too long or external noise is input to the IC pin, the user's program may not operate normally.

# • Connect the IC pin directly to EVss or Vss.



# 2.3 Pin I/O Circuits and Recommended Connection of Unused Pins

Table 2-1 shows the types of pin I/O circuits and the recommended connections of unused pins. Refer to **Figure 2-1** for the configuration of the I/O circuit of each type.

| Pin Name                                         | I/O Circuit Type | I/O   | Recommended Connection of Unused Pins                                                |
|--------------------------------------------------|------------------|-------|--------------------------------------------------------------------------------------|
| P00/TI000                                        | 8-A              | I/O   | Input: Independently connect to EV <sub>DD</sub> or EV <sub>SS</sub> via a resistor. |
| P01/TI010/TO00                                   | -                |       | Output: Leave open.                                                                  |
| P02/SO11 <sup>Note</sup>                         |                  |       |                                                                                      |
| P03/SI11 <sup>Note</sup>                         |                  |       |                                                                                      |
| P04/SCK11 <sup>Note</sup>                        |                  |       |                                                                                      |
| P05/SSI11 <sup>Note</sup> /TI001 <sup>Note</sup> |                  |       |                                                                                      |
| P06/TI011 <sup>Note</sup> /TO01 <sup>Note</sup>  |                  |       |                                                                                      |
| P10/SCK10/TxD0 <sup>Note</sup>                   |                  |       |                                                                                      |
| P11/SI10/RxD0 <sup>Note</sup>                    |                  |       |                                                                                      |
| P12/SO10                                         | 5-A              |       |                                                                                      |
| P13/TxD6                                         |                  |       |                                                                                      |
| P14/RxD6                                         | 8-A              |       |                                                                                      |
| P15/TOH0                                         | 5-A              |       |                                                                                      |
| P16/TOH1/INTP5                                   | 8-A              |       |                                                                                      |
| P17/TI50/TO50                                    |                  |       |                                                                                      |
| P20/ANI0 to P27/ANI7                             | 9-C              | Input | Connect to EVDD or EVSS.                                                             |
| P30/INTP1 to P32/INTP3                           | 8-A              | I/O   | Input: Independently connect to EVDD or EVss via a resistor.                         |
| P33/TI51/TO51/INTP4                              |                  |       | Output: Leave open.                                                                  |
| P40/AD0 to P47/AD7                               | 5-A              |       |                                                                                      |
| P50/A8 to P57/A15                                |                  |       |                                                                                      |
| P60, P61 (Mask ROM version)                      | 13-S             |       | Input: Independently connect to EVDD via a resistor.                                 |
| P60, P61 (Flash memory version)                  | 13-R             |       | Output: Leave open.                                                                  |
| P62, P63 (Mask ROM version)                      | 13-W             |       |                                                                                      |
| P62, P63 (Flash memory version)                  | 13-V             |       |                                                                                      |
| P64/WD                                           | 5-A              |       | Input: Independently connect to EVDD or EVSS via a resistor.                         |
| P65/WR                                           |                  |       | Output: Leave open.                                                                  |
| P66/WAIT                                         |                  |       |                                                                                      |
| P67/ASTB                                         |                  | ]     |                                                                                      |
| P70/KR0 to P77/KR7                               | 8-A              |       |                                                                                      |
| P120/INTP0                                       |                  |       |                                                                                      |

# Table 2-1. Pin I/O Circuit Types (1/2)

Note SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

|            |               | /              |
|------------|---------------|----------------|
| Table 2-1. | Pin I/O Circu | it Types (2/2) |

| Pin Name             | I/O Circuit Type | I/O    | Recommended Connection of Unused Pins                        |
|----------------------|------------------|--------|--------------------------------------------------------------|
| P130                 | 3-C              | Output | Leave open.                                                  |
| P140/PCL/INTP6       | 8-A              | I/O    | Input: Independently connect to EVDD or EVSS via a resistor. |
| P141/BUZ/BUSY0/INTP7 |                  |        | Output: Leave open.                                          |
| P142/SCKA0           |                  |        |                                                              |
| P143/SIA0            |                  |        |                                                              |
| P144/SOA0            | 5-A              |        |                                                              |
| P145/STB             |                  |        |                                                              |
| RESET                | 2                | Input  | -                                                            |
| XT1                  | 16               |        | Connect directly to EVDD or VDD.                             |
| XT2                  |                  | -      | Leave open.                                                  |
| AVREF                | _                | -      | Connect directly to EVDD or VDD.                             |
| AVss                 | _                | _      | Connect directly to EVss or Vss.                             |
| IC                   | _                | -      | Connect directly to EVss or Vss.                             |
| Vpp                  |                  |        |                                                              |

| Figure 2- <sup>-</sup> | I. Pin I/O | Circuit L | _ist (1/2) |
|------------------------|------------|-----------|------------|
|------------------------|------------|-----------|------------|





Figure 2-1. Pin I/O Circuit List (2/2)

# CHAPTER 3 CPU ARCHITECTURE

# 3.1 Memory Space

μPD780146

μPD780148

μPD78F0148

ССН

CFH

Products in the 78K0/KF1 Series can each access a 64 KB memory space. Figures 3-1 to 3-5 show the memory maps.

Caution Regardless of the internal memory capacity, the initial values of the internal memory size switching register (IMS) and internal expansion RAM size switching register (IXS) of all products in the 78K0/KF1 Series are fixed (IMS = CFH, IXS = 0CH). Therefore, set the value corresponding to each product as indicated below.

|           | IMS | IXS |
|-----------|-----|-----|
| μPD780143 | C6H | OCH |
| μPD780144 | С8Н |     |

Value corresponding to mask ROM version

0AH

 Table 3-1. Set Values of Internal Memory Size Switching Register (IMS)

 and Internal Expansion RAM Size Switching Register (IXS)



#### Figure 3-1. Memory Map (*µ*PD780143)



Figure 3-2. Memory Map (µPD780144)



#### Figure 3-3. Memory Map (*µ*PD780146)







#### Figure 3-5. Memory Map (µPD78F0148)

## 3.1.1 Internal program memory space

The internal program memory space stores the program and table data. Normally, it is addressed with the program counter (PC).

78K0/KF1 Series products incorporate internal ROM (or flash memory), as shown below.

| Part Number | Internal ROM |                                        |  |
|-------------|--------------|----------------------------------------|--|
|             | Structure    | Capacity                               |  |
| μPD780143   | Mask ROM     | 24576 $\times$ 8 bits (0000H to 5FFFH) |  |
| μPD780144   |              | 32768 $\times$ 8 bits (0000H to 7FFFH) |  |
| μPD780146   |              | 49152 $\times$ 8 bits (0000H to BFFFH) |  |
| μPD780148   |              | $61440 \times 8$ bits (0000H to EFFFH) |  |
| μPD78F0148  | Flash memory | $61440 \times 8$ bits (0000H to EFFFH) |  |

| Table 3-2. | Internal | Memory | Capacity |
|------------|----------|--------|----------|
|------------|----------|--------|----------|

The internal program memory space is divided into the following areas.

## (1) Vector table area

The 64-byte area 0000H to 003FH is reserved as a vector table area. The program start addresses for branch upon  $\overrightarrow{\text{RESET}}$  input or generation of each interrupt request are stored in the vector table area.

Of the 16-bit address, the lower 8 bits are stored at even addresses and the higher 8 bits are stored at odd addresses.

| Vector Table Address | Interrupt Source             | Vector Table Address | Interrupt Source         |
|----------------------|------------------------------|----------------------|--------------------------|
| 0000H                | 0000H RESET input, POC, LVI, | 0020H                | INTTM000                 |
| clock monitor, WDT   | 0022H                        | INTTM010             |                          |
| 0004H                | INTLVI                       | 0024H                | INTAD                    |
| 0006H                | INTP0                        | 0026H                | INTSR0                   |
| 0008H                | INTP1                        | 0028H                | INTWTI                   |
| 000AH                | INTP2                        | 002AH                | INTTM51                  |
| 000CH                | INTP3                        | 002CH                | INTKR                    |
| 000EH                | INTP4                        | 002EH                | INTWT                    |
| 0010H                | INTP5                        | 0030H                | INTP6                    |
| 0012H                | INTSRE6                      | 0032H                | INTP7                    |
| 0014H                | INTSR6                       | 0034H                | INTDMU                   |
| 0016H                | INTST6                       | 0036H                | INTCSI11 <sup>Note</sup> |
| 0018H                | INTCSI10/INTST0              | 0038H                | INTTM001 <sup>Note</sup> |
| 001AH                | INTTMH1                      | 003AH                | INTTM011 <sup>Note</sup> |
| 001CH                | INTTMHO                      | 003CH                | INTACSI                  |
| 001EH                | INTTM50                      |                      |                          |

#### Table 3-3. Vector Table

**Note** Available only in the  $\mu$ PD780146, 780148, and 78F0148.

## (2) CALLT instruction table area

The 64-byte area 0040H to 007FH can store the subroutine entry address of a 1-byte call instruction (CALLT).

## (3) CALLF instruction entry area

The area 0800H to 0FFFH can perform a direct subroutine call with a 2-byte call instruction (CALLF).

#### 3.1.2 Internal data memory space

78K0/KF1 Series products incorporate the following RAMs.

## (1) Internal high-speed RAM

The internal high-speed RAM is allocated to the area FB00H to FEFFH in a  $1024 \times 8$  bits configuration.

The 32-byte area FEE0H to FEFFH is assigned to four general-purpose register banks consisting of eight 8-bit registers per one bank.

This area cannot be used as a program area in which instructions are written and executed.

The internal high-speed RAM can also be used as a stack memory.

## (2) Internal expansion RAM

| Part Number | Internal Expansion RAM                |
|-------------|---------------------------------------|
| μPD780143   | -                                     |
| μPD780144   |                                       |
| μPD780146   | 1024 $\times$ 8 bits (F400H to F7FFH) |
| μPD780148   |                                       |
| μPD78F0148  |                                       |

#### Table 3-4. Internal Expansion RAM Capacity

The internal expansion RAM can also be used as a normal data area similar to the internal high-speed RAM, as well as a program area in which instructions can be written and executed.

# 3.1.3 Special function register (SFR) area

On-chip peripheral hardware special function registers (SFRs) are allocated in the area FF00H to FFFFH (refer to **Table 3-5 Special Function Register List** in **3.2.3 Special Function Registers (SFRs)**).

Caution Do not access addresses to which SFRs are not assigned.

#### 3.1.4 Data memory addressing

Addressing refers to the method of specifying the address of the instruction to be executed next or the address of the register or memory relevant to the execution of instructions. The address of the instruction to be executed next is addressed by the program counter (PC) (for details, refer to **3.3 Instruction Address Addressing**).

Several addressing modes are provided for addressing the memory relevant to the execution of instructions for the 78K0/KF1 Series, based on operability and other considerations. For areas containing data memory in particular, special addressing methods designed for the functions of special function registers (SFR) and general-purpose registers are available for use. Data memory addressing is illustrated in Figures 3-6 to 3-10. For details of each addressing mode, refer to **3.4 Operand Address Addressing**.



#### Figure 3-6. Data Memory Addressing (µPD780143)



Figure 3-7. Data Memory Addressing (µPD780144)



#### Figure 3-8. Data Memory Addressing (µPD780146)



#### Figure 3-9. Data Memory Addressing (µPD780148)



#### Figure 3-10. Data Memory Addressing (µPD78F0148)

# 3.2 Processor Registers

The 78K0/KF1 Series products incorporate the following processor registers.

## 3.2.1 Control registers

The control registers control the program sequence, statuses and stack memory. The control registers consist of a program counter (PC), a program status word (PSW) and a stack pointer (SP).

# (1) Program counter (PC)

The program counter is a 16-bit register that holds the address information of the next program to be executed. In normal operation, the PC is automatically incremented according to the number of bytes of the instruction to be fetched. When a branch instruction is executed, immediate data and register contents are set. RESET input sets the reset vector table values at addresses 0000H and 0001H to the program counter.

## Figure 3-11. Format of Program Counter



# (2) Program status word (PSW)

The program status word is an 8-bit register consisting of various flags set/reset by instruction execution. Program status word contents are automatically stacked upon interrupt request generation or PUSH PSW instruction execution and are automatically restored upon execution of the RETB, RETI and POP PSW instructions.

RESET input sets the PSW to 02H.





## (a) Interrupt enable flag (IE)

This flag controls the interrupt request acknowledge operations of the CPU.

When 0, the IE flag is set to the interrupt disabled (DI) state, and only non-maskable interrupt requests become acknowledgeable. Other interrupt requests are all disabled.

When 1, the IE flag is set to the interrupt enabled (EI) state and interrupt request acknowledgement is controlled with an in-service priority flag (ISP), an interrupt mask flag for various interrupt sources, and a priority specification flag.

The IE flag is reset (0) upon DI instruction execution or interrupt acknowledgement and is set (1) upon EI instruction execution.

# (b) Zero flag (Z)

When the operation result is zero, this flag is set (1). It is reset (0) in all other cases.

#### (c) Register bank select flags (RBS0 and RBS1)

These are 2-bit flags to select one of the four register banks. In these flags, the 2-bit information that indicates the register bank selected by SEL RBn instruction execution is stored.

#### (d) Auxiliary carry flag (AC)

If the operation result has a carry from bit 3 or a borrow at bit 3, this flag is set (1). It is reset (0) in all other cases.

#### (e) In-service priority flag (ISP)

This flag manages the priority of acknowledgeable maskable vectored interrupts. When this flag is 0, low-level vectored interrupt requests specified by a priority specification flag register (PR0L, PR0H, PR1L, PR1H) (refer to **19.3 (3) Priority specification flag registers (PR0L, PR0H, PR1L, PR1H)**) can not be acknowledged. Actual request acknowledgement is controlled by the interrupt enable flag (IE).

#### (f) Carry flag (CY)

This flag stores overflow and underflow upon add/subtract instruction execution. It stores the shift-out value upon rotate instruction execution and functions as a bit accumulator during bit operation instruction execution.

#### (3) Stack pointer (SP)

This is a 16-bit register to hold the start address of the memory stack area. Only the internal high-speed RAM area can be set as the stack area.

## Figure 3-13. Format of Stack Pointer



The SP is decremented ahead of write (save) to the stack memory and is incremented after read (restored) from the stack memory.

Each stack operation saves/restores data as shown in Figures 3-14 and 3-15.

# Caution Since **RESET** input makes the SP contents undefined, be sure to initialize the SP before instruction execution.



Figure 3-14. Data to Be Saved to Stack Memory

Figure 3-15. Data to Be Restored from Stack Memory



#### 3.2.2 General-purpose registers

General-purpose registers are mapped at particular addresses (FEE0H to FEFFH) of the data memory. The general-purpose registers consists of 4 banks, each bank consisting of eight 8-bit registers (X, A, C, B, E, D, L, and H).

Each register can be used as an 8-bit register, and two 8-bit registers can also be used in a pair as a 16-bit register (AX, BC, DE, and HL).

These registers can be described in terms of function names (X, A, C, B, E, D, L, H, AX, BC, DE, and HL) and absolute names (R0 to R7 and RP0 to RP3).

Register banks to be used for instruction execution are set by the CPU control instruction (SEL RBn). Because of the 4-register bank configuration, an efficient program can be created by switching between a register for normal processing and a register for interrupts for each bank.

# Figure 3-16. Configuration of General-Purpose Registers



#### (a) Absolute Name

#### (b) Function Name



# 3.2.3 Special Function Registers (SFRs)

Unlike a general-purpose register, each special function register has a special function. SFRs are allocated to the FF00H to FFFFH area.

Special function registers can be manipulated like general-purpose registers, using operation, transfer and bit manipulation instructions. The manipulatable bit units, 1, 8, and 16, depend on the special function register type. Each manipulation bit unit can be specified as follows.

• 1-bit manipulation

Describe the symbol reserved by the assembler for the 1-bit manipulation instruction operand (sfr.bit). This manipulation can also be specified with an address.

• 8-bit manipulation

Describe the symbol reserved by the assembler for the 8-bit manipulation instruction operand (sfr). This manipulation can also be specified with an address.

• 16-bit manipulation

Describe the symbol reserved by the assembler for the 16-bit manipulation instruction operand (sfrp). When specifying an address, describe an even address.

Table 3-5 gives a list of the special function registers. The meanings of items in the table are as follows.

Symbol

Symbol indicating the address of a special function register. It is a reserved word in the RA78K0, and is defined by the header file "sfrbit.h" in the CC78K0. When using the RA78K0, ID78K0-NS, ID78K0, or SM78K0, symbols can be written as an instruction operand.

• R/W

Indicates whether the corresponding special function register can be read or written.

R/W: Read/write enable

- R: Read only
- W: Write only
- Manipulatable bit units

Indicates the manipulatable bit unit (1, 8, or 16). "-" indicates a bit unit for which manipulation is not possible.

After reset

Indicates each register status upon RESET input.

| Address | Special Function Register (SFR) Name        | Symbol | R/W | Man          | Manipulatable Bit Unit |              | After     |
|---------|---------------------------------------------|--------|-----|--------------|------------------------|--------------|-----------|
|         |                                             |        |     | 1 Bit        | 8 Bits                 | 16 Bits      | Reset     |
| FF00H   | Port 0                                      | P0     | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF01H   | Port 1                                      | P1     | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF02H   | Port 2                                      | P2     | R   | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF03H   | Port 3                                      | P3     | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF04H   | Port 4                                      | P4     | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF05H   | Port 5                                      | P5     | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF06H   | Port 6                                      | P6     | R/W | $\checkmark$ |                        | -            | 00H       |
| FF07H   | Port 7                                      | P7     | R/W | $\checkmark$ |                        | -            | 00H       |
| FF08H   | A/D conversion result register              | ADCR   | R   | _            | -                      | $\checkmark$ | Undefined |
| FF09H   |                                             |        |     |              |                        |              |           |
| FF0AH   | Receive buffer register 6                   | RXB6   | R   | _            | $\checkmark$           | -            | FFH       |
| FF0BH   | Transmit buffer register 6                  | TXB6   | R/W | _            |                        | -            | FFH       |
| FF0CH   | Port 12                                     | P12    | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF0DH   | Port 13                                     | P13    | R/W | $\checkmark$ | $\checkmark$           | -            | 00H       |
| FF0EH   | Port 14                                     | P14    | R/W | $\checkmark$ |                        | -            | 00H       |
| FF0FH   | Serial I/O shift register 10                | SIO10  | R   | _            | $\checkmark$           | -            | 00H       |
| FF10H   | 16-bit timer counter 00                     | TM00   | R   | _            | -                      | $\checkmark$ | 0000H     |
| FF11H   |                                             |        |     |              |                        |              |           |
| FF12H   | 16-bit timer capture/compare register 000   | CR000  | R/W | _            | -                      | $\checkmark$ | 0000H     |
| FF13H   |                                             |        |     |              |                        |              |           |
| FF14H   | 16-bit timer capture/compare register 010   | CR010  | R/W | —            | -                      | $\checkmark$ | 0000H     |
| FF15H   |                                             |        |     |              |                        |              |           |
| FF16H   | 8-bit timer counter 50                      | TM50   | R   | _            | $\checkmark$           | -            | 00H       |
| FF17H   | 8-bit timer compare register 50             | CR50   | R/W | —            |                        | -            | 00H       |
| FF18H   | 8-bit timer H compare register 00           | CMP00  | R/W | _            | $\checkmark$           | -            | 00H       |
| FF19H   | 8-bit timer H compare register 10           | CMP10  | R/W | _            | $\checkmark$           | -            | 00H       |
| FF1AH   | 8-bit timer H compare register 01           | CMP01  | R/W | _            | $\checkmark$           | -            | 00H       |
| FF1BH   | 8-bit timer H compare register 11           | CMP11  | R/W | _            | $\checkmark$           | -            | 00H       |
| FF1FH   | 8-bit timer counter 51                      | TM51   | R   | —            | $\checkmark$           | -            | 00H       |
| FF20H   | Port mode register 0                        | PM0    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF21H   | Port mode register 1                        | PM1    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF23H   | Port mode register 3                        | PM3    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF24H   | Port mode register 4                        | PM4    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF25H   | Port mode register 5                        | PM5    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF26H   | Port mode register 6                        | PM6    | R/W | $\checkmark$ | $\checkmark$           | -            | FFH       |
| FF27H   | Port mode register 7                        | PM7    | R/W |              | $\checkmark$           | _            | FFH       |
| FF28H   | A/D converter mode register                 | ADM    | R/W |              |                        | _            | 00H       |
| FF29H   | Analog input channel specification register | ADS    | R/W |              |                        | _            | 00H       |
| FF2AH   | Power-fail comparison mode register         | PFM    | R/W |              | $\checkmark$           | -            | 00H       |
| FF2BH   | Power-fail comparison threshold register    | PFT    | R/W | _            | $\checkmark$           | -            | 00H       |

 $\star$ 

## Table 3-5. Special Function Register List (1/4)

| Address | Special Function Register (SFR) Name                            | Syr   | nbol   | R/W | Man          | ipulatable B | it Unit      | After   |
|---------|-----------------------------------------------------------------|-------|--------|-----|--------------|--------------|--------------|---------|
|         |                                                                 |       |        |     | 1 Bit        | 8 Bits       | 16 Bits      | Reset   |
| FF2CH   | Port mode register 12                                           | PM12  |        | R/W | $\checkmark$ | $\checkmark$ | -            | FFH     |
| FF2EH   | Port mode register 14                                           | PM14  |        | R/W | $\checkmark$ | $\checkmark$ | -            | FFH     |
| FF30H   | Pull-up resistor option register 0                              | PU0   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF31H   | Pull-up resistor option register 1                              | PU1   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF33H   | Pull-up resistor option register 3                              | PU3   |        | R/W | $\checkmark$ |              | _            | 00H     |
| FF34H   | Pull-up resistor option register 4                              | PU4   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF35H   | Pull-up resistor option register 5                              | PU5   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF36H   | Pull-up resistor option register 6                              | PU6   |        | R/W | $\checkmark$ |              | _            | 00H     |
| FF37H   | Pull-up resistor option register 7                              | PU7   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF3CH   | Pull-up resistor option register 12                             | PU12  |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF3EH   | Pull-up resistor option register 14                             | PU14  |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF40H   | Clock output selection register                                 | CKS   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF41H   | 8-bit timer compare register 51                                 | CR51  |        | R/W | -            |              | -            | 00H     |
| FF43H   | 8-bit timer mode control register 51                            | TMC5  | 1      | R/W | $\checkmark$ |              | -            | 00H     |
| FF47H   | Memory expansion mode register                                  | MEM   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF48H   | External interrupt rising edge enable register                  | EGP   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF49H   | External interrupt falling edge enable register                 | EGN   |        | R/W | $\checkmark$ |              | -            | 00H     |
| FF4AH   | Serial I/O shift register 11 <sup>Note</sup>                    | SIO11 |        | R   | _            |              | _            | 00H     |
| FF4CH   | Transmit buffer register 11 <sup>Note</sup>                     | SOTB  | 11     | R/W | _            |              | -            | Undefir |
| FF4FH   | Input switch control register                                   | ISC   |        | R/W | $\checkmark$ |              | _            | 00H     |
| FF50H   | Asynchronous serial interface operation mode register 6         | ASIM  | 3      | R/W | V            | V            | -            | 01H     |
| FF53H   | Asynchronous serial interface reception error status register 6 | ASIS6 |        | R   | _            | V            | _            | 00H     |
| FF55H   | Asynchronous serial interface transmission status register 6    | ASIF6 |        | R   | -            | V            | _            | 00H     |
| FF56H   | Clock selection register 6                                      | CKSR  | 6      | R/W | _            |              | -            | 00H     |
| FF57H   | Baud rate generator control register 6                          | BRGC  | 6      | R/W | _            |              | -            | FFH     |
| FF58H   | Asynchronous serial interface control register 6                | ASICL | .6     | R/W | $\checkmark$ |              | -            | 16H     |
| FF60H   | Remainder data register 0                                       | SDR0  | SDR0L  | R   | _            |              | $\checkmark$ | 00H     |
| FF61H   | ]                                                               |       | SDR0H  |     | _            |              |              | 00H     |
| FF62H   | Multiplication/division data register A0                        | MDAOL | MDA0LL | R/W | _            |              | $\checkmark$ | 00H     |
| FF63H   | ]                                                               |       | MDA0LH |     | _            |              |              | 00H     |
| FF64H   | ]                                                               | MDA0H | MDA0HL | R/W | _            |              | $\checkmark$ | 00H     |
| FF65H   |                                                                 |       | MDA0HH |     | _            |              | ]            | 00H     |
| FF66H   | Multiplication/division data register B0                        | MDB0  | MDB0L  | R/W | _            |              | $\checkmark$ | 00H     |
| FF67H   | ]                                                               |       | MDB0H  | l ľ | _            |              | 1            | 00H     |
| FF68H   | Multiplier/divider control register 0                           | DMUC  | 0      | R/W | $\checkmark$ |              | _            | 00H     |
| FF69H   | 8-bit timer H mode register 0                                   | ТМНМ  | 1D0    | R/W | $\checkmark$ |              | -            | 00H     |
| FF6AH   | Timer clock selection register 50                               | TCL50 | )      | R/W | -            |              | _            | 00H     |

## Table 3-5. Special Function Register List (2/4)

**Note** *µ*PD780146, 780148, and 78F0148 only.

| Address | Special Function Register (SFR) Name                            | Symbol | R/W | Man          | ipulatable B | it Unit | After                 |
|---------|-----------------------------------------------------------------|--------|-----|--------------|--------------|---------|-----------------------|
|         |                                                                 |        |     | 1 Bit        | 8 Bits       | 16 Bits | Reset                 |
| FF6BH   | 8-bit timer mode control register 50                            | TMC50  | R/W | $\checkmark$ |              | -       | 00H                   |
| FF6CH   | 8-bit timer H mode register 1                                   | TMHMD1 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF6DH   | 8-bit timer H carrier control register 1                        | TMCYC1 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF6EH   | Key return mode register                                        | KRM    | R/W | $\checkmark$ |              | -       | 00H                   |
| FF6FH   | Watch timer operation mode register                             | WTM    | R/W | $\checkmark$ |              | -       | 00H                   |
| FF70H   | Asynchronous serial interface operation mode register 0         | ASIM0  | R/W | $\checkmark$ | V            | _       | 01H                   |
| FF71H   | Baud rate generator control register 0                          | BRGC0  | R/W | -            |              | -       | 1FH                   |
| FF72H   | Receive buffer register 0                                       | RXB0   | R   | -            |              | -       | FFH                   |
| FF73H   | Asynchronous serial interface reception error status register 0 | ASIS0  | R   |              | $\checkmark$ | _       | 00H                   |
| FF74H   | Transmit shift register 0                                       | TXS0   | W   | -            | $\checkmark$ | -       | FFH                   |
| FF80H   | Serial operation mode register 10                               | CSIM10 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF81H   | Serial clock selection register 10                              | CSIC10 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF84H   | Transmit buffer register 10                                     | SOTB10 | R/W | -            |              | -       | Undefined             |
| FF88H   | Serial operation mode register 11 <sup>Note 1</sup>             | CSIM11 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF89H   | Serial clock selection register 11 <sup>Note 1</sup>            | CSIC11 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF8CH   | Timer clock selection register 51                               | TCL51  | R/W | -            |              | -       | 00H                   |
| FF90H   | Serial operation mode specification register 0                  | CSIMA0 | R/W | $\checkmark$ |              | -       | 00H                   |
| FF91H   | Serial status register 0                                        | CSIS0  | R/W | $\checkmark$ |              | -       | 00H                   |
| FF92H   | Serial trigger register 0                                       | CSIT0  | R/W | $\checkmark$ |              | -       | 00H                   |
| FF93H   | Divisor selection register 0                                    | BRGCA0 | R/W | -            |              | -       | 03H                   |
| FF94H   | Automatic data transfer address point specification register 0  | ADTP0  | R/W | _            | $\checkmark$ | _       | 00H                   |
| FF95H   | Automatic data transfer interval specification register 0       | ADTI0  | R/W | _            | V            | _       | 00H                   |
| FF96H   | Serial I/O shift register 0                                     | SIOA0  | R/W | _            |              | _       | 00H                   |
| FF97H   | Automatic data transfer address count register 0                | ADTC3  | R   | -            |              | -       | 00H                   |
| FF98H   | Watchdog timer mode register                                    | WDTM   | R/W | _            |              | -       | 67H                   |
| FF99H   | Watchdog timer enable register                                  | WDTE   | R/W | _            |              | -       | 9AH                   |
| FFA0H   | Ring-OSC mode register                                          | RCM    | R/W | $\checkmark$ |              | _       | 00H                   |
| FFA1H   | Main clock mode register                                        | MCM    | R/W | $\checkmark$ |              | _       | 00H                   |
| FFA2H   | Main OSC control register                                       | MOC    | R/W | $\checkmark$ |              | -       | 00H                   |
| FFA3H   | Oscillation stabilization time counter status register          | OSTC   | R   | $\checkmark$ |              | _       | 00H                   |
| FFA4H   | Oscillation stabilization time select register                  | OSTS   | R/W | _            |              | -       | 05H                   |
| FFA9H   | Clock monitor mode register                                     | CLM    | R/W | $\checkmark$ |              | -       | 00H                   |
| FFACH   | Reset control flag register                                     | RESF   | R   | _            |              | _       | 00H <sup>Note 2</sup> |
| FFB0H   | 16-bit timer counter 01 <sup>Note 1</sup>                       | TM01   | R   | _            | -            |         | 0000H                 |
| FFB1H   |                                                                 |        |     |              |              |         |                       |

## Table 3-5. Special Function Register List (3/4)

**Notes 1.** μPD780146, 780148, and 78F0148 only.

\*

2. This value varies depending on the reset source.

| Address | Special Function Register (SFR) Name                             | Syr   | Symbol F |     | Manipulatable Bit Unit |              |              | After |
|---------|------------------------------------------------------------------|-------|----------|-----|------------------------|--------------|--------------|-------|
|         |                                                                  |       |          |     | 1 Bit                  | 8 Bits       | 16 Bits      | Reset |
| FFB2H   | 16-bit timer capture/compare register 001Note 1                  | CR001 |          | R/W | _                      | -            | $\checkmark$ | 0000H |
| FFB3H   |                                                                  |       |          |     |                        |              |              |       |
| FFB4H   | 16-bit timer capture/compare register 011Note 1                  | CR01  | 1        | R/W | _                      | _            | $\checkmark$ | 0000H |
| FFB5H   |                                                                  |       |          |     |                        |              |              |       |
| FFB6H   | 16-bit timer mode control register 01 <sup>Note 1</sup>          | TMC0  | 1        | R/W |                        | $\checkmark$ | -            | 00H   |
| FFB7H   | Prescaler mode register 01 <sup>Note 1</sup>                     | PRM0  | 1        | R/W |                        |              | -            | 00H   |
| FFB8H   | Capture/compare control register 01 <sup>Note 1</sup>            | CRC0  | 1        | R/W |                        |              | -            | 00H   |
| FFB9H   | 16-bit timer output control register 01 <sup>Note 1</sup>        | TOC0  | 1        | R/W |                        |              | -            | 00H   |
| FFBAH   | 16-bit timer mode control register 00                            | TMC0  | 0        | R/W |                        | $\checkmark$ | _            | 00H   |
| FFBBH   | Prescaler mode register 00                                       | PRM0  | 0        | R/W |                        | $\checkmark$ | _            | 00H   |
| FFBCH   | Capture/compare control register 00                              | CRC0  | 0        | R/W | $\checkmark$           | $\checkmark$ | -            | 00H   |
| FFBDH   | 16-bit timer output control register 00                          | TOC0  | 0        | R/W | $\checkmark$           | $\checkmark$ | _            | 00H   |
| FFBEH   | Low-voltage detection register                                   | LVIM  |          | R/W | $\checkmark$           | $\checkmark$ | _            | 00H   |
| FFBFH   | Low-voltage detection level selection register                   | LVIS  |          | R/W | _                      | $\checkmark$ | _            | 00H   |
| FFE0H   | Interrupt request flag register 0L                               | IF0   | IF0L     | R/W |                        | $\checkmark$ | $\checkmark$ | 00H   |
| FFE1H   | Interrupt request flag register 0H                               |       | IF0H     | R/W |                        | $\checkmark$ |              | 00H   |
| FFE2H   | Interrupt request flag register 1L                               | IF1   | IF1L     | R/W |                        | $\checkmark$ | $\checkmark$ | 00H   |
| FFE3H   | Interrupt request flag register 1H                               |       | IF1H     | R/W | $\checkmark$           | $\checkmark$ |              | 00H   |
| FFE4H   | Interrupt mask flag register 0L                                  | MK0   | MK0L     | R/W | $\checkmark$           | $\checkmark$ | $\checkmark$ | FFH   |
| FFE5H   | Interrupt mask flag register 0H                                  |       | МКОН     | R/W | $\checkmark$           | $\checkmark$ |              | FFH   |
| FFE6H   | Interrupt mask flag register 1L                                  | MK1   | MK1L     | R/W | $\checkmark$           | $\checkmark$ | V            | FFH   |
| FFE7H   | Interrupt mask flag register 1H                                  |       | MK1H     | R/W |                        | $\checkmark$ |              | DFH   |
| FFE8H   | Priority specification flag register 0L                          | PR0   | PR0L     | R/W |                        | $\checkmark$ | $\checkmark$ | FFH   |
| FFE9H   | Priority specification flag register 0H                          |       | PR0H     | R/W | $\checkmark$           | $\checkmark$ |              | FFH   |
| FFEAH   | Priority specification flag register 1L                          | PR1   | PR1L     | R/W | $\checkmark$           | $\checkmark$ | V            | FFH   |
| FFEBH   | Priority specification flag register 1H                          |       | PR1H     | R/W | $\checkmark$           | $\checkmark$ |              | FFH   |
| FFF0H   | Internal memory size switching registerNote 2                    | IMS   |          | R/W | _                      | $\checkmark$ | -            | CFH   |
| FFF4H   | Internal expansion RAM size switching register <sup>Note 2</sup> | IXS   |          | R/W | _                      | $\checkmark$ | -            | 0CH   |
| FFF8H   | Memory expansion wait setting register                           | MM    |          | R/W |                        |              | -            | 10H   |
| FFFBH   | Processor clock control register                                 | PCC   |          | R/W |                        |              | _            | 00H   |

| Table 3-5. Special Function Register List (4/4) |
|-------------------------------------------------|
|-------------------------------------------------|

**Notes 1.** *μ*PD780146, 780148, and 78F0148 only.

**2.** The default value of IMS and IXS are fixed (IMS = CFH, IXS = 0CH) in all products in the 78K0/KF1 Series regardless of the internal memory capacity.

Therefore, set the following value to each product.

|            | IMS                                     | IXS |  |  |
|------------|-----------------------------------------|-----|--|--|
| μPD780143  | C6H                                     | 0CH |  |  |
| μPD780144  | C8H                                     |     |  |  |
| μPD780146  | ССН                                     | 0AH |  |  |
| μPD780148  | CFH                                     |     |  |  |
| μPD78F0148 | Value corresponding to mask ROM version |     |  |  |

#### 3.3 Instruction Address Addressing

An instruction address is determined by program counter (PC) contents and is normally incremented (+1 for each byte) automatically according to the number of bytes of an instruction to be fetched each time another instruction is executed. When a branch instruction is executed, the branch destination information is set to the PC and branched by the following addressing (for details of instructions, refer to **78K/0 Series Instructions User's Manual (U12326E)**).

#### 3.3.1 Relative addressing

#### [Function]

The value obtained by adding 8-bit immediate data (displacement value: jdisp8) of an instruction code to the start address of the following instruction is transferred to the program counter (PC) and branched. The displacement value is treated as signed two's complement data (-128 to +127) and bit 7 becomes a sign bit. In other words, relative addressing consists of relative branching from the start address of the following instruction to the -128 to +127 range.

This function is carried out when the BR \$addr16 instruction or a conditional branch instruction is executed.

#### [Illustration]



When S = 0, all bits of  $\alpha$  are 0. When S = 1, all bits of  $\alpha$  are 1.

## 3.3.2 Immediate addressing

## [Function]

Immediate data in the instruction word is transferred to the program counter (PC) and branched. This function is carried out when the CALL !addr16 or BR !addr16 or CALLF !addr11 instruction is executed. CALL !addr16 and BR !addr16 instructions can be branched to the entire memory space. The CALLF !addr11 instruction is branched to the 0800H to 0FFFH area.

## [Illustration]

In the case of CALL laddr16 and BR laddr16 instructions



In the case of CALLF !addr11 instruction



#### 3.3.3 Table indirect addressing

#### [Function]

Table contents (branch destination address) of the particular location to be addressed by bits 1 to 5 of the immediate data of an operation code are transferred to the program counter (PC) and branched.

This function is carried out when the CALLT [addr5] instruction is executed.

This instruction references the address stored in the memory table from 40H to 7FH, and allows branching to the entire memory space.

### [Illustration]



#### 3.3.4 Register addressing

#### [Function]

Register pair (AX) contents to be specified with an instruction word are transferred to the program counter (PC) and branched.

This function is carried out when the BR AX instruction is executed.

## [Illustration]



## 3.4 Operand Address Addressing

The following methods are available to specify the register and memory (addressing) to undergo manipulation during instruction execution.

## 3.4.1 Implied addressing

### [Function]

The register that functions as an accumulator (A and AX) among the general-purpose registers is automatically (implicitly) addressed.

Of the 78K0/KF1 Series instruction words, the following instructions employ implied addressing.

| Instruction | Register to Be Specified by Implied Addressing                                  |
|-------------|---------------------------------------------------------------------------------|
| MULU        | A register for multiplicand and AX register for product storage                 |
| DIVUW       | AX register for dividend and quotient storage                                   |
| ADJBA/ADJBS | A register for storage of numeric values that become decimal correction targets |
| ROR4/ROL4   | A register for storage of digit data that undergoes digit rotation              |

## [Operand format]

Because implied addressing can be automatically employed with an instruction, no particular operand format is necessary.

### [Description example]

In the case of MULU X

With an 8-bit  $\times$  8-bit multiply instruction, the product of A register and X register is stored in AX. In this example, the A and AX registers are specified by implied addressing.

#### 3.4.2 Register addressing

## [Function]

The general-purpose register to be specified is accessed as an operand with the register bank select flags (RBS0 to RBS1) and the register specify codes (Rn and RPn) of an operation code.

Register addressing is carried out when an instruction with the following operand format is executed. When an 8-bit register is specified, one of the eight registers is specified with 3 bits in the operation code.

## [Operand format]

| Identifier | Description            |
|------------|------------------------|
| r          | X, A, C, B, E, D, L, H |
| rp         | AX, BC, DE, HL         |

'r' and 'rp' can be described by absolute names (R0 to R7 and RP0 to RP3) as well as function names (X, A, C, B, E, D, L, H, AX, BC, DE, and HL).

## [Description example]

MOV A, C; when selecting C register as r



INCW DE; when selecting DE register pair as rp



## 3.4.3 Direct addressing

## [Function]

The memory to be manipulated is directly addressed with immediate data in an instruction word becoming an operand address.

## [Operand format]



#### [Description example]

MOV A, !0FE00H; when setting !addr16 to FE00H



## [Illustration]



#### 3.4.4 Short direct addressing

#### [Function]

The memory to be manipulated in the fixed space is directly addressed with 8-bit data in an instruction word. This addressing is applied to the 256-byte space FE20H to FF1FH. Internal RAM and special function registers (SFRs) are mapped at FE20H to FEFFH and FF00H to FF1FH, respectively.

The SFR area (FF00H to FF1FH) where short direct addressing is applied is a part of the overall SFR area. Ports that are frequently accessed in a program and compare and capture registers of the timer/event counter are mapped in this area, allowing SFRs to be manipulated with a small number of bytes and clocks. When 8-bit immediate data is at 20H to FFH, bit 8 of an effective address is set to 0. When it is at 00H to 1FH,

bit 8 is set to 1. Refer to the **[Illustration]** shown below.

#### [Operand format]

| Identifier | Description                                                |
|------------|------------------------------------------------------------|
| saddr      | Label or FE20H to FF1FH immediate data                     |
| saddrp     | Label or FE20H to FF1FH immediate data (even address only) |

#### [Description example]

MOV 0FE30H, #50H; when setting saddr to FE30H and immediate data to 50H



#### [Illustration]



When 8-bit immediate data is 20H to FFH,  $\alpha = 0$ When 8-bit immediate data is 00H to 1FH,  $\alpha = 1$ 

## 3.4.5 Special function register (SFR) addressing

## [Function]

A memory-mapped special function register (SFR) is addressed with 8-bit immediate data in an instruction word. This addressing is applied to the 240-byte spaces FF00H to FFCFH and FFE0H to FFFFH. However, the SFRs mapped at FF00H to FF1FH can be accessed with short direct addressing.

## [Operand format]

| Identifier | Description                                                             |
|------------|-------------------------------------------------------------------------|
| sfr        | Special function register name                                          |
| sfrp       | 16-bit manipulatable special function register name (even address only) |

## [Description example]

MOV PM0, A; when selecting PM0 (FF20H) as sfr



## [Illustration]



### 3.4.6 Register indirect addressing

## [Function]

Register pair contents specified by a register pair specify code in an instruction word and by a register bank select flag (RBS0 and RBS1) serve as an operand address for addressing the memory. This addressing can be carried out for all the memory spaces.

#### [Operand format]

| Identifier | Description |
|------------|-------------|
| -          | [DE], [HL]  |

1

#### [Description example]

MOV A, [DE]; when selecting [DE] as register pair

Operation code

| 0 | 0 | 0 | 0 | 1 | 0 | 1 |
|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |

## [Illustration]



## 3.4.7 Based addressing

## [Function]

8-bit immediate data is added as offset data to the contents of the base register, that is, the HL register pair in the register bank specified by the register bank select flag (RBS0 and RBS1), and the sum is used to address the memory. Addition is performed by expanding the offset data as a positive number to 16 bits. A carry from the 16th bit is ignored. This addressing can be carried out for all the memory spaces.

## [Operand format]

| Identifier | Description |  |  |
|------------|-------------|--|--|
| -          | [HL + byte] |  |  |

### [Description example]

MOV A, [HL + 10H]; when setting byte to 10H



#### 3.4.8 Based indexed addressing

#### [Function]

The B or C register contents specified in an instruction word are added to the contents of the base register, that is, the HL register pair in the register bank specified by the register bank select flag (RBS0 and RBS1), and the sum is used to address the memory. Addition is performed by expanding the B or C register contents as a positive number to 16 bits. A carry from the 16th bit is ignored. This addressing can be carried out for all the memory spaces.

#### [Operand format]

| Identifier | Description        |  |  |
|------------|--------------------|--|--|
| _          | [HL + B], [HL + C] |  |  |

#### [Description example]

In the case of MOV A, [HL + B]

Operation code

| 0 1 0 1 1 | 1 | 0 | 1 | 0 | 1 |
|-----------|---|---|---|---|---|
|-----------|---|---|---|---|---|

#### 3.4.9 Stack addressing

#### [Function]

The stack area is indirectly addressed with the stack pointer (SP) contents.

This addressing method is automatically employed when the PUSH, POP, subroutine call and return instructions are executed or the register is saved/reset upon generation of an interrupt request. With stack addressing, only the internal high-speed RAM area can be accessed.

### [Description example]

In the case of PUSH DE

Operation code

| 1 0 1 1 0 1 0 1 |
|-----------------|
|-----------------|

## 4.1 Port Functions

78K0/KF1 Series products are provided with the ports shown in Figure 4-1, which enable variety of control operations. The functions of each port are shown in Table 4-1.

In addition to the function as digital I/O ports, these ports have several alternate functions. For details of the alternate functions, refer to **CHAPTER 2 PIN FUNCTIONS**.



Figure 4-1. Port Types

| Table 4-1. | Port Functions | (1/2) |
|------------|----------------|-------|
|------------|----------------|-------|

| Pin Name   | I/O   | Function                                                                                                                                                     | After Reset | Alternate Function                           |
|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------|
| P00        | I/O   | Port 0.                                                                                                                                                      | Input       | TI000                                        |
| P01        |       | 7-bit I/O port.                                                                                                                                              |             | TI010/TO00                                   |
| P02        |       | Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a                                                    |             | SO11 <sup>Note</sup>                         |
| P03        |       | software setting.                                                                                                                                            |             | SI11 <sup>Note</sup>                         |
| P04        |       |                                                                                                                                                              |             | SCK11 <sup>Note</sup>                        |
| P05        |       |                                                                                                                                                              |             | SSI11 <sup>Note</sup> /TI001 <sup>Note</sup> |
| P06        |       |                                                                                                                                                              |             | TI011 <sup>Note</sup> /TO01 <sup>Note</sup>  |
| P10        | I/O   | Port 1.                                                                                                                                                      | Input       | SCK10/TxD0                                   |
| P11        |       | 8-bit I/O port.                                                                                                                                              |             | SI10/RxD0                                    |
| P12        |       | Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a                                                    |             | SO10                                         |
| P13        |       | software setting.                                                                                                                                            |             | TxD6                                         |
| P14        |       |                                                                                                                                                              |             | RxD6                                         |
| P15        |       |                                                                                                                                                              |             | ТОН0                                         |
| P16        |       |                                                                                                                                                              |             | TOH1/INTP5                                   |
| P17        |       |                                                                                                                                                              |             | TI50/TO50                                    |
| P20 to P27 | Input | Port 2.<br>8-bit input-only port.                                                                                                                            | Input       | ANI0 to ANI7                                 |
| P30 to P32 | I/O   | Port 3.<br>4-bit I/O port.<br>Input/output can be specified in 1-bit units.                                                                                  | Input       | INTP1 to INTP3                               |
| P33        |       | Use of an on-chip pull-up resistor can be specified by a software setting.                                                                                   |             | INTP4/TI51/TO51                              |
| P40 to P47 | I/O   | Port 4.<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting. | Input       | AD0 to AD7                                   |
| P50 to P57 | I/O   | Port 5.<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting. | Input       | A8 to A15                                    |

Note SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

| Pin Name   | I/O    | Function                                                                                                               |                                                                                                                                        | After Reset         | Alternate Function |
|------------|--------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------|
| P60 to P63 | I/O    | Port 6.<br>8-bit I/O port.<br>Input/output can be specified<br>in 1-bit units.                                         | N-ch open-drain I/O port.<br>Use of an on-chip pull-up<br>resistor can be specified by a<br>mask option only for mask<br>ROM versions. | Input               | _                  |
| P64        |        |                                                                                                                        | Use of an on-chip pull-up                                                                                                              |                     | RD                 |
| P65        |        |                                                                                                                        | resistor can be specified by a software setting.                                                                                       |                     | WR                 |
| P66        |        |                                                                                                                        | sonware setting.                                                                                                                       |                     | WAIT               |
| P67        |        |                                                                                                                        |                                                                                                                                        |                     | ASTB               |
| P70 to P77 | I/O    | Port 7.<br>8-bit I/O port.<br>Input/output can be specified in<br>Use of an on-chip pull-up resis<br>software setting. | Input                                                                                                                                  | KR0 to KR7          |                    |
| P120       | 1/0    | Port 12.<br>1-bit I/O port.<br>Use of an on-chip pull-up resis<br>software setting.                                    | Input                                                                                                                                  | INTPO               |                    |
| P130       | Output | Port 13.<br>1-bit output-only port.                                                                                    |                                                                                                                                        | Output              | -                  |
| P140       | I/O    | Port 14.                                                                                                               |                                                                                                                                        | Input               | PCL/INTP6          |
| P141       |        | 6-bit I/O port.<br>Input/output can be specified in                                                                    |                                                                                                                                        | BUZ/BUSY0/<br>INTP7 |                    |
| P142       |        | Use of an on-chip pull-up resis software setting.                                                                      |                                                                                                                                        | SCKA0               |                    |
| P143       |        | Solumite Soluting.                                                                                                     |                                                                                                                                        |                     | SIA0               |
| P144       |        |                                                                                                                        |                                                                                                                                        |                     | SOA0               |
| P145       |        |                                                                                                                        |                                                                                                                                        |                     | STB0               |

## Table 4-1. Port Functions (2/2)

## 4.2 Port Configuration

Ports consist of the following hardware.

## Table 4-2. Port Configuration

| Item              | Configuration                                                                                                                                                       |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Control registers | Port mode register (PM0, PM1, PM3 to PM7, PM12, PM14)<br>Pull-up resistor option register (PU0, PU1, PU3 to PU7, PU12, PU14)<br>Input switch control register (ISC) |  |
| Port              | Total: 67 (CMOS I/O: 54, CMOS input: 8, CMOS output: 1, N-ch open drain output: 4)                                                                                  |  |
| Pull-up resistor  | <ul> <li>Mask ROM version<br/>Total: 58 (software control: 54, mask option specification: 4)</li> <li>Flash memory version: Total: 54</li> </ul>                    |  |

### 4.2.1 Port 0

Port 0 is a 7-bit I/O port with an output latch. Port 0 can be set to the input mode or output mode in 1-bit units using port mode register 0 (PM0). When the P00 to P06 pins are used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 0 (PU0).

This port can also be used for timer I/O, serial interface data I/O, and clock I/O.

RESET input sets port 0 to input mode.

Figures 4-2 to 4-5 show block diagrams of port 0.

## Caution When P02/SO11<sup>Note</sup>, P03/SI11<sup>Note</sup>, and P04/SCK11<sup>Note</sup> are used as general-purpose ports, do not write to serial clock selection register 11 (CSIC11).



Figure 4-2. Block Diagram of P00, P03, and P05

- PU0: Pull-up resistor option register 0
- PM: Port mode register
- RD: Port 0 read signal
- WR: Port 0 write signal



Figure 4-3. Block Diagram of P01 and P06

- PU0: Pull-up resistor option register 0
- PM: Port mode register
- RD: Port 0 read signal
- WR: Port 0 write signal

Figure 4-4. Block Diagram of P02



- PU0: Pull-up resistor option register 0
- PM: Port mode register
- RD: Port 0 read signal
- WR: Port 0 write signal





- PU0: Pull-up resistor option register 0
- PM: Port mode register
- RD: Port 0 read signal
- WR: Port 0 write signal

## 4.2.2 Port 1

Port 1 is an 8-bit I/O port with an output latch. Port 1 can be set to the input mode or output mode in 1-bit units using port mode register 1 (PM1). When the P10 to P17 pins are used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 1 (PU1).

This port can also be used for external interrupt request input, serial interface data I/O, clock I/O, and timer I/O. RESET input sets port 1 to input mode.

Figures 4-6 to 4-11 show block diagrams of port 1.

# Caution When P10/SCK10/TxD0, P11/SI10/RxD0, and P12/SO10 are used as general-purpose ports, do not write to serial clock selection register 10 (CSIC10).



Figure 4-6. Block Diagram of P10

- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal



Figure 4-7. Block Diagram of P11 and P14

- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal

Figure 4-8. Block Diagram of P12



- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal





- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal

Figure 4-10. Block Diagram of P15



- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal



Figure 4-11. Block Diagram of P16 and P17

- PU1: Pull-up resistor option register 1
- PM: Port mode register
- RD: Port 1 read signal
- WR: Port 1 write signal

## 4.2.3 Port 2

Port 2 is an 8-bit input-only port.

This port can also be used for A/D converter analog input.

Figure 4-12 shows a block diagram of port 2.





RD: Port 2 read signal

## 4.2.4 Port 3

Port 3 is a 4-bit I/O port with an output latch. Port 3 can be set to the input mode or output mode in 1-bit units using port mode register 3 (PM3). When used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 3 (PU3).

This port can also be used for external interrupt request input.

RESET input sets port 3 to input mode.

Figures 4-13 and 4-14 show block diagrams of port 3.





- PU3: Pull-up resistor option register 3
- PM: Port mode register
- RD: Port 3 read signal
- WR: Port 3 write signal

Figure 4-14. Block Diagram of P33



- PU0: Pull-up resistor option register 3
- PM: Port mode register
- RD: Port 3 read signal
- WR: Port 3 write signal

## 4.2.5 Port 4

Port 4 is an 8-bit I/O port with an output latch. Port 4 can be set to the input mode or output mode in 1-bit units using port mode register 4 (PM4). Use of an on-chip pull-up resistor can be specified in 1-bit units with pull-up resistor option register 4 (PU4).

This port can also be used as an address/data bus in external memory expansion mode.

RESET input sets port 4 to input mode.

Figure 4-15 shows a block diagram of port 4.





- PU: Pull-up resistor option register
- PM: Port mode register
- RD: Port 4 read signal
- WR: Port 4 write signal

## 4.2.6 Port 5

Port 5 is an 8-bit I/O port with an output latch. Port 5 can be set to the input mode or output mode in 1-bit units using port mode register 5 (PM5). Use of an on-chip pull-up resistor can be specified in 1-bit units using pull-up resistor option register 5 (PU5).

This port can also be used as an address bus in external memory expansion mode.

RESET input sets port 5 to input mode.

Figure 4-16 shows a block diagram of port 5.





- PU: Pull-up resistor option register
- PM: Port mode register
- RD: Port 5 read signal
- WR: Port 5 write signal

## 4.2.7 Port 6

Port 6 is an 8-bit I/O port with an output latch. Port 6 can be set to the input mode or output mode in 1-bit units using port mode register 6 (PM6).

This port has the following functions for pull-up resistors. These functions differ depending on the higher 4 bits/lower 4 bits of the port, and whether the product is a mask ROM version or a flash memory version.

| Table 4-3. | Pull-up | Resistor | of | Port | 6 |
|------------|---------|----------|----|------|---|
|------------|---------|----------|----|------|---|

|                      | Higher 4 Bits (Pins P64 to P67)                                       | Lower 4 Bits (Pins P60 to P63)                                             |
|----------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------|
| Mask ROM version     | An on-chip pull-up resistor can be<br>connected in 1-bit units by PU6 | An on-chip pull-up resistor can be specified in 1-bit units by mask option |
| Flash memory version |                                                                       | On-chip pull-up resistors are not provided                                 |

PU6: Pull-up resistor option register 6

The P64 to P67 pins can also be used for the control signal output function in external memory expansion mode. RESET input sets port 6 to input mode.

Figures 4-17 to 4-19 show block diagrams of port 6.

## Caution P66 can be used as an I/O port when an external wait is not used in external memory expansion mode.



Figure 4-17. Block Diagram of P60 to P63

PM: Port mode register

RD: Port 6 read signal

WR: Port 6 write signal



Figure 4-18. Block Diagram of P64, P65, and P67

- PU6: Pull-up resistor option register 6
- PM: Port mode register
- RD: Port 6 read signal
- WR: Port 6 write signal

Figure 4-19. Block Diagram of P66



- PU6: Pull-up resistor option register 6
- PM: Port mode register
- RD: Port 6 read signal
- WR: Port 6 write signal

# 4.2.8 Port 7

Port 7 is an 8-bit I/O port with an output latch. Port 7 can be set to the input mode or output mode in 1-bit units using port mode register 7 (PM7). When the P70 to P77 pins are used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 7 (PU7).

This port can also be used for key return input.

RESET input sets port 7 to input mode.

Figure 4-20 shows a block diagram of port 7.





- PU7: Pull-up resistor option register 7
- PM: Port mode register
- RD: Port 7 read signal
- WR: Port 7 write signal

# 4.2.9 Port 12

Port 12 is a 1-bit I/O port with an output latch. Port 12 can be set to the input mode or output mode in 1-bit units using port mode register 12 (PM12). When used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 12 (PU12).

This port can also be used for external interrupt input.

RESET input sets port 12 to input mode.

Figure 4-21 shows a block diagram of port 12.





- PU12: Pull-up resistor option register 12
- PM: Port mode register
- RD: Port 12 read signal
- WR: Port 12 write signal

# 4.2.10 Port 13

Port 13 is a 1-bit output-only port.

Figure 4-22 shows a block diagram of port 13.





RD: Port 13 read signal

WD: Port 13 write signal

# 4.2.11 Port 14

Port 14 is a 6-bit I/O port with an output latch. Port 14 can be set to the input mode or output mode in 1-bit units using port mode register 14 (PM14). When the P140 to P145 pins are used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 14 (PU14).

This port can also be used for external interrupt request input, serial interface data I/O, clock I/O, busy input, buzzer output, and clock output.

RESET input sets port 14 to input mode.

Figures 4-23 to 4-26 show block diagrams of port 14.



Figure 4-23. Block Diagram of P140 and P141

- PU14: Pull-up resistor option register 14
- PM: Port mode register
- RD: Port 14 read signal
- WR: Port 14 write signal

Figure 4-24. Block Diagram of P142



- PU14: Pull-up resistor option register 14
- PM: Port mode register
- RD: Port 14 read signal
- WR: Port 14 write signal



Figure 4-25. Block Diagram of P143

- PU14: Pull-up resistor option register 14
- PM: Port mode register
- RD: Port 14 read signal
- WR: Port 14 write signal



Figure 4-26. Block Diagram of P144 and P145

- PU14: Pull-up resistor option register 14
- PM: Port mode register
- RD: Port 14 read signal
- WR: Port 14 write signal

# 4.3 Registers Controlling Port Function

Port functions are controlled by the following three types of registers.

- Port mode registers (PM0, PM1, PM3 to PM7, PM12, PM14)
- Pull-up resistor option registers (PU0, PU1, PU3 to PU7, PU12, PU14)
- Input switch control register (ISC)

## (1) Port mode registers (PM0, PM1, PM3 to PM7, PM12, and PM14)

These registers specify input or output mode for the port in 1-bit units.

These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets these registers to FFH.

When port pins are used as alternate-function pins, set the port mode register and output latch as shown in Table 4-4.

| Symbol | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     | Address | After reset | R/W |
|--------|------|------|-------|-------|-------|-------|-------|-------|---------|-------------|-----|
| PM0    | 1    | PM06 | PM05  | PM04  | PM03  | PM02  | PM01  | PM00  | FF20H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM1    | PM17 | PM16 | PM15  | PM14  | PM13  | PM12  | PM11  | PM10  | FF21H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM3    | 1    | 1    | 1     | 1     | PM33  | PM32  | PM31  | PM30  | FF23H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM4    | PM47 | PM46 | PM45  | PM44  | PM43  | PM42  | PM41  | PM40  | FF24H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM5    | PM57 | PM56 | PM55  | PM54  | PM53  | PM52  | PM51  | PM50  | FF25H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM6    | PM67 | PM66 | PM65  | PM64  | PM63  | PM62  | PM61  | PM60  | FF26H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       | -       |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM7    | PM77 | PM76 | PM75  | PM74  | PM73  | PM72  | PM71  | PM70  | FF27H   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM12   | 1    | 1    | 1     | 1     | 1     | 1     | 1     | PM120 | FF2CH   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PM14   | 1    | 1    | PM145 | PM144 | PM143 | PM142 | PM141 | PM140 | FF2EH   | FFH         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        |      | Т    |       |       |       |       |       |       |         |             |     |

# Figure 4-27. Format of Port Mode Register

| PMmn | Pmn pin I/O mode selection<br>(m = 0, 1, 3 to 7, 12, 14; n = 0 to 7) |
|------|----------------------------------------------------------------------|
| 0    | Output mode (output buffer on)                                       |
| 1    | Input mode (output buffer off)                                       |

| Pin Name   | Alternate Function    |        | PM×× | P×× |
|------------|-----------------------|--------|------|-----|
|            | Function Name         | I/O    |      |     |
| P00        | TI000                 | Input  | 1    | ×   |
| P01        | TI010                 | Input  | 1    | ×   |
|            | TO00                  | Output | 0    | 0   |
| P02        | SO11 <sup>Note</sup>  | Output | 0    | 0   |
| P03        | SI11 <sup>Note</sup>  | Input  | 1    | ×   |
| P04        | SCK11 <sup>Note</sup> | Input  | 1    | ×   |
|            |                       | Output | 0    | 1   |
| P05        | SSI11 <sup>Note</sup> | Input  | 1    | ×   |
|            | TI001 <sup>Note</sup> | Input  | 1    | ×   |
| P06        | TI011 <sup>Note</sup> | Input  | 1    | ×   |
|            | TO01 <sup>Note</sup>  | Output | 0    | 0   |
| P10        | SCK10                 | Input  | 1    | ×   |
|            |                       | Output | 0    | 1   |
|            | TxD0                  | Output | 0    | 1   |
| P11        | SI10                  | Input  | 1    | ×   |
|            | RxD0                  | Input  | 1    | ×   |
| P12        | SO10                  | Output | 0    | 0   |
| P13        | TxD6                  | Output | 0    | 1   |
| P14        | RxD6                  | Input  | 1    | ×   |
| P15        | ТОНО                  | Output | 0    | 0   |
| P16        | ТОН1                  | Output | 0    | 0   |
|            | INTP5                 | Input  | 1    | ×   |
| P17        | TI50                  | Input  | 1    | ×   |
|            | TO50                  | Output | 0    | 0   |
| P30 to P32 | INTP1 to INTP3        | Input  | 1    | ×   |
| P33        | INTP4                 | Input  | 1    | ×   |
|            | TI51                  | Input  | 1    | ×   |
|            | TO51                  | Output | 0    | 0   |
| P40 to P47 | AD0 to AD7            | Input  | 1    | ×   |
|            |                       | Output | 0    | 0   |
| P50 to P57 | A8 to A15             | Output | 0    | 0   |

# Table 4-4. Settings of Port Mode Register and Output Latch When Using Alternate Function (1/2)

Note SO11, SI11, SCK11, SSI11, TI001, TI011, and TO01 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

**Remark** ×: Don't care

PM××: Port mode register

Pxx: Port output latch

| Pin Name   | Alternate Function |        | PM×× | P×× |
|------------|--------------------|--------|------|-----|
|            | Function Name      | I/O    |      |     |
| P64        | RD                 | Output | 0    | 0   |
| P65        | WR                 | Output | 0    | 0   |
| P66        | WAIT               | Input  | 1    | ×   |
| P67        | ASTB               | Output | 0    | 0   |
| P70 to P77 | KR0 to KR7         | Input  | 1    | ×   |
| P120       | INTP0              | Input  | 1    | ×   |
| P140       | PCL                | Output | 0    | 0   |
|            | INTP6              | Input  | 1    | ×   |
| P141       | BUZ                | Output | 0    | 0   |
|            | BUSY0              | Input  | 1    | ×   |
|            | INTP7              | Input  | 1    | ×   |
| P142       | SCKAO              | Input  | 1    | ×   |
|            |                    | Output | 0    | 1   |
| P143       | SIA0               | Input  | 1    | ×   |
| P144       | SOA0               | Output | 0    | 0   |
| P145       | STB0               | Output | 0    | 0   |

# Table 4-4. Settings of Port Mode Register and Output Latch When Using Alternate Function (2/2)

Remark ×: Don't care

PM xx: Port mode register

Pxx: Port output latch

## (2) Pull-up resistor option registers (PU0, PU1, PU3 to PU7, PU12, and PU14)

These registers specify whether the on-chip pull-up resistors of P00 to P06, P10 to P17, P30 to P33, P40 to P47, P50 to P57, P64 to P67, P70 to P77, P120, or P140 to P145 are to be used or not. On-chip pull-up resistors can be used in 1-bit units only for the bits set to input mode of the pins to which the use of an on-chip pull-up resistor has been specified. On-chip pull-up resistors cannot be used for bits set to output mode and bits used as alternate-function output pins, regardless of the settings of PU0, PU1, PU3 to PU7, PU12, and PU14. These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears these registers to 00H.

# Caution Use of a pull-up resistor can be specified for P60 to P63 pins by a mask option only in the mask ROM versions.

| Symbol | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     | Address | After reset | R/W |
|--------|------|------|-------|-------|-------|-------|-------|-------|---------|-------------|-----|
| PU0    | 0    | PU06 | PU05  | PU04  | PU03  | PU02  | PU01  | PU00  | FF30H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU1    | PU17 | PU16 | PU15  | PU14  | PU13  | PU12  | PU11  | PU10  | FF31H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU3    | 0    | 0    | 0     | 0     | PU33  | PU32  | PU31  | PU30  | FF33H   | 00H         | R/W |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU4    | PU47 | PU46 | PU45  | PU44  | PU43  | PU42  | PU41  | PU40  | FF34H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU5    | PU57 | PU56 | PU55  | PU54  | PU53  | PU52  | PU51  | PU50  | FF35H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU6    | PU67 | PU66 | PU65  | PU64  | 0     | 0     | 0     | 0     | FF36H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU7    | PU77 | PU76 | PU75  | PU74  | PU73  | PU72  | PU71  | PU70  | FF37H   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     |         |             |     |
| PU12   | 0    | 0    | 0     | 0     | 0     | 0     | 0     | PU120 | FF3CH   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     | 1       |             |     |
| PU14   | 0    | 0    | PU145 | PU144 | PU143 | PU142 | PU141 | PU140 | FF3EH   | 00H         | R/W |
|        |      |      |       |       |       |       |       |       |         |             |     |
|        |      |      |       |       |       |       |       |       |         |             |     |

#### Figure 4-28. Format of Pull-up Resistor Option Register

| PUmn | Pmn pin on-chip pull-up resistor selection<br>(m = 0, 1, 3 to 7, 12, 14; n = 0 to 7) |
|------|--------------------------------------------------------------------------------------|
| 0    | On-chip pull-up resistor not connected                                               |
| 1    | On-chip pull-up resistor connected                                                   |

# (3) Input switch control register (ISC)

This register is used to receive a status signal transmitted from the master during LIN (Local Interconnect Network) reception. The input signal is switched by setting ISC.

For the port configuration during LIN reception, refer to Figure 15-3 Port Configuration for LIN Reception Operation in CHAPTER 15 SERIAL INTERFACE UART6.

This register can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

## Figure 4-29. Format of Input Switch Control Register (ISC)

Address: FF4FH After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|--------|---|---|---|---|---|---|------|------|
| ISC    | 0 | 0 | 0 | 0 | 0 | 0 | ISC1 | ISC0 |

| ISC1 | Input signal selection |
|------|------------------------|
| 0    | TI000 input            |
| 1    | RxD6 input             |

| ISC0 | Input signal selection |
|------|------------------------|
| 0    | INTP0 input            |
| 1    | RxD6 input             |

## 4.4 Port Function Operations

Port operations differ depending on whether the input or output mode is set, as shown below.

### 4.4.1 Writing to I/O port

#### (1) Output mode

A value is written to the output latch by a transfer instruction, and the output latch contents are output from the pin.

Once data is written to the output latch, it is retained until data is written to the output latch again.

#### (2) Input mode

A value is written to the output latch by a transfer instruction, but since the output buffer is off, the pin status does not change.

Once data is written to the output latch, it is retained until data is written to the output latch again.

Caution In the case of 1-bit memory manipulation instruction, although a single bit is manipulated, the port is accessed as an 8-bit unit. Therefore, on a port with a mixture of input and output pins, the output latch contents for pins specified as input are undefined even for bits other than the manipulated bit.

## 4.4.2 Reading from I/O port

#### (1) Output mode

The output latch contents are read by a transfer instruction. The output latch contents do not change.

#### (2) Input mode

The pin status is read by a transfer instruction. The output latch contents do not change.

### 4.4.3 Operations on I/O port

#### (1) Output mode

An operation is performed on the output latch contents, and the result is written to the output latch. The output latch contents are output from the pins.

Once data is written to the output latch, it is retained until data is written to the output latch again.

#### (2) Input mode

The output latch contents are undefined, but since the output buffer is off, the pin status does not change.

Caution In the case of 1-bit memory manipulation instruction, although a single bit is manipulated, the port is accessed as an 8-bit unit. Therefore, on a port with a mixture of input and output pins, the output latch contents for pins specified as input are undefined, even for bits other than the manipulated bit.

# CHAPTER 5 EXTERNAL BUS INTERFACE

# 5.1 External Bus Interface

The external bus interface connects external devices to areas other than the internal ROM, RAM, and SFR areas. Connection of external devices uses ports 4 to 6. Ports 4 to 6 control address/data, read/write strobe, wait, address strobe, etc.

The external bus interface is usable only when the X1 clock is selected as the CPU clock.

| Pin Func   | tion When External Device Is Connected | Alternate Function |
|------------|----------------------------------------|--------------------|
| Name       | Function                               |                    |
| AD0 to AD7 | Multiplexed address/data bus           | P40 to P47         |
| A8 to A15  | Address bus                            | P50 to P57         |
| RD         | Read strobe signal                     | P64                |
| WR         | Write strobe signal                    | P65                |
| WAIT       | Wait signal                            | P66                |
| ASTB       | Address strobe signal                  | P67                |

#### Table 5-1. Pin Functions in External Memory Expansion Mode

## Table 5-2. State of Ports 4 to 6 Pins in External Memory Expansion Mode

| External                | Port 4       |      |      |   | Po | rt 5 |   |      |   |      |   |   | Po | rt 6 |       |         |      |
|-------------------------|--------------|------|------|---|----|------|---|------|---|------|---|---|----|------|-------|---------|------|
| Expansion Mode          | 0 to 7       | 0    | 1    | 2 | 3  | 4    | 5 | 6    | 7 | 0    | 1 | 2 | 3  | 4    | 5     | 6       | 7    |
| Single-chip mode        | Port         | Port |      |   |    |      |   |      |   | Port |   |   |    |      |       |         |      |
| 256-byte expansion mode | Address/data | Port |      |   |    |      |   |      |   | Port |   |   |    | RD,  | WR, V | VAIT, A | ASTB |
| 4 KB expansion mode     | Address/data | Add  | ress |   |    | Port |   |      |   | Port |   |   |    | RD,  | WR, V | VAIT,   | ASTB |
| 16 KB expansion mode    | Address/data | Add  | ress |   |    |      |   | Port | t | Port |   |   |    | RD,  | WR, V | VAIT, A | ASTB |
| Full-address mode       | Address/data | Add  | ress |   |    |      |   |      |   | Port |   |   |    | RD,  | WR, V | VAIT,   | ASTB |

Caution When the external wait function is not used, the WAIT pin can be used as a port in all modes.

The memory maps when the external bus interface is used are as follows.

# Figure 5-1. Memory Map When Using External Bus Interface (1/2)

- (a) Memory map of  $\mu$ PD780143 and of  $\mu$ PD78F0148 when internal ROM (flash memory) size is 24 KB
- (b) Memory map of  $\mu$ PD780144 and of  $\mu$ PD78F0148 when internal ROM (flash memory) size is 32 KB

|                                                             |                                                                                                      | FFFFH                                     |                                                                                                                                                                 |
|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FF00H                                                       | SFR                                                                                                  | FF00H<br>FEFFH                            | SFR                                                                                                                                                             |
|                                                             | Internal high-speed RAM                                                                              |                                           | Internal high-speed RA                                                                                                                                          |
| FB00H<br>FAFFH                                              |                                                                                                      | FB00H<br>FAFFH                            |                                                                                                                                                                 |
| FA20H                                                       | Reserved                                                                                             | FA20H                                     | Reserved                                                                                                                                                        |
| FA1FH                                                       | Buffer RAM                                                                                           | FA1FH                                     | Buffer RAM                                                                                                                                                      |
| FA00H                                                       |                                                                                                      | FA00H<br>F9FFH                            |                                                                                                                                                                 |
| F800H                                                       | Reserved                                                                                             | F800H<br>F7FFH                            | Reserved                                                                                                                                                        |
| $\widehat{}$                                                | Full-address mode<br>(when MM2 to MM0 = 111)                                                         | С000Н                                     | Full-address mode<br>(when MM2 to MM0 = 1                                                                                                                       |
|                                                             |                                                                                                      | BFFFH                                     |                                                                                                                                                                 |
|                                                             |                                                                                                      | BFFFH                                     |                                                                                                                                                                 |
|                                                             | 16 KB expansion mode<br>(when MM2 to MM0 = 101)                                                      | BFFFH<br>9000H<br>8FFFH                   |                                                                                                                                                                 |
| 9FFFH                                                       |                                                                                                      | 9000Н                                     | (when MM2 to MM0 = <sup>-</sup><br>4 KB expansion mod                                                                                                           |
| 9FFFH<br>7000H<br>6FFFH                                     |                                                                                                      | 9000Н                                     | (when MM2 to MM0 =<br>4 KB expansion mod<br>(when MM2 to MM0 =<br>256-byte expansion mo                                                                         |
| 9FFFH<br>7000H<br>6FFFH<br>6100H                            | (when MM2 to MM0 = 101)<br>4 KB expansion mode<br>(when MM2 to MM0 = 100)<br>256-byte expansion mode | 9000H<br>8FFFH<br>8100H                   | (when MM2 to MM0 =<br>4 KB expansion mod<br>(when MM2 to MM0 =<br>256-byte expansion mod                                                                        |
| A000H<br>9FFFH<br>7000H<br>6FFFH<br>60FFH<br>600FH<br>5FFFH | (when MM2 to MM0 = 101)<br>4 KB expansion mode<br>(when MM2 to MM0 = 100)                            | 9000H<br>8FFFH<br>8100H<br>80FFH<br>8000H | 16 KB expansion mod<br>(when MM2 to MM0 = 1<br>4 KB expansion mod<br>(when MM2 to MM0 = 1<br>256-byte expansion mod<br>(when MM2 to MM0 = 0<br>Single-chip mode |



Figure 5-1. Memory Map When Using External Bus Interface (2/2)

- (c) Memory map of  $\mu$ PD780146 and of  $\mu$ PD78F0148 when internal ROM (flash memory) size is 48 KB
- (d) Memory map of μPD780148 and of μPD78F0148
   when internal ROM (flash memory) size is 60 KB





## 5.2 Registers Controlling External Bus Interface

The external bus interface is controlled by the following two registers.

- Memory expansion mode register (MEM)
- Memory expansion wait setting register (MM)

#### (1) Memory expansion mode register (MEM)

MEM sets the external expansion area. MEM is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets MEM to 00H.

#### Figure 5-2. Format of Memory Expansion Mode Register (MEM)

Address: FF47H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|--------|---|---|---|---|---|-----|-----|-----|
| MEM    | 0 | 0 | 0 | 0 | 0 | MM2 | MM1 | MM0 |

| MM2                             | MM1 | MMO | Single-chip/memory  |                                      |               |            |           | to P67 pin | state                                       |
|---------------------------------|-----|-----|---------------------|--------------------------------------|---------------|------------|-----------|------------|---------------------------------------------|
|                                 |     |     | expansion m         | ode selection                        | P40 to P47    | P50 to P53 | P54, P55  | P56, P57   | P64 to P67                                  |
| 0                               | 0   | 0   | Single-chip         | mode                                 | Port mode     |            |           |            |                                             |
| 0                               | 1   | 1   | Memory<br>expansion | 256-byte<br>mode                     | AD0 to<br>AD7 | Port mode  |           |            | $P64 = \overline{RD}$ $P65 = \overline{WR}$ |
| 1                               | 0   | 0   | mode                | 4 KB<br>mode                         |               | A8 to A11  | Port mode |            | P66 = WAIT<br>P67 = ASTB                    |
| 1                               | 0   | 1   |                     | 16 KB<br>mode                        |               |            | A12, A13  | Port mode  |                                             |
| 1                               | 1   | 1   |                     | Full-address<br>mode <sup>Note</sup> |               |            |           | A14, A15   |                                             |
| Other than above Setting prohib |     |     | hibited             |                                      |               |            |           |            |                                             |

**Note** The full-address mode allows external expansion to the entire 64 KB address space except for the internal ROM, RAM, SFR areas and the reserved areas.

## (2) Memory expansion wait setting register (MM)

MM sets the number of waits.

MM is set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets MM to 10H.

#### Figure 5-3. Format of Memory Expansion Wait Setting Register (MM)

| Address: FF | F8H After | reset: 10H | R/W |     |   |   |   |   |
|-------------|-----------|------------|-----|-----|---|---|---|---|
| Symbol      | 7         | 6          | 5   | 4   | 3 | 2 | 1 | 0 |
| MM          | 0         | 0          | PW1 | PW0 | 0 | 0 | 0 | 0 |

| PW1 | PW0 | Wait control                      |
|-----|-----|-----------------------------------|
| 0   | 0   | No wait                           |
| 0   | 1   | Wait (one wait state inserted)    |
| 1   | 0   | Setting prohibited                |
| 1   | 1   | Wait control by external wait pin |

Caution To control wait with external wait pin, be sure to set WAIT/P66 pin to input mode (set bit 6 (PM66) of port mode register 6 (PM6) to 1).

# 5.3 External Bus Interface Function Timing

Timing control signal output pins in the external memory expansion mode are as follows.

## (1) RD pin (Alternate function: P64)

Read strobe signal output pin. The read strobe signal is output in data access and instruction fetch from external memory.

During internal memory access, the read strobe signal is not output (maintains high level).

## (2) WR pin (Alternate function: P65)

Write strobe signal output pin. The write strobe signal is output in data access to external memory. During internal memory access, the write strobe signal is not output (maintains high level).

## (3) WAIT pin (Alternate function: P66)

External wait signal input pin. When the external wait is not used, the  $\overline{\text{WAIT}}$  pin can be used as an I/O port. During internal memory access, the external wait signal is ignored.

## (4) ASTB pin (Alternate function: P67)

Address strobe signal output pin. The address strobe signal is output regardless of data access and instruction fetch from external memory.

During internal memory access, the address strobe signal is output.

## (5) AD0 to AD7, A8 to A15 pins (Alternate function: P40 to P47, P50 to P57)

Address/data signal output pins. Valid signal is output or input during data accesses and instruction fetches from external memory.

These signals change even during internal memory access (output values are undefined).

The timing charts are shown in Figures 5-4 to 5-7.





Preliminary User's Manual U15947EJ1V1UD

WAIT



## Figure 5-5. External Memory Read Timing



(a) No wait (PW1, PW0 = 0, 0) setting





Figure 5-7. External Memory Read Modify Write Timing

# 5.4 Example of Connection with Memory

An example of connecting the  $\mu$ PD780143 with external memory (in this example, SRAM) is shown in Figure 5-8. In addition, the external bus interface function is used in the full-address mode, and the addresses from 0000H to 7FFFH (32 KB) are allocated to internal ROM, and the addresses after 8000H to SRAM.



Figure 5-8. Connection Example of µPD780143 and Memory

# CHAPTER 6 CLOCK GENERATOR

# 6.1 Functions of Clock Generator

The clock generator generates the clock to be supplied to the CPU and peripheral hardware. The following three system clock oscillators are available.

• X1 oscillator

The X1 oscillator oscillates a clock of 2.0 to 10.0 MHz. Oscillation can be stopped by executing the STOP instruction or setting the main OSC control register (MOC) and processor clock control register (PCC).

Ring-OSC oscillator

The Ring-OSC oscillator oscillates a clock of 240 kHz (TYP.). Oscillation can be stopped by setting the Ring-OSC mode register (RCM) when "Can be stopped by software" is set by a mask option and the X1 input clock is used as the CPU clock.

Subsystem clock oscillator

The subsystem clock oscillator oscillates a clock of 32.768 kHz. Oscillation cannot be stopped. When subsystem clock oscillator is not used, setting not to use the on-chip feedback resistor is possible using the processor clock control register (PCC), and the power consumption can be reduced in the STOP mode.

# 6.2 Configuration of Clock Generator

The clock generator consists of the following hardware.

| Item              | Configuration                                                                                                                                                                                                                                                         |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Control registers | Processor clock control register (PCC)<br>Ring-OSC mode register (RCM)<br>Main clock mode register (MCM)<br>Main OSC control register (MOC)<br>Oscillation stabilization time counter status register (OSTC)<br>Oscillation stabilization time select register (OSTS) |
| Oscillator        | X1 oscillator<br>Ring-OSC oscillator<br>Subsystem clock oscillator                                                                                                                                                                                                    |

## Table 6-1. Configuration of Clock Generator



## Figure 6-1. Block Diagram of Clock Generator

## 6.3 Registers Controlling Clock Generator

The following six registers are used to control the clock generator.

- Processor clock control register (PCC)
- Ring-OSC mode register (RCM)
- Main clock mode register (MCM)
- Main OSC control register (MOC)
- Oscillation stabilization time counter status register (OSTC)
- Oscillation stabilization time select register (OSTS)

## (1) Processor clock control register (PCC)

The PCC register is used to select the CPU clock, the division ratio, main system clock oscillator operation/stop and whether to use the on-chip feedback resistor of the subsystem clock oscillator.

The PCC is set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears PCC to 00H.





## Figure 6-3. Format of Processor Clock Control Register (PCC)

| Address: FFFBH After reset: 00H |     |     | R/W <sup>Note 1</sup> |     |   |      |      |      |
|---------------------------------|-----|-----|-----------------------|-----|---|------|------|------|
| Symbol                          | 7   | 6   | 5                     | 4   | 3 | 2    | 1    | 0    |
| PCC                             | MCC | FRC | CLS                   | CSS | 0 | PCC2 | PCC1 | PCC0 |

| MCC | Control of X1 oscillator operation <sup>Note 2</sup> |
|-----|------------------------------------------------------|
| 0   | Oscillation possible                                 |
| 1   | Oscillation stopped                                  |

| FRC | Subsystem clock feedback resistor selection Note 3 |
|-----|----------------------------------------------------|
| 0   | On-chip feedback resistor used                     |
| 1   | On-chip feedback resistor not used                 |

| CLS | CPU clock status                 |
|-----|----------------------------------|
| 0   | X1 input clock or Ring-OSC clock |
| 1   | Subsystem clock                  |

| CSS <sup>Note 4</sup> | PCC2 | PCC1 | PCC0 | CPU Clock (fcPu) Selection |
|-----------------------|------|------|------|----------------------------|
| 0                     | 0    | 0    | 0    | fx                         |
|                       | 0    | 0    | 1    | fx/2                       |
|                       | 0    | 1    | 0    | fx/2 <sup>2</sup>          |
|                       | 0    | 1    | 1    | fx/2 <sup>3</sup>          |
|                       | 1    | 0    | 0    | fx/2 <sup>4</sup>          |
| 1                     | 0    | 0    | 0    | fxt/2                      |
|                       | 0    | 0    | 1    |                            |
|                       | 0    | 1    | 0    |                            |
|                       | 0    | 1    | 1    |                            |
|                       | 1    | 0    | 0    |                            |
| Other than a          | bove |      |      | Setting prohibited         |

## Notes 1. Bit 5 is read-only.

- 2. When the CPU is operating on the subsystem clock, MCC should be used to stop the X1 oscillator operation. When the CPU is operating on the Ring-OSC clock, use bit 7 (MSTOP) of the main OSC control register (MOC) to stop the X1 oscillator operation (this cannot be set by MCC). A STOP instruction should not be used.
- **3.** The feedback resistor is required to adjust the bias point of the oscillation waveform to close to the middle of the power supply voltage. Setting FRC to 1 can further reduce the current consumption in the STOP mode, but only when the subsystem clock is not used.
- 4. Be sure to switch CSS from 1 to 0 when bits 1 (MCS) and 0 (MCM0) of the main clock mode register (MCM) are 1.

# Caution Be sure to set bit 3 to 0.

- Remarks 1. fx: Main system clock oscillation frequency (X1 input clock oscillation frequency or Ring-OSC clock oscillation frequency)
  - **2.** fxT: Subsystem clock oscillation frequency

The fastest instruction can be executed in 2 clocks of the CPU clock in the 78K0/KF1 Series. Therefore, the relationship between the CPU clock (fcPu) and minimum instruction execution time is as shown in the Table 6-2.

| CPU Clock (fcpu)  | Minimum Instruction Execution Time: 2/fcPU              |                                                                |                                              |  |  |  |  |  |
|-------------------|---------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------|--|--|--|--|--|
|                   | X1 Input Clock <sup>Note</sup><br>(at 10 MHz Operation) | Ring-OSC Clock <sup>№0®</sup><br>(at 240 kHz (TYP.) Operation) | Subsystem Clock<br>(at 32.768 kHz Operation) |  |  |  |  |  |
| fx                | 0.2 μs                                                  | 8.3 μs (TYP.)                                                  | -                                            |  |  |  |  |  |
| fx/2              | 0.4 μs                                                  | 16.6 μs (TYP.)                                                 | -                                            |  |  |  |  |  |
| fx/2 <sup>2</sup> | 0.8 μs                                                  | 33.2 μs (TYP.)                                                 | -                                            |  |  |  |  |  |
| fx/2 <sup>3</sup> | 1.6 <i>μ</i> s                                          | 66.4 μs (TYP.)                                                 | -                                            |  |  |  |  |  |
| fx/2 <sup>4</sup> | 3.2 μs                                                  | 132.8 μs (TYP.)                                                | -                                            |  |  |  |  |  |
| fxt/2             | _                                                       | _                                                              | 122.1 μs                                     |  |  |  |  |  |

Table 6-2. Relationship Between CPU Clock and Minimum Instruction Execution Time

Note The main clock mode register (MCM) is used to set the CPU clock (X1 input clock/Ring-OSC clock) (see Figure 6-5).

## (2) Ring-OSC mode register (RCM)

This register sets the operation mode of Ring-OSC.

This register is valid when "Can be stopped by software" is set for Ring-OSC by a mask option, and the X1 input clock or subsystem clock is selected as the CPU clock. If "Cannot be stopped" is selected for Ring-OSC by a mask option, settings for this register are invalid.

RCM can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

#### Figure 6-4. Format of Ring-OSC Mode Register (RCM)

| Address: FFA0H | After reset: | 00H | R/W |
|----------------|--------------|-----|-----|
|----------------|--------------|-----|-----|

Syr

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|--------|---|---|---|---|---|---|---|-------|
| RCM    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | RSTOP |

| RSTOP | Ring-OSC oscillating/stopped |  |  |  |  |
|-------|------------------------------|--|--|--|--|
| 0     | Ring-OSC oscillating         |  |  |  |  |
| 1     | Ring-OSC stopped             |  |  |  |  |

Caution Make sure that the bit 1 (MCS) of the main clock mode register (MCM) is 1 before setting RSTOP.

## (3) Main clock mode register (MCM)

This register sets the CPU clock (X1 input clock/Ring-OSC clock). MCM can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

#### Figure 6-5. Format of Main Clock Mode Register (MCM)

| Address: FFA1H After reset: 00H |   |   | R/W |   |   |   |     |      |
|---------------------------------|---|---|-----|---|---|---|-----|------|
| Symbol                          | 7 | 6 | 5   | 4 | 3 | 2 | 1   | 0    |
| MCM                             | 0 | 0 | 0   | 0 | 0 | 0 | MCS | MCM0 |
|                                 |   |   |     |   |   |   |     |      |

| MCS | CPU clock status             |  |  |  |  |  |
|-----|------------------------------|--|--|--|--|--|
| 0   | Operates with Ring-OSC clock |  |  |  |  |  |
| 1   | Operates with X1 input clock |  |  |  |  |  |

| MCM0 | Selection of clock supplied to CPU |  |  |  |  |
|------|------------------------------------|--|--|--|--|
| 0    | Ring-OSC clock                     |  |  |  |  |
| 1    | X1 input clock                     |  |  |  |  |

Cautions 1. When Ring-OSC clock is selected as the clock to be supplied to the CPU, the divided clock of the Ring-OSC oscillator output (fx) is supplied to the peripheral hardware (fx = 240 kHz (TYP.)).

Operation of the peripheral hardware with Ring-OSC clock cannot be guaranteed. Therefore, when Ring-OSC clock is selected as the clock supplied to the CPU, do not use peripheral hardware. In addition, stop the peripheral hardware before switching the clock supplied to the CPU from the X1 input clock to the Ring-OSC clock. Note, however, that the following peripheral hardware can be used when the CPU operates on the Ring-OSC clock.

- Watchdog timer
- Clock monitor
- 8-bit timer H1 when f<sub>R</sub>/2<sup>7</sup> is selected as count clock
- Peripheral hardware selecting external clock as the clock source (Except when external count clock of TM0n (n = 0, 1) is selected (TI00n valid edge))
- 2. Set MCS = 1 and MCM0 = 1 before switching subsystem clock operation to X1 input clock operation (bit 4 (CSS) of the processor clock control register (PCC) is changed from 1 to 0).

# (4) Main OSC control register (MOC)

This register selects the operation mode of the X1 input clock.

This register is used to stop the X1 oscillator operation when the CPU is operating with the Ring-OSC clock. Therefore, this register is valid only when the CPU is operating with the Ring-OSC clock.

MOC can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

# Figure 6-6. Format of Main OSC Control Register (MOC)



| MSTOP | Control of X1 oscillator operation |  |  |  |  |  |
|-------|------------------------------------|--|--|--|--|--|
| 0     | X1 oscillator operating            |  |  |  |  |  |
| 1     | X1 oscillator stopped              |  |  |  |  |  |

- Cautions 1. Make sure that bit 1 (MCS) of the main clock mode register (MCM) is 0 before setting MSTOP.
  - 2. To stop X1 oscillation during operation with the subsystem clock, set bit 7 (MCC) of the processor clock control register (PCC) to 1 (setting by MSTOP is not possible).

# (5) Oscillation stabilization time counter status register (OSTC)

This is the status register of the X1 input clock oscillation stabilization time counter. If the Ring-OSC clock is used as the CPU clock, the X1 input clock oscillation stabilization time can be checked.

OSTC can be read by a 1-bit or 8-bit memory manipulation instruction.

6

**RESET** input, STOP instruction, MSTOP = 1, and MCC = 1 clear OSTC to 00H.

## Figure 6-7. Format of Oscillation Stabilization Time Counter Status Register (OSTC)

Address: FFA3H After reset: 00H R

7

Symbol OSTC

| 0   |     | 0      | 0      | MOST11 | MOST13 | MOST14                                                | MOST15                 | MOST16 |
|-----|-----|--------|--------|--------|--------|-------------------------------------------------------|------------------------|--------|
|     |     |        |        |        |        |                                                       |                        |        |
| MOS | T11 | MOST13 | MOST14 | MOST15 | MOST16 | Oscillation stabilization time status                 |                        |        |
| 1   |     | 0      | 0      | 0      | 0      | 2 <sup>11</sup> /fxp min. (2                          | 204.8 <i>µ</i> s min.) | )      |
| 1   |     | 1      | 0      | 0      | 0      | 2 <sup>13</sup> /fx <sub>P</sub> min. (819.2 μs min.) |                        |        |
| 1   |     | 1      | 1      | 0      | 0      | 2 <sup>14</sup> /fx <sup>p</sup> min. (1.64 ms min.)  |                        |        |
| 1   |     | 1      | 1      | 1      | 0      | 2 <sup>15</sup> /fxp min. (3.27 ms min.)              |                        |        |
| 1   |     | 1      | 1      | 1      | 1      | 2 <sup>16</sup> /fxp min. (6.55 ms min.)              |                        |        |

3

Caution After the above time has elapsed, the bits are set to 1 in order from MOST11 and remain 1.

**Remarks 1.** Values in parentheses are for operation with  $f_{XP} = 10$  MHz.

2. fxp: X1 input clock oscillation frequency

5

## (6) Oscillation stabilization time select register (OSTS)

This register is used to select the X1 oscillation stabilization wait time when STOP mode is released. The wait time set by OSTS is valid only after STOP mode is released with the X1 input clock selected as CPU clock. After STOP mode is released with Ring-OSC selected as CPU clock, the oscillation stabilization time must be confirmed by OSTC.

OSTS can be set by an 8-bit memory manipulation instruction.

RESET input sets OSTS to 05H.

## Figure 6-8. Format of Oscillation Stabilization Time Select Register (OSTS)

| Address: F | FA4H Afte | er reset: 05H | R/W |   |   |       |       |       |
|------------|-----------|---------------|-----|---|---|-------|-------|-------|
| Symbol     | 7         | 6             | 5   | 4 | 3 | 2     | 1     | 0     |
| OSTS       | 0         | 0             | 0   | 0 | 0 | OSTS2 | OSTS1 | OSTS0 |

| OSTS2 | OSTS1         | OSTS0 | Oscillation stabilization time selection    |  |  |  |
|-------|---------------|-------|---------------------------------------------|--|--|--|
| 0     | 0             | 1     | 2 <sup>11</sup> /fx <sub>P</sub> (204.8 μs) |  |  |  |
| 0     | 1             | 0     | 2 <sup>13</sup> /fx <sub>P</sub> (819.2 μs) |  |  |  |
| 0     | 1             | 1     | 2 <sup>14</sup> /fx <sub>P</sub> (1.64 ms)  |  |  |  |
| 1     | 0             | 0     | 2 <sup>15</sup> /fxp (3.27 ms)              |  |  |  |
| 1     | 0             | 1     | 2 <sup>16</sup> /fxp (6.55 ms)              |  |  |  |
| 0     | ther than abo | ve    | Setting prohibited                          |  |  |  |

Cautions 1. If the STOP mode is entered and then released while the Ring-OSC clock is being used as the CPU clock, set the oscillation stabilization time as follows.

• Desired OSTC oscillation stabilization time ≤ Oscillation stabilization time set by OSTS

The X1 oscillation stabilization time counter counts up to the oscillation stabilization time set by OSTS. Note, therefore, that only the status up to the oscillation stabilization time set by OSTS is set to OSTC after STOP mode is released.

2. The wait time when STOP mode is released does not include the time after STOP mode release until clock oscillation starts ("a" below) regardless of whether STOP mode is released by **RESET** input or interrupt generation.



- **Remarks 1.** Values in parentheses are for operation with  $f_{XP} = 10$  MHz.
  - **2.** fxP: X1 input clock oscillation frequency

## 6.4 System Clock Oscillator

#### 6.4.1 X1 oscillator

The X1 oscillator oscillates with a crystal resonator or ceramic resonator (Standard: 8.38 MHz, 10 MHz when REGC pin is directly connected to VDD) connected to the X1 and X2 pins.

An external clock can be input to the X1 oscillator when the REGC pin is directly connected to  $V_{DD}$ . In this case, input the clock signal to the X1 pin and input the inverse signal to the X2 pin.

Figure 6-9 shows the external circuit of the X1 oscillator.

#### Figure 6-9. External Circuit of X1 Oscillator







#### 6.4.2 Subsystem clock oscillator

The subsystem clock oscillator oscillates with a crystal resonator (Standard: 32.768 kHz) connected to the XT1 and XT2 pins.

External clocks can be input to the subsystem clock oscillator when the REGC pin is directly connected to  $V_{DD}$ . In this case, input the clock signal to the XT1 pin and the inverse signal to the XT2 pin.

Figure 6-10 shows an external circuit of the subsystem clock oscillator.



# (a) Crystal oscillation







Cautions are listed on the next page.

- Cautions 1. When using the X1 oscillator and subsystem clock oscillator, wire as follows in the area enclosed by the broken lines in the Figure 6-11 to avoid an adverse effect from wiring capacitance.
  - Keep the wiring length as short as possible.
  - Do not cross the wiring with the other signal lines.
  - Do not route the wiring near a signal line through which a high fluctuating current flows.
  - Always make the ground point of the oscillator capacitor the same potential as Vss. Do not ground the capacitor to a ground pattern through which a high current flows.
  - Do not fetch signals from the oscillator.

Note that the subsystem clock oscillator is designed as a low-amplitude circuit for reducing current consumption.

Figure 6-11 shows examples of incorrect resonator connection.



## Figure 6-11. Examples of Incorrect Resonator Connection (1/2)

**Remark** When using the subsystem clock, replace X1 and X2 with XT1 and XT2, respectively. Also, insert resistors in series on the XT2 side.

Figure 6-11. Examples of Incorrect Resonator Connection (2/2)

- (c) Wiring near high alternating current
- (d) Current flowing through ground line of oscillator (potential at points A, B, and C fluctuates)





(e) Signals are fetched



- **Remark** When using the subsystem clock, replace X1 and X2 with XT1 and XT2, respectively. Also, insert resistors in series on the XT2 side.
- Cautions 2. When X2 and XT1 are wired in parallel, the crosstalk noise of X2 may increase with XT1, resulting in malfunctioning. To prevent that from occurring, it is recommended to wire X2 and XT1 so that they are not in parallel, and to connect the IC pin between X2 and XT1 directly to Vss.

#### 6.4.3 When subsystem clock is not used

If it is not necessary to use the subsystem clock for low power consumption operations and watch operations, connect the XT1 and XT2 pins as follows.

XT1: Connect to EVDD or VDD

XT2: Leave open

In this state, however, some current may leak via the on-chip feedback resistor of the subsystem clock oscillator when the X1 input clock and Ring-OSC clock stop. To minimize leakage current, the above on-chip feedback resistor can be set not to be used via bit 6 (FRC) of the processor clock control register (PCC). In this case also, connect the XT1 and XT2 pins as described above.

#### 6.4.4 Ring-OSC oscillator

Ring-OSC oscillator is incorporated in the  $\mu$ PD780143, 780144, 780146, 780148, and 78F0148.

"Can be stopped by software" or "Cannot be stopped" can be selected by a mask option. The Ring-OSC clock always oscillates after RESET release (240 kHz (TYP.)).

#### 6.4.5 Prescaler

The prescaler generates various clocks by dividing the X1 oscillator output (fx) when the X1 input clock is selected as the clock to be supplied to the CPU.

# Caution When the Ring-OSC clock is selected as the clock supplied to the CPU, the prescaler generates various clocks by dividing the Ring-OSC oscillator output (fx) (fx = 240 kHz (TYP.)).

## 6.5 Clock Generator Operation

The clock generator generates the following clocks and controls the operation modes of the CPU, such as standby mode.

- X1 input clock fxP
- Ring-OSC clock fr
- Subsystem clock fxT
- CPU clock fcpu
- Clock to peripheral hardware

The CPU starts operation when the on-chip Ring-OSC oscillator starts outputting after reset release in the 78K0/KF1 Series, thus enabling the following.

### (1) Enhancement of security function

When the X1 input clock is set as the CPU clock by the default setting, the device cannot operate if the X1 input clock is damaged or badly connected and therefore does not operate after reset is released. However, the start clock of the CPU is the on-chip Ring-OSC clock, so the device can be started by the Ring-OSC clock after reset release by the clock monitor (detection of X1 input clock stop). Consequently, the system can be safely shut down by performing a minimum operation, such as acknowledging a reset source by software or performing safety processing when there is a malfunction.

#### (2) Improvement of performance

Because the CPU can be started without waiting for the X1 input clock oscillation stabilization time, the total performance can be improved.

A timing diagram of the CPU default start using Ring-OSC is shown in Figure 6-12.





Note Check using the oscillation stabilization time counter status register (OSTC).

- (a) When the RESET signal is generated, bit 0 of the main clock mode register (MCM) is set to 0 and the Ring-OSC clock is set as the CPU clock. However, a clock is supplied to the CPU after 17 clocks of the Ring-OSC clock have elapsed after RESET release (or clock supply to the CPU stops for 17 clocks). During the RESET period, oscillation of the X1 input clock and Ring-OSC clock is stopped.
- (b) After RESET release, the CPU clock can be switched from the Ring-OSC clock to the X1 input clock using bit 0 (MCM0) of the main clock mode register (MCM) after the X1 input clock oscillation stabilization time has elapsed. At this time, check the oscillation stabilization time using the oscillation stabilization time counter status register (OSTC) before switching the CPU clock. The CPU clock status can be checked using bit 1 (MCS) of MCM.
- (c) Ring-OSC can be set to stopped/oscillating using the Ring-OSC mode register (RCM) when "Can be stopped by software" is selected for the Ring-OSC by a mask option, if the X1 input or subsystem clock is used as the CPU clock. Make sure that MCS is 1 at this time.
- (d) When Ring-OSC is used as the CPU clock, the X1 input clock can be set to stopped/oscillating using the main OSC control register (MOC). Make sure that MCS is 0 at this time.
   When the subsystem clock is used as the CPU clock, whether the X1 input clock stops or oscillates can be set by the processor clock control register (PCC). In addition, HALT mode can be used during operation with the subsystem clock, but STOP mode cannot be used (subsystem clock oscillation cannot be stopped by the STOP instruction).

(e) Select the X1 input clock oscillation stabilization time (2<sup>11</sup>/fxP, 2<sup>13</sup>/fxP, 2<sup>14</sup>/fxP, 2<sup>15</sup>/fxP, 2<sup>16</sup>/fxP) using the oscillation stabilization time select register (OSTS) when releasing STOP mode while X1 input clock is being used as the CPU clock. In addition, when releasing STOP mode while RESET is released and Ring-OSC clock is being used as the CPU clock, check the X1 input clock oscillation stabilization time using the oscillation stabilization time counter status register (OSTC).

A status transition diagram of this product is shown in Figure 6-13, and the relationship between the operation clocks in each operation status and between the oscillation control flag and oscillation status of each clock are shown in Tables 6-3 and 6-4, respectively.

#### Figure 6-13. Status Transition Diagram (1/4)



(1) When "Ring-OSC can be stopped by software" is selected by mask option (when subsystem clock is not used)

- Notes 1. When shifting from status 3 to status 4, make sure that bit 1 (MCS) of the main clock mode register (MCM) is 1.
  - 2. Before shifting from status 2 to status 3 after reset and STOP are released, check the X1 input clock oscillation stabilization time status using the oscillation stabilization time counter status register (OSTC).
  - 3. When shifting from status 2 to status 1, make sure that MCS is 0.
  - 4. When "Ring-OSC can be stopped by software" is selected by a mask option, the watchdog timer stops operating in the HALT and STOP modes, regardless of the source clock of the watchdog timer. However, oscillation of Ring-OSC does not stop even in the HALT and STOP modes if RSTOP = 0.
- 5. All reset sources (RESET input, POC, LVI, clock monitor, and WDT)

Figure 6-13. Status Transition Diagram (2/4)



(2) When "Ring-OSC can be stopped by software" is selected by mask option (when subsystem clock is used)

- Notes 1. When shifting from status 3 to status 4, make sure that bit 1 (MCS) of the main clock mode register (MCM) is 1.
  - Before shifting from status 2 to status 3 after reset and STOP are released, check the X1 input clock oscillation stabilization time status using the oscillation stabilization time counter status register (OSTC).
  - 3. When shifting from status 2 to status 1, make sure that MCS is 0.
  - 4. When "Ring-OSC can be stopped by software" is selected by a mask option, the Ring-OSC oscillator is stopped after the HALT or STOP instruction has been executed, regardless of the setting of bit 0 (RSTOP) of the Ring-OSC mode register (RCM) and bit 0 (MCM0) of the main clock mode register (MCM).
  - **5.** Shifting to status 5 (subsystem clock operation) can be performed only from status 3 or 4 (X1 input clock operation).
  - 6. Shifting to status 1 or status 2 from status 5 is not possible.
  - 7. All reset sources (RESET input, POC, LVI, clock monitor, and WDT)

#### Figure 6-13. Status Transition Diagram (3/4)



# (3) When "Ring-OSC cannot be stopped" is selected by mask option (when subsystem clock is not used)

- **Notes 1.** Before shifting from status 2 to status 3 after reset and STOP are released, check the X1 input clock oscillation stabilization time status using the oscillation stabilization time counter status register (OSTC).
  - 2. When shifting from status 2 to status 1, make sure that MCS is 0.
  - 3. The watchdog timer operates using Ring-OSC even in STOP mode if "Ring-OSC cannot be stopped" is selected by a mask option. Ring-OSC division can be selected as the count source of 8-bit timer H1 (TMH1), so clear the watchdog timer using the TMH1 interrupt request before watchdog timer overflow. If this processing is not performed, an internal reset signal is generated at watchdog timer overflow after STOP instruction execution.
  - 4. All reset sources (RESET input, POC, LVI, clock monitor, and WDT)

\*

Figure 6-13. Status Transition Diagram (4/4)



(4) When "Ring-OSC cannot be stopped" is selected by mask option (when subsystem clock is used)

- **Notes 1.** Before shifting from status 2 to status 3 after reset and STOP are released, check the X1 input clock oscillation stabilization time status using the oscillation stabilization time counter status register (OSTC).
  - 2. When shifting from status 2 to status 1, make sure that MCS is 0.
  - 3. The watchdog timer operates using Ring-OSC even in STOP mode if "Ring-OSC cannot be stopped" is selected by a mask option. Ring-OSC division can be selected as the count source of 8-bit timer H1 (TMH1), so clear the watchdog timer using the TMH1 interrupt request before watchdog timer overflow. If this processing is not performed, an internal reset signal is generated at watchdog timer overflow after STOP instruction execution.
  - Shifting to status 4 (subsystem clock operation) can be performed only from status 3 (X1 input clock operation).
  - 5. Shifting to status 1 or status 2 from status 4 is not possible.

+

6. All reset sources (RESET input, POC, LVI, clock monitor, and WDT)

| Status    | X1<br>Oscillator | Rir         | ng-OSC Oscilla | ator      | Subsystem<br>Clock | CPU Clock<br>After | Prescaler Clock Supplied to Peripherals |          |
|-----------|------------------|-------------|----------------|-----------|--------------------|--------------------|-----------------------------------------|----------|
| Operation |                  | Note 1      | No             | te 2      | Oscillator         | Release            | MCM0 = 0                                | MCM0 = 1 |
| Mode      |                  |             | RSTOP = 0      | RSTOP = 1 |                    |                    |                                         |          |
| Reset     | Stopped          | Stopped     |                |           | Stopped            | Ring-OSC           | Stopped                                 |          |
| STOP      |                  | Oscillating | Oscillating    | Stopped   | Oscillating        | Note 3             | Stopped                                 |          |
| HALT      | Oscillating      |             |                |           |                    | Note 4             | Ring-OSC                                | X1       |

#### Table 6-3. Relationship Between Operation Clocks in Each Operation Status

Caution The RSTOP setting is valid only when "Can be stopped by software" is set for Ring-OSC by a mask option.

- Notes 1. When "Cannot be stopped" is selected for Ring-OSC by a mask option.
  - 2. When "Can be stopped by software" is selected for Ring-OSC by a mask option.
  - 3. Operates using the CPU clock at STOP instruction execution.
  - 4. Operates using the CPU clock at HALT instruction execution.
- Remark RSTOP: Bit 0 of the Ring-OSC mode register (RCM)
  - MCM0: Bit 0 of the main clock mode register (MCM)

#### \*

#### Table 6-4. Oscillation Control Flags and Clock Oscillation Status

|                           |           | X1 Oscillator      | Ring-OSC Oscillator |
|---------------------------|-----------|--------------------|---------------------|
| MSTOP = 1 <sup>Note</sup> | RSTOP = 0 | Stopped            | Oscillating         |
|                           | RSTOP = 1 | Setting prohibited |                     |
| $MSTOP = 0^{Note}$        | RSTOP = 0 | Oscillating        | Oscillating         |
|                           | RSTOP = 1 |                    | Stopped             |
| $MCC = 1^{Note}$          | RSTOP = 0 | Stopped            | Oscillating         |
|                           | RSTOP = 1 |                    | Stopped             |
| $MCC = 0^{Note}$          | RSTOP = 0 | Oscillating        | Oscillating         |
|                           | RSTOP = 1 |                    | Stopped             |

Note Setting X1 oscillator oscillating/stopped differs depending on the CPU clock used.

- When the Ring-OSC clock is used as the CPU clock: Set using the MSTOP bit
- When the subsystem clock is used as the CPU clock: Set using the MCC bit

# Caution The RSTOP setting is valid only when "Can be stopped by software" is set for Ring-OSC by a mask option.

 Remark
 MSTOP:
 Bit 7 of the main OSC control register (MOC)

 MCC:
 Bit 7 of the processor clock control register (PCC)

 RSTOP:
 Bit 0 of the Ring-OSC mode register (RCM)

# 6.6 Time Required to Switch Between Ring-OSC Clock and X1 Input Clock

Bit 0 (MCM0) of the main clock mode register (MCM) is used to switch between the Ring-OSC clock and X1 input clock.

In the actual switching operation, switching does not occur immediately after MCM0 rewrite; several instructions are executed using the pre-switch clock after switching MCM0 (see **Table 6-5**).

Bit 1 (MCS) of MCM is used to judge that operation is performed using either the Ring-OSC clock or X1 input clock. To stop the clock, wait for the number of clocks shown in Table 6-5 before stopping.

Table 6-5. Time Required to Switch Between Ring-OSC Clock and X1 Input Clock

|      | PCC  |      | Time Required for Switching   |                           |  |  |  |
|------|------|------|-------------------------------|---------------------------|--|--|--|
| PCC2 | PCC1 | PCC0 | X1→Ring-OSC                   | Ring-OSC $\rightarrow$ X1 |  |  |  |
| 0    | 0    | 0    | fxp/fR + 1 clock              | 2 clocks                  |  |  |  |
| 0    | 0    | 1    | fxp/2fR + 1 clock             |                           |  |  |  |
| 0    | 1    | 0    | fxp/4f <sub>R</sub> + 1 clock |                           |  |  |  |
| 0    | 1    | 1    | fxp/8fr + 1 clock             |                           |  |  |  |
| 1    | 0    | 0    | fxp/16fr + 1 clock            |                           |  |  |  |

Caution To calculate the maximum time, set  $f_R = 120$  kHz.

Remarks 1. PCC: Processor clock control register

- 2. fxp: X1 input clock oscillation frequency
- 3. fR: Ring-OSC clock oscillation frequency
- 4. The maximum time is the number of clocks of the CPU clock before switching.

# 6.7 Changing System Clock and CPU Clock Settings

# 6.7.1 Time required for switching between system clock and CPU clock

The system clock and CPU clock can be switched using bits 0 to 2 (PCC0 to PCC2) and bit 4 (CSS) of the processor clock control register (PCC).

The actual switchover operation is not performed immediately after rewriting to the PCC; operation continues on the pre-switchover clock for several instructions (see **Table 6-6**).

Whether the system is operating on the X1 input clock (or Ring-OSC clock) or the subsystem clock can be ascertained using bit 5 (CLS) of the PCC register.

|     | Valu<br>Switc |      |      |     | Set Value After Switchover |           |      |         |          |       |      |          |      |           |            |     |       |                                 |          |     |      |                                 |      |     |     |         |      |
|-----|---------------|------|------|-----|----------------------------|-----------|------|---------|----------|-------|------|----------|------|-----------|------------|-----|-------|---------------------------------|----------|-----|------|---------------------------------|------|-----|-----|---------|------|
| CSS | PCC2          | PCC1 | PCC0 | CSS | PCC2                       | PCC1      | PCC0 | CSS     | PCC2     | PCC1  | PCC0 | CSS      | PCC2 | PCC1      | PCC0       | CSS | PCC2  | PCC1                            | PCC0     | CSS | PCC2 | PCC1                            | PCC0 | CSS | PCC | 2 PCC1  | PCC0 |
|     |               |      |      | 0   | 0                          | 0         | 0    | 0       | 0        | 0     | 1    | 0        | 0    | 1         | 0          | 0   | 0     | 1                               | 1        | 0   | 1    | 0                               | 0    | 1   | ×   | ×       | ×    |
| 0   | 0             | 0    | 0    |     |                            | 16 clocks |      |         |          | 16 cl | ocks | i        |      | 16 clocks |            |     |       | 16 clocks                       |          |     |      | fxp/fxt clocks<br>(306 clocks)  |      |     |     |         |      |
|     | 0             | 0    | 1    |     | 8 cl                       | ocks      |      |         |          |       |      | 8 clo    | ocks |           | 8 clocks   |     |       |                                 | 8 clocks |     |      | fxp/2fxt clocks<br>(153 clocks) |      |     |     |         |      |
|     | 0             | 1    | 0    |     | 4 cl                       | ocks      |      |         | 4 clo    | ocks  |      | /        |      |           |            |     | 4 clo | ocks                            |          |     | 4 cl | ocks                            |      |     |     | tt cloc | -    |
|     | 0             | 1    | 1    |     | 2 cl                       | ocks      |      |         | 2 clocks |       |      | 2 clocks |      |           | 2 clocks   |     |       | fxp/8fxt clocks<br>(39 clocks)  |          |     |      |                                 |      |     |     |         |      |
|     | 1             | 0    | 0    |     | 1 c                        | lock      |      | 1 clock |          |       | 1 cl | ock      |      |           | 1 clock fx |     |       | fxp/16fxt clocks<br>(20 clocks) |          |     |      |                                 |      |     |     |         |      |
| 1   | ×             | ×    | ×    |     | 1 clock 1 clock            |           |      |         | 1 cl     | ock   |      |          | 1 cl | ock       |            |     | 1 c   | lock                            |          |     |      |                                 |      |     |     |         |      |

Table 6-6. Maximum Time Required for CPU Clock Switchover

**Remarks 1.** The maximum time is the number of clocks of the CPU clock before switching.

**2.** Figures in parentheses apply to operation with  $f_{XP} = 10$  MHz and  $f_{XT} = 32.768$  kHz.

Caution Selection of the CPU clock cycle division factor (PCC0 to PCC2) and switchover from the X1 input clock to the subsystem clock (changing CSS from 0 to 1) should not be set simultaneously.

Simultaneous setting is possible, however, for selection of the CPU clock cycle division factor (PCC0 to PCC2) and switchover from the subsystem clock to the X1 input clock (changing CSS from 1 to 0).

# 6.8 Clock Switching Flowchart and Register Setting

# 6.8.1 Switching from Ring-OSC clock to X1 input clock



#### Figure 6-14. Switching from Ring-OSC Clock to X1 Input Clock

**Note** Check the oscillation stabilization wait time of the X1 oscillator after reset release using the OSTC register and then switch to the X1 input clock operation after the oscillation stabilization wait time has elapsed. The OSTS register setting is valid only after STOP mode is released during X1 input clock operation.

# 6.8.2 Switching from X1 input clock to Ring-OSC clock



Figure 6-15. Switching from X1 Input Clock to Ring-OSC Clock (Flowchart)

Note Required only when "clock can be stopped by software" is selected for Ring-OSC by a mask option.

#### 6.8.3 Switching from X1 input clock to subsystem clock





# 6.8.4 Switching from subsystem clock to X1 input clock





#### 6.8.5 Register settings

| fcpu                              | Mode                                 |                     | ę | Setting Fla         | g                   |                         | Status Flag |          |
|-----------------------------------|--------------------------------------|---------------------|---|---------------------|---------------------|-------------------------|-------------|----------|
|                                   |                                      | PCC Register MCM    |   |                     | MOC                 | RCM                     | PCC         | MCM      |
|                                   |                                      |                     |   | Register            | Register            | Register                | Register    | Register |
|                                   |                                      | MCC CS              |   |                     |                     | RSTOP <sup>Note 1</sup> | CLS         | MCS      |
| X1 input clock <sup>Note 2</sup>  | Ring-OSC oscillating                 | 0                   | 0 | 1                   | 0                   | 0                       | 0           | 1        |
|                                   | Ring-OSC stopped                     | 0                   | 0 | 1                   | 0                   | 1                       | 0           | 1        |
| Ring-OSC clock                    | X1 oscillating                       | 0                   | 0 | 0                   | 0                   | 0                       | 0           | 0        |
|                                   | X1 stopped                           | 0 <sup>Note 3</sup> | 0 | 0                   | 1                   | 0                       | 0           | 0        |
| Subsystem clock <sup>Note 4</sup> | X1 oscillating, Ring-OSC oscillating | 0                   | 1 | 1 <sup>Note 5</sup> | 0 <sup>Note 6</sup> | 0                       | 1           | 1        |
|                                   | X1 stopped, Ring-OSC oscillating     | 1                   | 1 | 1 <sup>Note 5</sup> | 0 <sup>Note 6</sup> | 0                       | 1           | 1        |
|                                   | X1 oscillating, Ring-OSC stopped     | 0                   | 1 | 1 <sup>Note 5</sup> | 0 <sup>Note 6</sup> | 1                       | 1           | 1        |
|                                   | X1 stopped, Ring-OSC stopped         | 1                   | 1 | 1 <sup>Note 5</sup> | 0 <sup>Note 6</sup> | 1                       | 1           | 1        |

#### Table 6-7. Clock and Register Setting

**Notes 1.** Valid only when "clock can be stopped by software" is selected for Ring-OSC by a mask option.

2. Do not set MCC = 1 or MSTOP = 1 during X1 input clock operation (even if MCC = 1 or MSTOP = 1 is set, the X1 oscillation does not stop).

**3.** Do not set MCC = 1 during Ring-OSC operation (even if MCC = 1 is set, the X1 oscillation does not stop). To stop X1 oscillation during Ring-OSC operation, use MSTOP.

**4.** Shifting to subsystem clock operation mode must be performed from the X1 input clock operation mode. From subsystem clock operation mode, only X1 input clock operation mode can be shifted to.

**5.** Do not set MCM0 = 0 (shifting to Ring-OSC) during subsystem clock operation.

6. Do not set MSTOP = 1 during subsystem clock operation (even if MSTOP = 1 is set, X1 oscillation does not stop). To stop X1 oscillation during subsystem clock operation, use MCC.

# CHAPTER 7 16-BIT TIMER/EVENT COUNTERS 00 AND 01

The  $\mu$ PD780143 and 780144 incorporate 16-bit timer/event counter 00, and the  $\mu$ PD780146, 780148, and 78F0148 incorporate 16-bit timer/event counters 00 and 01.

# 7.1 Functions of 16-Bit Timer/Event Counters 00 and 01

16-bit timer/event counters 00 and 01<sup>Note</sup> have the following functions.

- Interval timer
- PPG output
- Pulse width measurement
- External event counter
- Square-wave output
- One-shot pulse output

#### (1) Interval timer

16-bit timer/event counters 00 and 01 generate an interrupt request at the preset time interval.

#### (2) PPG output

16-bit timer/event counters 00 and 01 can output a rectangular wave whose frequency and output pulse width can be set freely.

#### (3) Pulse width measurement

16-bit timer/event counters 00 and 01 can measure the pulse width of an externally input signal.

#### (4) External event counter

16-bit timer/event counters 00 and 01 can measure the number of pulses of an externally input signal.

#### (5) Square-wave output

16-bit timer/event counters 00 and 01 can output a square wave with any selected frequency.

#### (6) One-shot pulse output

16-bit timer/event counters 00 and 01 can output a one-shot pulse whose output pulse width can be set freely.

**Note** Available only for the  $\mu$ PD780146, 780148, and 78F0148.

# 7.2 Configuration of 16-Bit Timer/Event Counters 00 and 01

16-bit timer/event counters 00 and 01 consist of the following hardware.

| Item              | Configuration                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer counter     | 16 bits × 1 (TM0n)                                                                                                                                                                                                                               |
| Register          | 16-bit timer capture/compare register: 16 bits $\times$ 2 (CR00n, CR01n)                                                                                                                                                                         |
| Timer output      | 1 (TO0n)                                                                                                                                                                                                                                         |
| Control registers | 16-bit timer mode control register 0n (TMC0n)<br>16-bit timer capture/compare control register 0n (CRC0n)<br>16-bit timer output control register 0n (TOC0n)<br>Prescaler mode register 0n (PRM0n)<br>Port mode register 0 (PM0) <sup>Note</sup> |

Note See Figure 4-2 Block Diagram of P00, P03, and P05 and Figure 4-3 Block Diagram of P01 and P06.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

Figures 7-1 and 7-2 show the block diagrams.



#### Figure 7-1. Block Diagram of 16-Bit Timer/Event Counter 00



Figure 7-2. Block Diagram of 16-Bit Timer/Event Counter 01

#### (1) 16-bit timer counter 0n (TM0n)

TMOn is a 16-bit read-only register that counts count pulses.

The counter is incremented in synchronization with the rising edge of the input clock. The count value is reset to 0000H in the following cases.

- <1> At RESET input
- <2> If TMC0n3 and TMC0n2 are cleared
- <3> If the valid edge of TI00n is input in the mode in which clear & start occurs when inputting the valid edge of TI00n
- <4> If TM0n and CR00n match in the mode in which clear & start occurs on a match of TM0n and CR00n
- <5> OSPT0n is set in one-shot pulse output mode

#### (2) 16-bit timer capture/compare register 00n (CR00n)

CR00n is a 16-bit register that has the functions of both a capture register and a compare register. Whether it is used as a capture register or as a compare register is set by bit 0 (CRC0n0) of capture/compare control register 0n (CRC0n).

#### • When CR00n is used as a compare register

The value set in CR00n is constantly compared with the 16-bit timer counter 0n (TM0n) count value, and an interrupt request (INTTM00n) is generated if they match. It can also be used as the register that holds the interval time when TM0n is set to interval timer operation.

#### • When CR00n is used as a capture register

It is possible to select the valid edge of the TI00n pin or the TI01n pin as the capture trigger. The TI00n or TI01n valid edge is set using prescaler mode register 0n (PRM0n).

If the capture trigger is specified to be the valid edge of the TI00n pin, the situation is as shown in Table 7-2. On the other hand, when the capture trigger is specified to be the valid edge of the TI01n pin, the situation is as shown in Table 7-3.

| ES0n1 | ES0n0 | TI00n Pin Valid Edge          | CR00n Capture Trigger | CR01n Capture Trigger         |
|-------|-------|-------------------------------|-----------------------|-------------------------------|
| 0     | 0     | Falling edge                  | Rising edge           | Falling edge                  |
| 0     | 1     | Rising edge                   | Falling edge          | Rising edge                   |
| 1     | 0     | Setting prohibited            | Setting prohibited    | Setting prohibited            |
| 1     | 1     | Both rising and falling edges | No capture operation  | Both rising and falling edges |

#### Table 7-2. TI00n Pin Valid Edge and CR00n, CR01n Capture Trigger

# Table 7-3. TI01n Pin Valid Edge and CR00n Capture Trigger

| ES1n1 | ES1n0 | TI01n Pin Valid Edge          | CR00n Capture Trigger         |
|-------|-------|-------------------------------|-------------------------------|
| 0     | 0     | Falling edge                  | Falling edge                  |
| 0     | 1     | Rising edge                   | Rising edge                   |
| 1     | 0     | Setting prohibited            | Setting prohibited            |
| 1     | 1     | Both rising and falling edges | Both rising and falling edges |

**Remark** n = 0: µPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148

CR00n can be set by a 16-bit memory manipulation instruction.

- ★ RESET input clears this register to 0000H.
  - Cautions 1. Set a value other than 0000H in CR00n in the mode in which clear & start occurs on a match of TM0n and CR00n. However, in the free-running mode and in the clear mode using the valid edge of Tl00n, if CR00n is set to 0000H, an interrupt request (INTTM00n) is generated following overflow (FFFFH).
    - 2. If the changed value of CR00n is smaller than the value of 16-bit timer counter 0n (TM0n), TM0n continues counting and starts counting again from 0 after overflow. Therefore, if the value of CR00n after the change is smaller than before the change, the timer should be restarted after CR00n is changed.
    - 3. When P01 or P06 is used as the valid edge of Tl01n, it cannot be used as the timer output (T00n). Moreover, when P01 or P06 is used as T00n, it cannot be used as the valid edge of Tl01n.
    - 4. When CR00n is used as a capture register, read data is undefined if the register read time and capture trigger input conflict (the capture data itself is the correct value).
      - If count stop input and capture trigger input conflict, the captured data is undefined.
    - 5. Do not rewrite CR00n during TM0n operation.

# (3) 16-bit timer capture/compare register 01n (CR01n)

CR01n is a 16-bit register that has the functions of both a capture register and a compare register. Whether it is used as a capture register or a compare register is set by bit 2 (CRC0n2) of capture/compare control register 0n (CRC0n).

# • When CR01n is used as a compare register

The value set in the CR01n is constantly compared with the 16-bit timer counter 0n (TM0n) count value, and an interrupt request (INTTM01n) is generated if they match.

# • When CR01n is used as a capture register

It is possible to select the valid edge of the TI00n pin as the capture trigger. The TI00n valid edge is set by prescaler mode register 0n (PRM0n).

CR01n can be set by a 16-bit memory manipulation instruction.

RESET input clears this register to 0000H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

Cautions 1. Set CR01n to other than 0000H. This means a 1-pulse count operation cannot be performed when CR01n is used as the event counter.

However, in the free-running mode and in the clear mode using the valid edge of TI00n, if CR01n is set to 0000H, an interrupt request (INTTM01n) is generated following overflow (FFFFH).

- 2. When CR01n is used as a capture register, read data is undefined if the register read time and capture trigger input conflict (the capture data itself is the correct value).
  - If count stop input and capture trigger input conflict, the captured data is undefined.
- 3. CR01n can be rewritten during TM0n operation. For details, refer to Remark 2 in Figure 7-17.

\*

# 7.3 Registers Controlling 16-Bit Timer/Event Counters 00 and 01

The following five registers are used to control 16-bit timer/event counters 00 and 01.

- 16-bit timer mode control register 0n (TMC0n)
- Capture/compare control register 0n (CRC0n)
- 16-bit timer output control register 0n (TOC0n)
- Prescaler mode register 0n (PRM0n)
- Port mode register 0 (PM0)

#### (1) 16-bit timer mode control register 0n (TMC0n)

This register sets the 16-bit timer operating mode, the 16-bit timer counter 0n (TM0n) clear mode, and output timing, and detects an overflow.

TMC0n can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears TMC0n to 00H.

# Caution 16-bit timer counter 0n (TM0n) starts operation at the moment TMC0n2 and TMC0n3 are set to values other than 0, 0 (operation stop mode), respectively. Set TMC0n2 and TMC0n3 to 0, 0 to stop the operation.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 7-3. Format of 16-Bit Timer Mode Control Register 00 (TMC00)

| Address | FFBA | H Af | ter rese | t: 00H | R/W    |        |        |       |
|---------|------|------|----------|--------|--------|--------|--------|-------|
| Symbol  | 7    | 6    | 5        | 4      | 3      | 2      | 1      | 0     |
| TMC00   | 0    | 0    | 0        | 0      | TMC003 | TMC002 | TMC001 | OVF00 |

| TMC003 | TMC002 | TMC001 | Operating mode and clear<br>mode selection           | TO00 output timing selection                                                         | Interrupt request generation                                                     |
|--------|--------|--------|------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 0      | 0      | 0      | Operation stop                                       | No change                                                                            | Not generated                                                                    |
| 0      | 0      | 1      | (TM00 cleared to 0)                                  |                                                                                      |                                                                                  |
| 0      | 1      | 0      | Free-running mode                                    | Match between TM00 and<br>CR000 or match between<br>TM00 and CR010                   | Generated on match between<br>TM00 and CR000, or match<br>between TM00 and CR010 |
| 0      | 1      | 1      |                                                      | Match between TM00 and<br>CR000, match between TM00<br>and CR010 or TI000 valid edge |                                                                                  |
| 1      | 0      | 0      | Clear & start occurs on TI000                        | -                                                                                    |                                                                                  |
| 1      | 0      | 1      | valid edge                                           |                                                                                      |                                                                                  |
| 1      | 1      | 0      | Clear & start occurs on match between TM00 and CR000 | Match between TM00 and<br>CR000 or match between<br>TM00 and CR010                   |                                                                                  |
| 1      | 1      | 1      |                                                      | Match between TM00 and<br>CR000, match between TM00<br>and CR010 or TI000 valid edge |                                                                                  |

| OVF00 | 16-bit timer counter 00 (TM00) overflow detection |
|-------|---------------------------------------------------|
| 0     | Overflow not detected                             |
| 1     | Overflow detected                                 |

Cautions 1. Timer operation must be stopped before writing to bits other than the OVF00 flag.

- 2. Set the valid edge of the TI000/P00 pin using prescaler mode register 00 (PRM00).
- 3. If any the following modes: the mode in which clear & start occurs on match between TM00 and CR000, the mode in which clear & start occurs at the TI00 valid edge, or free-running mode is selected, when the set value of CR000 is FFFFH and the TM00 value changes from FFFFH to 0000H, the OVF00 flag is set to 1.
- Remarks 1. TO00: 16-bit timer/event counter 00 output pin
  - **2.** TI000: 16-bit timer/event counter 00 input pin
  - 3. TM00: 16-bit timer counter 00
  - 4. CR000: 16-bit timer capture/compare register 000
  - 5. CR010: 16-bit timer capture/compare register 010

#### Figure 7-4. Format of 16-Bit Timer Mode Control Register 01 (TMC01)

| Address | H Aft | er rese | t: 00H | R/W |        |        |        |       |
|---------|-------|---------|--------|-----|--------|--------|--------|-------|
| Symbol  | 7     | 6       | 5      | 4   | 3      | 2      | 1      | 0     |
| TMC01   | 0     | 0       | 0      | 0   | TMC013 | TMC012 | TMC011 | OVF01 |

| TMC013 | TMC012 | TMC011 | Operating mode and clear<br>mode selection           | TO01 output timing selection                                                         | Interrupt request generation                                                     |
|--------|--------|--------|------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 0      | 0      | 0      | Operation stop                                       | No change                                                                            | Not generated                                                                    |
| 0      | 0      | 1      | (TM01 cleared to 0)                                  |                                                                                      |                                                                                  |
| 0      | 1      | 0      | Free-running mode                                    | Match between TM01 and<br>CR001 or match between<br>TM01 and CR011                   | Generated on match between<br>TM01 and CR001, or match<br>between TM01 and CR011 |
| 0      | 1      | 1      |                                                      | Match between TM01 and<br>CR001, match between TM01<br>and CR011 or TI001 valid edge |                                                                                  |
| 1      | 0      | 0      | Clear & start occurs on TI001                        | -                                                                                    |                                                                                  |
| 1      | 0      | 1      | valid edge                                           |                                                                                      |                                                                                  |
| 1      | 1      | 0      | Clear & start occurs on match between TM01 and CR001 | Match between TM01 and<br>CR001 or match between<br>TM01 and CR011                   |                                                                                  |
| 1      | 1      | 1      |                                                      | Match between TM01 and<br>CR001, match between TM01<br>and CR011 or TI001 valid edge |                                                                                  |

| OVF01 | 16-bit timer counter 01 (TM01) overflow detection |
|-------|---------------------------------------------------|
| 0     | Overflow not detected                             |
| 1     | Overflow detected                                 |

Cautions 1. Timer operation must be stopped before writing to bits other than the OVF01 flag.

- 2. Set the valid edge of the TI001/P05 pin using prescaler mode register 01 (PRM01).
- 3. If any the following modes: the mode in which clear & start occurs on match between TM01 and CR001, the mode in which clear & start occurs at the Tl01 valid edge, or free-running mode is selected, when the set value of CR001 is FFFFH and the TM01 value changes from FFFFH to 0000H, the OVF01 flag is set to 1.
- Remarks 1. TO01: 16-bit timer/event counter 01 output pin
  - 2. TI001: 16-bit timer/event counter 01 input pin
  - 3. TM01: 16-bit timer counter 01
  - 4. CR001: 16-bit timer capture/compare register 001
  - 5. CR011: 16-bit timer capture/compare register 011

#### (2) Capture/compare control register 0n (CRC0n)

This register controls the operation of the 16-bit timer capture/compare registers (CR00n, CR01n). CRC0n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears CRC0n to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 7-5. Format of Capture/Compare Control Register 00 (CRC00)

| Address: FFBCH After reset: 00H |   |   | R/W |   |   |        |        |        |
|---------------------------------|---|---|-----|---|---|--------|--------|--------|
| Symbol                          | 7 | 6 | 5   | 4 | 3 | 2      | 1      | 0      |
| CRC00                           | 0 | 0 | 0   | 0 | 0 | CRC002 | CRC001 | CRC000 |

| CRC002 | CR010 operating mode selection |
|--------|--------------------------------|
| 0      | Operates as compare register   |
| 1      | Operates as capture register   |

| CRC001 | CR000 capture trigger selection                  |  |  |  |  |  |
|--------|--------------------------------------------------|--|--|--|--|--|
| 0      | Captures on valid edge of TI010                  |  |  |  |  |  |
| 1      | Captures on valid edge of TI000 by reverse phase |  |  |  |  |  |

| CRC000 | CR000 operating mode selection |
|--------|--------------------------------|
| 0      | Operates as compare register   |
| 1      | Operates as capture register   |

Cautions 1. Timer operation must be stopped before setting CRC00.

- 2. When the mode in which clear & start occurs on a match between TM00 and CR000 is selected with 16-bit timer mode control register 00 (TMC00), CR000 should not be specified as a capture register.
- 3. To ensure that the capture operation is performed properly, the capture trigger requires a pulse two times longer than the count clock selected by prescaler mode register 00 (PRM00).

### Figure 7-6. Format of Capture/Compare Control Register 01 (CRC01)

| Address: FFB8H After reset: 00H |   |   | R/W |   |   |        |        |        |
|---------------------------------|---|---|-----|---|---|--------|--------|--------|
| Symbol                          | 7 | 6 | 5   | 4 | 3 | 2      | 1      | 0      |
| CRC01                           | 0 | 0 | 0   | 0 | 0 | CRC012 | CRC011 | CRC010 |

| CRC012 | CR011 operating mode selection |
|--------|--------------------------------|
| 0      | Operates as compare register   |
| 1      | Operates as capture register   |

| CRC011 | CR001 capture trigger selection                  |
|--------|--------------------------------------------------|
| 0      | Captures on valid edge of TI011                  |
| 1      | Captures on valid edge of TI001 by reverse phase |

| CRC010 | CR001 operating mode selection |
|--------|--------------------------------|
| 0      | Operates as compare register   |
| 1      | Operates as capture register   |

Cautions 1. Timer operation must be stopped before setting CRC01.

- 2. When the mode in which clear & start occurs on a match between TM01 and CR001 is selected with 16-bit timer mode control register 01 (TMC01), CR001 should not be specified as a capture register.
- 3. To ensure that the capture operation is performed properly, the capture trigger requires a pulse two times longer than the count clock selected by prescaler mode register 01 (PRM01).

#### (3) 16-bit timer output control register 0n (TOC0n)

This register controls the operation of the 16-bit timer/event counter 0n output controller. It sets/resets the R-S type flip-flop (LV0n), enables/disables output inversion and 16-bit timer/event counter 0n timer output, enables/disables the one-shot pulse output operation, and sets the one-shot pulse output trigger via software. TOC0n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears TOC0n to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 7-7. Format of 16-Bit Timer Output Control Register 00 (TOC00)

| Address: FF | BDH After | reset: 00H | R/W    |        |       |       |        |       |
|-------------|-----------|------------|--------|--------|-------|-------|--------|-------|
| Symbol      | 7         | 6          | 5      | 4      | 3     | 2     | 1      | 0     |
| TOC00       | 0         | OSPT00     | OSPE00 | TOC004 | LVS00 | LVR00 | TOC001 | TOE00 |

| OSPT00 | One-shot pulse output trigger control via software |  |  |
|--------|----------------------------------------------------|--|--|
| 0      | o one-shot pulse trigger                           |  |  |
| 1      | ne-shot pulse trigger                              |  |  |

| OSPE00 | One-shot pulse output operation control    |  |  |
|--------|--------------------------------------------|--|--|
| 0      | Successive pulse output mode               |  |  |
| 1      | One-shot pulse output mode <sup>Note</sup> |  |  |

| TOC004 | Timer output F/F control using match of CR010 and TM00 |  |  |
|--------|--------------------------------------------------------|--|--|
| 0      | Disables inversion operation                           |  |  |
| 1      | Enables inversion operation                            |  |  |

| LVS00 | LVR00 | 16-bit timer/event counter 00 timer output F/F status setting |  |
|-------|-------|---------------------------------------------------------------|--|
| 0     | 0     | o change                                                      |  |
| 0     | 1     | mer output F/F reset (0)                                      |  |
| 1     | 0     | Timer output F/F set (1)                                      |  |
| 1     | 1     | Setting prohibited                                            |  |

| TOC001 | Timer output F/F control using match of CR000 and TM00 |  |  |
|--------|--------------------------------------------------------|--|--|
| 0      | ables inversion operation                              |  |  |
| 1      | Enables inversion operation                            |  |  |

| TOE00 | 16-bit timer/event counter 00 output control |
|-------|----------------------------------------------|
| 0     | Disables output (output fixed to level 0)    |
| 1     | Enables output                               |

- **Note** The one-shot pulse output mode operates correctly only in the free-running mode and the mode in which clear & start occurs at the TI000 valid edge. In the mode in which clear & start occurs on a match between the TM00 register and CR000 register, one-shot pulse output is not possible because an overflow does not occur.
- **★** Cautions 1. Timer operation must be stopped before setting other than TOC004.
  - 2. If LVS00 and LVR00 are read after data is set, 0 is read.
  - 3. OSPT00 is automatically cleared after data is set, so 0 is read.
  - 4. Do not set OSPT00 to 1 other than in one-shot pulse output mode.
  - 5. A write interval of two cycles or more of the operating clock is required to write to OSPT00 successively.

#### Figure 7-8. Format of 16-Bit Timer Output Control Register 01 (TOC01)

| Address: FFB9H After reset: 00H |   |        | R/W    |        |       |       |        |       |
|---------------------------------|---|--------|--------|--------|-------|-------|--------|-------|
| Symbol                          | 7 | 6      | 5      | 4      | 3     | 2     | 1      | 0     |
| TOC01                           | 0 | OSPT01 | OSPE01 | TOC014 | LVS01 | LVR01 | TOC011 | TOE01 |

| OSPT01 | One-shot pulse output trigger control via software |  |  |
|--------|----------------------------------------------------|--|--|
| 0      | o one-shot pulse trigger                           |  |  |
| 1      | Dne-shot pulse trigger                             |  |  |

| OSPE01 | One-shot pulse output operation control    |  |
|--------|--------------------------------------------|--|
| 0      | uccessive pulse output mode                |  |
| 1      | One-shot pulse output mode <sup>Note</sup> |  |

| TOC014 | Timer output F/F control using match of CR011 and TM01 |  |  |
|--------|--------------------------------------------------------|--|--|
| 0      | Disables inversion operation                           |  |  |
| 1      | Enables inversion operation                            |  |  |

| LVS01 | LVR01 | 16-bit timer/event counter 01 timer output F/F status setting |  |
|-------|-------|---------------------------------------------------------------|--|
| 0     | 0     | lo change                                                     |  |
| 0     | 1     | Timer output F/F reset (0)                                    |  |
| 1     | 0     | Timer output F/F set (1)                                      |  |
| 1     | 1     | Setting prohibited                                            |  |

| TOC011 | Timer output F/F control using match of CR001 and TM01 |  |  |  |
|--------|--------------------------------------------------------|--|--|--|
| 0      | Disables inversion operation                           |  |  |  |
| 1      | ables inversion operation                              |  |  |  |

| TOE01 | 16-bit timer/event counter 01 output control |  |  |  |  |
|-------|----------------------------------------------|--|--|--|--|
| 0     | Disables output (output fixed to level 0)    |  |  |  |  |
| 1     | Enables output                               |  |  |  |  |

**Note** The one-shot pulse output mode operates correctly only in the free-running mode and the mode in which clear & start occurs at the TI001 valid edge. In the mode in which clear & start occurs on a match between the TM01 register and CR001 register, one-shot pulse output is not possible because an overflow does not occur.

#### Cautions 1. Timer operation must be stopped before setting other than TOC014.

- 2. If LVS01 and LVR01 are read after data is set, 0 is read.
- 3. OSPT01 is automatically cleared after data is set, so 0 is read.
- 4. Do not set OSPT01 to 1 other than in one-shot pulse output mode.
- 5. A write interval of two cycles or more of the operating clock is required to write to OSPT01 successively.

# (4) Prescaler mode register 0n (PRM0n)

- This register is used to set the 16-bit timer counter 0n (TM0n) count clock and TI00n and TI01n input valid edges.
- ★ PRM0n can be set by a 1-bit or 8-bit memory manipulation instruction.
   RESET input clears PRM0n to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 7-9. Format of Prescaler Mode Register 00 (PRM00)

| Address: FFBBH After reset: 00H |       |       | R/W   |       |   |   |        |        |
|---------------------------------|-------|-------|-------|-------|---|---|--------|--------|
| Symbol                          | 7     | 6     | 5     | 4     | 3 | 2 | 1      | 0      |
| PRM00                           | ES101 | ES100 | ES001 | ES000 | 0 | 0 | PRM001 | PRM000 |

| ES101 | ES100 | TI010 valid edge selection    |
|-------|-------|-------------------------------|
| 0     | 0     | Falling edge                  |
| 0     | 1     | Rising edge                   |
| 1     | 0     | Setting prohibited            |
| 1     | 1     | Both falling and rising edges |

| ES001 | ES000 | TI000 valid edge selection    |
|-------|-------|-------------------------------|
| 0     | 0     | Falling edge                  |
| 0     | 1     | Rising edge                   |
| 1     | 0     | Setting prohibited            |
| 1     | 1     | Both falling and rising edges |

| PRM001 | PRM000 | Count clock selection            |
|--------|--------|----------------------------------|
| 0      | 0      | fx (10 MHz)                      |
| 0      | 1      | fx/2² (2.5 MHz)                  |
| 1      | 0      | fx/2 <sup>®</sup> (39.06 kHz)    |
| 1      | 1      | TI000 valid edge <sup>Note</sup> |

**Note** The external clock requires a pulse two times longer than internal clock (fx).

- Cautions 1. If the valid edge of TI000 is to be set for the count clock, do not set the clear & start mode using the valid edge of TI000 and the capture trigger.
  - 2. Always set data to PRM00 after stopping the timer operation.
  - 3. If the TI000 or TI010 pin is high level immediately after system reset, the rising edge is immediately detected after the rising edge or both the rising and falling edges are set as the valid edge(s) of the TI000 pin or TI010 pin to enable the operation of 16-bit timer counter 00 (TM00). Care is therefore required when pulling up the TI000 or TI010 pin. However, when reenabling operation after the operation has been stopped once, the rising edge is not detected.
  - 4. When P01 is used as the TI010 valid edge, it cannot be used as the timer output (TO00), and when used as TO00, it cannot be used as the TI010 valid edge.

#### Remarks 1. fx: X1 input clock oscillation frequency

- 2. TI000, TI010: 16-bit timer/event counter 00 input pin
- **3.** Figures in parentheses are for operation with fx = 10 MHz.

#### Figure 7-10. Format of Prescaler Mode Register 01 (PRM01)

| Address: FFB7H After reset: 00H |       |       | R/W   |       |   |   |        |        |
|---------------------------------|-------|-------|-------|-------|---|---|--------|--------|
| Symbol                          | 7     | 6     | 5     | 4     | 3 | 2 | 1      | 0      |
| PRM01                           | ES111 | ES110 | ES011 | ES010 | 0 | 0 | PRM011 | PRM010 |

| ES111 | ES110 | TI011 valid edge selection    |
|-------|-------|-------------------------------|
| 0     | 0     | Falling edge                  |
| 0     | 1     | Rising edge                   |
| 1     | 0     | Setting prohibited            |
| 1     | 1     | Both falling and rising edges |

| ES011 | ES010 | TI001 valid edge selection    |
|-------|-------|-------------------------------|
| 0     | 0     | Falling edge                  |
| 0     | 1     | Rising edge                   |
| 1     | 0     | Setting prohibited            |
| 1     | 1     | Both falling and rising edges |

| PRM011 | PRM010 | Count clock selection            |
|--------|--------|----------------------------------|
| 0      | 0      | fx (10 MHz)                      |
| 0      | 1      | fx/2⁴ (625 kHz)                  |
| 1      | 0      | fx/2 <sup>e</sup> (156.25 kHz)   |
| 1      | 1      | TI001 valid edge <sup>Note</sup> |

**Note** The external clock requires a pulse two times longer than internal clock (fx).

- Cautions 1. If the valid edge of TI001 is to be set for the count clock, do not set the clear & start mode using the valid edge of TI001 and the capture trigger.
  - 2. Always set data to PRM01 after stopping the timer operation.
  - 3. If the TI001 or TI011 pin is high level immediately after system reset, the rising edge is immediately detected after the rising edge or both the rising and falling edges are set as the valid edge(s) of the TI001 pin or TI011 pin to enable the operation of 16-bit timer counter 01 (TM01). Care is therefore required when pulling up the TI001 or TI011 pin. However, when reenabling operation after the operation has been stopped once, the rising edge is not detected.
  - 4. When P06 is used as the TI011 valid edge, it cannot be used as the timer output (TO01), and when used as TO01, it cannot be used as the TI011 valid edge.

**Remarks 1**. fx: X1 input clock oscillation frequency

- 2. TI001, TI011: 16-bit timer/event counter 01 input pin
- **3.** Figures in parentheses are for operation with fx = 10 MHz.

#### (5) Port mode register 0 (PM0)

This register sets port 0 input/output in 1-bit units.

When using the P01/TO00/TI010 and P06/TO01<sup>Note</sup>/TI011<sup>Note</sup> pins for timer output, set PM01 and PM06 and the output latch of P01 and P06 to 0.

PM0 can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets PM0 to FFH.

#### Figure 7-11. Format of Port Mode Register 0 (PM0)



| PM0n | P0n pin I/O mode selection (n = 0 to 6) |  |  |  |  |
|------|-----------------------------------------|--|--|--|--|
| 0    | Output mode (output buffer on)          |  |  |  |  |
| 1    | Input mode (output buffer off)          |  |  |  |  |

**Note** Available only for the  $\mu$ PD780146, 780148, and 78F0148.

#### 7.4 Operation of 16-Bit Timer/Event Counters 00 and 01

#### 7.4.1 Interval timer operation

Setting 16-bit timer mode control register 0n (TMC0n) and capture/compare control register 0n (CRC0n) as shown in Figure 7-12 allows operation as an interval timer. Interrupt requests are generated repeatedly using the count value preset in 16-bit timer capture/compare register 00n (CR00n) as the interval.

When the count value of 16-bit timer counter 0n (TM0n) matches the value set in CR00n, counting continues with the TM0n value cleared to 0 and the interrupt request signal (INTTM00n) is generated.

The count clock of the 16-bit timer/event counter 0n can be selected with bits 0 and 1 (PRM0n0, PRM0n1) of prescaler mode register 0n (PRM0n).

See 7.5 Cautions for 16-Bit Timer/Event Counters 00 and 01 (2) 16-bit timer capture/compare register setting for details of the operation when the compare register value is changed during timer count operation.

#### Figure 7-12. Control Register Settings for Interval Timer Operation

#### (a) 16-bit timer mode control register 0n (TMC0n)



#### (b) Capture/compare control register 0n (CRC0n)



**Remarks 1.** 0/1: Setting 0 or 1 allows another function to be used simultaneously with the interval timer. For details, see **Figures 7-3** to **7-6**.

**2.** n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148

Figure 7-13. Interval Timer Configuration Diagram



**Remark** Frequencies and pin names without parentheses are for 16-bit timer/event counter 00, and those in parentheses are for 16-bit timer/event counter 01.



Figure 7-14. Timing of Interval Timer Operation

**Remark** Interval time =  $(N + 1) \times t$ N = 0001H to FFFFH n = 0:  $\mu$ PD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148

# 7.4.2 PPG output operations

Setting 16-bit timer mode control register 0n (TMC0n) and capture/compare control register 0n (CRC0n) as shown in Figure 7-15 allows operation as PPG (Programmable Pulse Generator) output.

In the PPG output operation, rectangular waves are output from the TO0n pin with the pulse width and the cycle that correspond to the count values preset in 16-bit timer capture/compare register 01n (CR01n) and in 16-bit timer capture/compare register 00n (CR00n), respectively.

#### Figure 7-15. Control Register Settings for PPG Output Operation

#### (a) 16-bit timer mode control register 0n (TMC0n)



# (b) Capture/compare control register 0n (CRC0n)



#### (c) 16-bit timer output control register 0n (TOC0n)



- Cautions 1. Values in the following range should be set in CR00n and CR01n:  $0000H < CR01n < CR00n \le FFFFH$ 
  - 2. The cycle of the pulse generated through PPG output (CR00n setting value + 1) has a duty of (CR01n setting value + 1)/(CR00n setting value + 1).

# Remark ×: Don't care

- n = 0: μPD780143, 780144
- n = 0, 1: μPD780146, 780148, 78F0148

Figure 7-16. Configuration of PPG Output



**Remark** Frequencies and pin names without parentheses are for 16-bit timer/event counter 00, and those in parentheses are for 16-bit timer/event counter 01.



Figure 7-17. PPG Output Operation Timing

#### Caution CR00n cannot be rewritten during TM0n operation.

**Remarks 1.**  $0000H < M < N \le FFFFH$ 

- In the PPG output operation, change the pulse width (rewrite CR01n) during TM0n operation using the following procedure.
  - <1> Disable the timer output inversion operation by match of TM0n and CR01n (TOC0n4 = 0)
  - <2> Disable the INTTM01n interrupt (TMMK01n = 1)
  - <3> Rewrite CR01n
  - <4> Wait for 1 cycle of the TM0n count clock
  - <5> Enable the timer output inversion operation by match of TM0n and CR01n (TOC0n4 = 1)
  - <6> Clear the interrupt request flag of INTTM01n (TMIF01n = 0)
  - <7> Enable the INTTM01n interrupt (TMMK01n = 0)
- **3.** n = 0: μPD780143, 780144, n = 0, 1: μPD780146, 780148, 78F0148

### 7.4.3 Pulse width measurement operations

It is possible to measure the pulse width of the signals input to the TI00n pin and TI01n pin using 16-bit timer counter 0n (TM0n).

There are two measurement methods: measuring with TM0n used in free-running mode, and measuring by restarting the timer in synchronization with the edge of the signal input to the TI00n pin.

#### (1) Pulse width measurement with free-running counter and one capture register

When 16-bit timer counter 0n (TM0n) is operated in free-running mode (see register settings in **Figure 7-18**), and the edge specified by prescaler mode register 0n (PRM0n) is input to the TI00n pin, the value of TM0n is taken into 16-bit timer capture/compare register 01n (CR01n) and an external interrupt request signal (INTTM01n) is set.

Any of three edges—rising, falling, or both edges—can be selected using bits 4 and 5 (ES0n0 and ES0n1) of PRM0n.

For valid edge detection, sampling is performed using the count clock selected by PRMOn, and a capture operation is only performed when a valid level is detected twice, thus eliminating noise with a short pulse width.

# Figure 7-18. Control Register Settings for Pulse Width Measurement with Free-Running Counter and One Capture Register

#### (a) 16-bit timer mode control register 0n (TMC0n)



#### (b) Capture/compare control register 0n (CRC0n)



**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. See **Figures 7-3** to **7-6**.

n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148



#### Figure 7-19. Configuration Diagram for Pulse Width Measurement with Free-Running Counter

**Remark** Frequencies without parentheses are for 16-bit timer/event counter 00, and those in parentheses are for 16-bit timer/event counter 01.





**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

### (2) Measurement of two pulse widths with free-running counter

When 16-bit timer counter 0n (TM0n) is operated in free-running mode (see **Figure 7-21**), it is possible to simultaneously measure the pulse widths of the two signals input to the TI00n pin and the TI01n pin.

When the edge specified by bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n) is input to the TI00n pin, the value of TM0n is taken into 16-bit timer capture/compare register 01n (CR01n) and an interrupt request signal (INTTM01n) is set.

Also, when the edge specified by bits 6 and 7 (ES1n0 and ES1n1) of PRM0n is input to the TI01n pin, the value of TM0n is taken into 16-bit timer capture/compare register 00n (CR00n) and an interrupt request signal (INTTM00n) is set.

Any of three edges—rising, falling, or both edges—can be selected as the valid edge of the TI00n pin and the TI01n pin, specified using bits 4 and 5 (ES0n0 and ES0n1) and bits 6 and 7 (ES1n0 and ES1n1) of PRM0n, respectively.

For valid edge detection of the TI00n and TI01n pins, sampling is performed at the interval selected by prescaler mode register 0n (PRM0n), and a capture operation is only performed when a valid level is detected twice, thus eliminating noise with a short pulse width.

#### Figure 7-21. Control Register Settings for Measurement of Two Pulse Widths with Free-Running Counter



#### (a) 16-bit timer mode control register 0n (TMC0n)

#### (b) Capture/compare control register 0n (CRC0n)



**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. For details, see **Figures 7-3** and **7-4**.

n = 0: μPD780143, 780144

n = 0, 1: *µ*PD780146, 780148, 78F0148

#### • Capture operation (free-running mode)

The capture register operation when capture trigger is input is shown below.



Figure 7-22. CR01n Capture Operation with Rising Edge Specified





#### (3) Pulse width measurement with free-running counter and two capture registers

When 16-bit timer counter 0n (TM0n) is operated in free-running mode (see **Figure 7-24**), it is possible to measure the pulse width of the signal input to the TI00n pin.

When the edge specified by bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n) is input to the TI00n pin, the value of TM0n is taken into 16-bit timer capture/compare register 01n (CR01n) and an interrupt request signal (INTTM01n) is set.

Also, when the inverse edge to that of the capture operation is input into CR01n, the value of TM0n is taken into 16-bit timer capture/compare register 00n (CR00n).

Either of two edges—rising or falling—can be selected as the valid edge of the TI00n pin specified using bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n).

For TI00n pin valid edge detection, sampling is performed at the interval selected by prescaler mode register 0n (PRM0n), and a capture operation is only performed when a valid level is detected twice, thus eliminating noise with a short pulse width.

## Figure 7-24. Control Register Settings for Pulse Width Measurement with Free-Running Counter and Two Capture Registers



#### (a) 16-bit timer mode control register 0n (TMC0n)





**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. See the description of the respective control registers for details.

n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148



Figure 7-25. Timing of Pulse Width Measurement Operation with Free-Running Counter and Two Capture Registers (with Rising Edge Specified)

#### (4) Pulse width measurement by means of restart

When input of a valid edge to the TI00n pin is detected, the count value of 16-bit timer counter 0n (TM0n) is taken into 16-bit timer capture/compare register 01n (CR01n), and then the pulse width of the signal input to the TI00n pin is measured by clearing TM0n and restarting the count operation (see **Figure 7-26**).

Either of two edges—rising or falling—can be selected using bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n).

In valid edge detection, sampling is performed using the count clock cycle selected by prescaler mode register 0n (PRM0n) and a capture operation is only performed when a valid level is detected twice, thus eliminating noise with a short pulse width.

#### Figure 7-26. Control Register Settings for Pulse Width Measurement by Means of Restart

#### (a) 16-bit timer mode control register 0n (TMC0n)



**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. For details, see **Figures 7-3** and **7-4**.

CR01n used as capture register



(with Rising Edge Specified)



**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### 7.4.4 External event counter operation

The external event counter counts the number of external clock pulses input to the TI00n pin using 16-bit timer counter 0n (TM0n).

TM0n is incremented each time the valid edge specified by prescaler mode register 0n (PRM0n) is input.

When the TM0n count value matches the 16-bit timer capture/compare register 00n (CR00n) value, TM0n is cleared to 0 and the interrupt request signal (INTTM00n) is generated.

Input a value other than 0000H to CR00n (a count operation with 1-bit pulse cannot be carried out).

Any of three edges—rising, falling, or both edges—can be selected using bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n).

Because operation is carried out only after the valid edge is detected twice by sampling using the internal clock (fx), noise with short pulse widths can be eliminated.

#### Figure 7-28. Control Register Settings in External Event Counter Mode

(a) 16-bit timer mode control register 0n (TMC0n)



### (b) Capture/compare control register 0n (CRC0n)

|       |   |   |   |   |   | CRC0n2 | CRC0n1 | CRC0n0 |                                |
|-------|---|---|---|---|---|--------|--------|--------|--------------------------------|
| CRC0n | 0 | 0 | 0 | 0 | 0 | 0/1    | 0/1    | 0      |                                |
|       |   |   | • |   |   |        |        |        | CR00n used as compare register |

**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with the external event counter. For details, see **Figures 7-3** to **7-6**.

n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148



#### Figure 7-29. Configuration Diagram of External Event Counter

**Remark** Frequencies without parentheses are for 16-bit timer/event counter 00, and those in parentheses are for 16-bit timer/event counter 01.

Figure 7-30. External Event Counter Operation Timing (with Rising Edge Specified)

| TI00n pin input  |                                       |                                    |   |
|------------------|---------------------------------------|------------------------------------|---|
| TM0n count value | X0000HX0001HX0002HX0003HX0004HX0005HX | X N-1 X N X0000HX0001HX0002HX0003H | X |
| CR00n            | N                                     |                                    |   |
| INTTM00n         |                                       | ่ <u>`</u>                         |   |

Caution When reading the external event counter count value, TM0n should be read.

#### 7.4.5 Square-wave output operation

A square wave with any selected frequency can be output at intervals of the count value preset to 16-bit timer capture/compare register 00n (CR00n).

The TO0n pin output status is reversed at intervals of the count value preset to CR00n by setting bit 0 (TOE0n) and bit 1 (TOC0n1) of 16-bit timer output control register 0n (TOC0n) to 1. This enables a square wave with any selected frequency to be output.

#### Figure 7-31. Control Register Settings in Square-Wave Output Mode

(a) 16-bit timer mode control register 0n (TMC0n)

# TMC0n3 TMC0n2 TMC0n1 OVF0n TMC0n 0 0 0 1 1 0 0 Clears and starts on match between TM0n and CR00n.







**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with square-wave output. For details, see **Figures 7-5** to **7-8**.

n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148



#### 7.4.6 One-shot pulse output operation

16-bit timer/event counter 0n can output a one-shot pulse in synchronization with a software trigger or an external trigger (TI00n pin input).

#### (1) One-shot pulse output with software trigger

A one-shot pulse can be output from the TO0n pin by setting 16-bit timer mode control register 0n (TMC0n), capture/compare control register 0n (CRC0n), and 16-bit timer output control register 0n (TOC0n) as shown in Figure 7-33, and by setting bit 6 (OSPT0n) of the TOC0n register to 1 by software.

By setting the OSPT0n bit to 1, 16-bit timer/event counter 0n is cleared and started, and its output becomes active at the count value (N) set in advance to 16-bit timer capture/compare register 01n (CR01n). After that, the output becomes inactive at the count value (M) set in advance to 16-bit timer capture/compare register 00n (CR00n)<sup>Note</sup>.

Even after the one-shot pulse has been output, the TMOn register continues its operation. To stop the TMOn register, the TMC0n3 and TMC0n2 bits of the TMC0n register must be set to 00.

- **Note** The case where N < M is described here. When N > M, the output becomes active with the CR00n register and inactive with the CR01n register.
- Cautions 1. Do not set the OSPT0n bit while the one-shot pulse is being output. To output the one-shot pulse again, wait until the current one-shot pulse output is completed.
  - 2. When using the one-shot pulse output of 16-bit timer/event counter 0n with a software trigger, do not change the level of the TI00n pin or its alternate-function port pin. Because the external trigger is valid even in this case, the timer is cleared and started even at the level of the TI00n pin or its alternate-function port pin, resulting in the output of a pulse at an undesired timing.

#### Figure 7-33. Control Register Settings for One-Shot Pulse Output with Software Trigger

#### (a) 16-bit timer mode control register 0n (TMC0n)



Caution Do not set 0000H to the CR00n and CR01n registers.

**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. For details, see **Figures 7-5** to **7-8**.

- n = 0: μPD780143, 780144
- n = 0, 1: µPD780146, 780148, 78F0148



Figure 7-34. Timing of One-Shot Pulse Output Operation with Software Trigger

Caution 16-bit timer counter 0n starts operating as soon as a value other than 00 (operation stop mode) is set to the TMC0n3 and TMC0n2 bits.

 $\textbf{Remark} \quad N < M$ 

#### (2) One-shot pulse output with external trigger

A one-shot pulse can be output from the TO0n pin by setting 16-bit timer mode control register 0n (TMC0n), capture/compare control register 0n (CRC0n), and 16-bit timer output control register 0n (TOC0n) as shown in Figure 7-35, and by using the valid edge of the TI00n pin as an external trigger.

The valid edge of the TI00n pin is specified by bits 4 and 5 (ES0n0, ES0n1) of prescaler mode register 0n (PRM0n). The rising, falling, or both the rising and falling edges can be specified.

When the valid edge of the TI00n pin is detected, the 16-bit timer/event counter is cleared and started, and the output becomes active at the count value set in advance to 16-bit timer capture/compare register 01n (CR01n). After that, the output becomes inactive at the count value set in advance to 16-bit timer capture/compare register 00n (CR00n)<sup>Note</sup>.

**Note** The case where N < M is described here. When N > M, the output becomes active with the CR00n register and inactive with the CR01n register.

#### Caution Even if the external trigger is generated again while the one-shot pulse is output, it is ignored.

#### Figure 7-35. Control Register Settings for One-Shot Pulse Output with External Trigger

#### (a) 16-bit timer mode control register 0n (TMC0n)





#### Caution Do not set 0000H to the CR00n and CR01n registers.

**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. For details, see **Figures 7-5** to **7-8**.

n = 0: μPD780143, 780144

n = 0, 1: μPD780146, 780148, 78F0148



Figure 7-36. Timing of One-Shot Pulse Output Operation with External Trigger (with Rising Edge Specified)

- Caution 16-bit timer counter 0n starts operating as soon as a value other than 00 (operation stop mode) is set to the TMC0n2 and TMC0n3 bits.
- Remark N < M

#### 7.5 Cautions for 16-Bit Timer/Event Counters 00 and 01

#### (1) Timer start errors

An error of up to one clock may occur in the time required for a match signal to be generated after timer start. This is because 16-bit timer counter 0n (TM0n) is started asynchronously to the count clock.





(2) 16-bit timer capture/compare register setting (in the mode in which clear & start occurs on match between TM0n and CR00n)

Set 16-bit timer capture/compare registers 00n, 01n (CR00n, CR01n) to other than 0000H. This means a 1-pulse count operation cannot be performed when 16-bit timer/event counter 0n is used as an event counter.

#### (3) Operation after compare register change during timer count operation

If the value after 16-bit timer capture/compare register 00n (CR00n) is changed is smaller than that of 16-bit timer counter 0n (TM0n), TM0n continues counting, overflows and then restarts counting from 0. Thus, if the value (M) after CR00n changes is smaller than that (N) before the change, it is necessary to restart the timer after changing CR00n.



Figure 7-38. Timings After Change of Compare Register During Timer Count Operation

 $\label{eq:remark} \textbf{Remark} \quad N > X > M$ 

#### (4) Capture register data retention timing

If the valid edge of the TI00n pin is input during 16-bit timer capture/compare register 01n (CR01n) read, CR01n performs a capture operation. However, the value read at this time is not guaranteed. The interrupt request flag (TMIF01n) is set upon detection of the valid edge.



#### Figure 7-39. Capture Register Data Retention Timing

#### (5) Valid edge setting

Set the valid edge of the TI00n pin after setting bits 2 and 3 (TMC0n2 and TMC0n3) of 16-bit timer mode control register 0n (TMC0n) to 0, 0, respectively, and then stopping timer operation. The valid edge is set using bits 4 and 5 (ES0n0 and ES0n1) of prescaler mode register 0n (PRM0n).

#### (6) Re-triggering one-shot pulse

#### (a) One-shot pulse output by software

When a one-shot pulse is output, do not set the OSPT0n bit to 1. Do not output the one-shot pulse again until INTTM00n, which occurs upon a match with the CR00n register, or INTTM01n, which occurs upon a match with the CR01n register, occurs.

#### (b) One-shot pulse output with external trigger

If the external trigger occurs again while a one-shot pulse is output, it is ignored.

#### (c) One-shot pulse output function

When using the one-shot pulse output of 16-bit timer/event counter 0n with a software trigger, do not change the level of the TI00n pin or its alternate function port pin.

Because the external trigger is valid even in this case, the timer is cleared and started even at the level of the TI00n pin or its alternate function port pin, resulting in the output of a pulse at an undesired timing.

#### (7) Operation of OVF0n flag

<1> The OVF0n flag is set to 1 in the following case.

When of the following modes: the mode in which clear & start occurs on a match between TM0n and CR00n, the mode in which clear & start occurs on a TI0n valid edge, or the free-running mode, is selected

CR00n is set to FFFH  $\downarrow$ 

↓

TMOn is counted up from FFFFH to 0000H.



<2> Even if the OVF0n flag is cleared before the next count clock (before TM0n becomes 0001H) after the occurrence of TM0n overflow, the OVF0n flag is re-set newly and clear is disabled.

#### (8) Conflicting operations

Conflict between the read period of the 16-bit timer capture/compare register (CR00n/CR01n) and capture trigger input (CR00n/CR01n used as capture register)

Capture trigger input has priority. The data read from CR00n/CR01n is undefined.

#### (9) Timer operation

- <1> Even if 16-bit timer counter 0n (TM0n) is read, the value is not captured by 16-bit timer capture/compare register 01n (CR01n).
- <2> Regardless of the CPU's operation mode, when the timer stops, the input signals to the TI00n/TI01n pins are not acknowledged.
- <3> The one-shot pulse output mode operates correctly only in the free-running mode and the mode in which clear & start occurs at the TI00n valid edge. In the mode in which clear & start occurs on a match between the TM0n register and CR00n register, one-shot pulse output is not possible because an overflow does not occur.

#### (10) Capture operation

- <1> If TI00n valid edge is specified as the count clock, a capture operation by the capture register specified as the trigger for TI00n is not possible.
- <2> To ensure the reliability of the capture operation, the capture trigger requires a pulse two times longer than the count clock selected by prescaler mode register 0n (PRM0n).
- <3> The capture operation is performed at the falling edge of the count clock. An interrupt request input (INTTM00n/INTTM01n), however, is generated at the rise of the next count clock.

#### (11) Compare operation

- <1> When the 16-bit timer capture/compare register (CR00n/CR01n) is overwritten during timer operation, a match interrupt may be generated or a clear operation may not be performed normally if that value is close to or larger than the timer value.
- <2> A capture operation may not be performed for CR00n/CR01n set in compare mode even if a capture trigger has been input.

#### (12) Edge detection

- <1> If the TI00n or TI01n pin is high level immediately after system reset and the rising edge or both the rising and falling edges are specified as the valid edge of the TI00n or TI01n pin to enable the 16-bit timer counter 0n (TM0n) operation, a rising edge is detected immediately after the operation is enabled. Be careful therefore when pulling up the TI00n or TI01n pin. However, the rising edge is not detected at restart after the operation has been stopped once.
- <2> The sampling clock used to remove noise differs when the TI00n valid edge is used as the count clock and when it is used as a capture trigger. In the former case, the count clock is fx, and in the latter case the count clock is selected by prescaler mode register 0n (PRM0n). The capture operation is started only after a valid edge is detected twice by sampling, thus eliminating noise with a short pulse width.

#### CHAPTER 8 8-BIT TIMER/EVENT COUNTERS 50 AND 51

#### 8.1 Functions of 8-Bit Timer/Event Counters 50 and 51

8-bit timer/event counters 50 and 51 have the following functions.

- Interval timer
- External event counter
- Square-wave output
- PWM output

Figures 8-1 and 8-2 show the block diagrams of 8-bit timer/event counters 50 and 51.







#### Figure 8-2. Block Diagram of 8-Bit Timer/Event Counter 51

#### 8.2 Configuration of 8-Bit Timer/Event Counters 50 and 51

8-bit timer/event counters 50 and 51 consist of the following hardware.

#### Table 8-1. Configuration of 8-Bit Timer/Event Counters 50 and 51

| Item              | Configuration                                                                                                                                                                         |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer register    | 8-bit timer counter 5n (TM5n)                                                                                                                                                         |
| Register          | 8-bit timer compare register 5n (CR5n)                                                                                                                                                |
| Timer output      | 1 (TO5n)                                                                                                                                                                              |
| Control registers | Timer clock selection register 5n (TCL5n)<br>8-bit timer mode control register 5n (TMC5n)<br>Port mode register 1 (PM1) <sup>Note</sup> or port mode register 3 (PM3) <sup>Note</sup> |

Note See Figure 4-11 Block Diagram of P16 and P17 and Figure 4-14 Block Diagram of P33.

#### (1) 8-bit timer counter 5n (TM5n)

TM5n is an 8-bit register that counts the count pulses and is read-only.

The counter is incremented in synchronization with the rising edge of the count clock.

When the count value is read during operation, count clock input is temporary stopped, and then the count value is read. In the following situations, the count value is cleared to 00H.

- <1> RESET input
- <2> When TCE5n is cleared
- <3> When TM5n and CR5n match in the mode in which clear & start occurs upon a match of the TM5n and CR5n.

#### (2) 8-bit timer compare register 5n (CR5n)

CR5n can be read and written by an 8-bit memory manipulation instruction.

Except in PWM mode, the value set in CR5n is constantly compared with the 8-bit timer counter 5n (TM5n) count value, and an interrupt request (INTTM5n) is generated if they match.

In PWM mode, when the TO5n pin becomes active due to a TM5n overflow and the values of TM5n and CR5n match, the TO5n pin becomes inactive.

The value of CR5n can be set within 00H to FFH.

- Cautions 1. In the mode in which clear & start occurs on a match of TM5n and CR5n (TMC5n6 = 0), do not write other values to CR5n during operation.
  - 2. In PWM mode, make the CR5n rewrite period 3 count clocks of the count clock (clock selected by TCL5n) or more.

**Remark** n = 0, 1

#### 8.3 Registers Controlling 8-Bit Timer/Event Counters 50 and 51

The following three registers are used to control 8-bit timer/event counters 50 and 51.

- Timer clock selection register 5n (TCL5n)
- 8-bit timer mode control register 5n (TMC5n)
- Port mode register 1 (PM1) or port mode register 3 (PM3)

#### (1) Timer clock selection register 5n (TCL5n)

This register sets the count clock of 8-bit timer/event counter 5n and the valid edge of TI5n input. TCL5n can be set by an 8-bit memory manipulation instruction. RESET input clears TCL5n to 00H.

#### **Remark** n = 0, 1

#### Address: FF6AH After reset: 00H R/W Symbol 7 6 5 4 3 2 1 0 TCL50 0 0 0 0 0 TCL502 TCL501 TCL500 TCL502 TCL501 TCL500 Count clock selection TI50 falling edge 0 0 0 0 0 TI50 rising edge 1 0 1 0 fx (10 MHz) 0 1 1 fx/2 (5 MHz) 1 0 fx/2<sup>2</sup> (2.5 MHz) 0 fx/2<sup>6</sup> (156.25 kHz) 0 1 1 1 0 fx/28 (39.06 kHz) 1

fx/2<sup>13</sup> (1.22 kHz)

#### Figure 8-3. Format of Timer Clock Selection Register 50 (TCL50)

#### Cautions 1. When rewriting TCL50 to other data, stop the timer operation beforehand.

1

2. Be sure to set bits 3 to 7 to 0.

1

Remarks 1. fx: X1 input clock oscillation frequency

1

**2.** Figures in parentheses apply to operation at fx = 10 MHz.

| Address: FF | 8CH After | reset: 00H | R/W    |                               |      |                |        |        |
|-------------|-----------|------------|--------|-------------------------------|------|----------------|--------|--------|
| Symbol      | 7         | 6          | 5      | 4                             | 3    | 2              | 1      | 0      |
| TCL51       | 0         | 0          | 0      | 0                             | 0    | TCL512         | TCL511 | TCL510 |
|             |           |            |        |                               |      |                |        |        |
|             | TCL512    | TCL511     | TCL510 |                               | Cou  | nt clock selec | tion   |        |
|             | 0         | 0          | 0      | TI51 falling e                | edge |                |        |        |
|             | 0         | 0          | 1      | TI51 rising edge              |      |                |        |        |
|             | 0         | 1          | 0      | fx (10 MHz)                   |      |                |        |        |
|             | 0         | 1          | 1      | fx/2 (5 MHz)                  |      |                |        |        |
|             | 1         | 0          | 0      | fx/2⁴ (625 kH                 | lz)  |                |        |        |
|             | 1         | 0          | 1      | fx/2 <sup>6</sup> (156.25     | kHz) |                |        |        |
|             | 1         | 1          | 0      | fx/2 <sup>°</sup> (39.06 kHz) |      |                |        |        |
|             | 1         | 1          | 1      | fx/2 <sup>12</sup> (2.44 k    | Hz)  |                |        |        |

#### Figure 8-4. Format of Timer Clock Selection Register 51 (TCL51)

### 

#### 2. Be sure to set bits 3 to 7 to 0.

Remarks 1. fx: X1 input clock oscillation frequency

**2.** Figures in parentheses apply to operation at fx = 10 MHz.

#### (2) 8-bit timer mode control register 5n (TMC5n)

TMC5n is a register that performs the following five types of settings.

- <1> 8-bit timer counter 5n (TM5n) count operation control
- <2> 8-bit timer counter 5n (TM5n) operating mode selection
- <3> Timer output F/F (flip-flop) status setting
- <4> Active level selection in timer F/F control or PWM (free-running) mode
- <5> Timer output control

TMC5n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

#### **Remark** n = 0, 1

#### Figure 8-5. Format of 8-Bit Timer Mode Control Register 50 (TMC50)

Address: FF6BH After reset: 00H R/W

| Symbol | 7     | 6      | 5 | 4 | 3     | 2     | 1      | 0     |
|--------|-------|--------|---|---|-------|-------|--------|-------|
| TMC50  | TCE50 | TMC506 | 0 | 0 | LVS50 | LVR50 | TMC501 | TOE50 |

| TCE50 | TM50 count operation control                                    |
|-------|-----------------------------------------------------------------|
| 0     | After clearing to 0, count operation disabled (counter stopped) |
| 1     | Count operation start                                           |

| TMC506 | TM50 operating mode selection                                       |
|--------|---------------------------------------------------------------------|
| 0      | Mode in which clear & start occurs on a match between TM50 and CR50 |
| 1      | PWM (free-running) mode                                             |

| LVS50 | LVR50 | Timer output F/F status setting |
|-------|-------|---------------------------------|
| 0     | 0     | No change                       |
| 0     | 1     | Timer output F/F reset (0)      |
| 1     | 0     | Timer output F/F set (1)        |
| 1     | 1     | Setting prohibited              |

| TMC501 | In other modes (TMC506 = 0)  | In PWM mode (TMC506 = 1) |  |  |
|--------|------------------------------|--------------------------|--|--|
|        | Timer F/F control            | Active level selection   |  |  |
| 0      | Inversion operation disabled | Active-high              |  |  |
| 1      | Inversion operation enabled  | Active-low               |  |  |

| TOE50 | Timer output control                             |  |  |  |  |
|-------|--------------------------------------------------|--|--|--|--|
| 0     | Output disabled (TO50 pin outputs the low level) |  |  |  |  |
| 1     | Output enabled                                   |  |  |  |  |

#### Figure 8-6. Format of 8-Bit Timer Mode Control Register 51 (TMC51)

| Address: FF43H After reset: 00H |       | R/W    |   |   |       |       |        |       |
|---------------------------------|-------|--------|---|---|-------|-------|--------|-------|
| Symbol                          | 7     | 6      | 5 | 4 | 3     | 2     | 1      | 0     |
| TMC51                           | TCE51 | TMC516 | 0 | 0 | LVS51 | LVR51 | TMC511 | TOE51 |

| TCE51 | TM51 count operation control                                    |
|-------|-----------------------------------------------------------------|
| 0     | After clearing to 0, count operation disabled (counter stopped) |
| 1     | Count operation start                                           |

|                           | TMC516 | TM51 operating mode selection                                         |  |  |
|---------------------------|--------|-----------------------------------------------------------------------|--|--|
|                           | 0      | 0 Mode in which clear & start occurs on a match between TM51 and CR51 |  |  |
| 1 PWM (free-running) mode |        | PWM (free-running) mode                                               |  |  |

| LVS51 | LVR51 | Timer output F/F status setting |  |
|-------|-------|---------------------------------|--|
| 0     | 0     | change                          |  |
| 0     | 1     | mer output F/F reset (0)        |  |
| 1     | 0     | mer output F/F set (1)          |  |
| 1     | 1     | Setting prohibited              |  |

| TMC511 | In other modes (TMC516 = 0)  | In PWM mode (TMC516 = 1) |  |
|--------|------------------------------|--------------------------|--|
|        | Timer F/F control            | Active level selection   |  |
| 0      | Inversion operation disabled | Active-high              |  |
| 1      | Inversion operation enabled  | Active-low               |  |

| TOE51                                              | Timer output control |
|----------------------------------------------------|----------------------|
| 0 Output disabled (TO51 pin outputs the low level) |                      |
| 1 Output enabled                                   |                      |

Cautions 1. To clear TCE5n to 0, set the interrupt mask flag (TMMK5n) to 1 beforehand. Otherwise, an interrupt may occur when TCE5n is cleared. TCE5n is cleared to 0 as follows.

| TMMK5n = 1; | Mask set                     |
|-------------|------------------------------|
| TCE5n = 0;  | Timer clear                  |
| TMIF5n = 0; | Interrupt request flag clear |
| TMMK5n = 0; | Mask clear                   |
| •           |                              |
| TCE5n = 1;  | Timer start                  |

- 2. The settings of LVS5n and LVR5n are valid in other than PWM mode.
- 3. Do not rewrite TMC5n1 and TOE5n simultaneously.
- 4. When switching to the PWM mode, do not rewrite TM5n6 and LVS5n or LVR5n simultaneously.
- 5. To rewrite TMC5n6, stop operation beforehand.

**Remarks 1.** In PWM mode, PWM output is made inactive by setting TCE5n to 0.

- 2. If LVS5n and LVR5n are read after data is set, 0 is read.
- **3.** The values of the TMC5n6, LVS5n, LVR5n, TMC5n1, and TOE5n bits are reflected at the TO5n pin regardless of the value of TCE5n.
- **4.** n = 0, 1

#### (3) Port mode register 1 (PM1) and 3 (PM3)

These registers set port 1 and 3 input/output in 1-bit units.

When using the P17/TO50/TI50 and P33/TO51/TI51 pins for timer output, set PM17 and PM33 and the output latches of P17 and P33 to 0.

PM1 and PM3 can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets these registers to FFH.

#### Figure 8-7. Format of Port Mode Register 1 (PM1)

Address: FF21H After reset: FFH R/W Symbol 7 6 5 4 3 2 1 0 PM1 PM17 PM16 PM15 PM14 PM13 PM12 PM11 PM10

| PM1n P1n pin I/O mode selection (n = 0 to 7) |                                  | P1n pin I/O mode selection (n = 0 to 7) |  |
|----------------------------------------------|----------------------------------|-----------------------------------------|--|
|                                              | 0 Output mode (output buffer on) |                                         |  |
|                                              | 1                                | 1 Input mode (output buffer off)        |  |

#### Figure 8-8. Format of Port Mode Register 3 (PM3)

| Address: FF23H After rese |   | After reset: FF | H R/W |   |      |      |      |      |
|---------------------------|---|-----------------|-------|---|------|------|------|------|
| Symbol                    | 7 | 6               | 5     | 4 | 3    | 2    | 1    | 0    |
| PM3                       | 0 | 0               | 0     | 0 | PM33 | PM32 | PM31 | PM30 |

| PM3n | P3n pin I/O mode selection $(n = 0 \text{ to } 3)$ |  |
|------|----------------------------------------------------|--|
| 0    | Output mode (output buffer on)                     |  |
| 1    | Input mode (output buffer off)                     |  |

#### 8.4 Operations of 8-Bit Timer/Event Counters 50 and 51

#### 8.4.1 Operation as interval timer

8-bit timer/event counter 5n operates as an interval timer that generates interrupt requests repeatedly at intervals of the count value preset to 8-bit timer compare register 5n (CR5n).

When the count value of 8-bit timer counter 5n (TM5n) matches the value set to CR5n, counting continues with the TM5n value cleared to 0 and an interrupt request signal (INTTM5n) is generated.

The count clock of TM5n can be selected with bits 0 to 2 (TCL5n0 to TCL5n2) of timer clock selection register 5n (TCL5n).

#### [Setting]

- <1> Set the registers.
  - TCL5n: Select the count clock.
  - CR5n: Compare value
  - TMC5n: Stop the count operation, select the mode in which clear & start occurs on a match of TM5n and CR5n.

 $(TMC5n = 0000 \times \times 0B \times = Don't care)$ 

- <2> After TCE5n = 1 is set, the count operation starts.
- <3> If the values of TM5n and CR5n match, INTTM5n is generated (TM5n is cleared to 00H).
- <4> INTTM5n is generated repeatedly at the same interval.
  Set TCEEn to 0 to stop the sound exerction

Set TCE5n to 0 to stop the count operation.

#### Caution Do not write other values to CR5n during operation.

#### Figure 8-9. Interval Timer Operation Timing (1/2)



**Remark** Interval time =  $(N + 1) \times t$ N = 00H to FFH n = 0, 1





(b) When CR5n = 00H





**Remark** n = 0, 1

#### 8.4.2 Operation as external event counter

The external event counter counts the number of external clock pulses to be input to TI5n by 8-bit timer counter 5n (TM5n).

TM5n is incremented each time the valid edge specified by timer clock selection register 5n (TCL5n) is input. Either the rising or falling edge can be selected.

When the TM5n count value matches the value of 8-bit timer compare register 5n (CR5n), TM5n is cleared to 0 and an interrupt request signal (INTTM5n) is generated.

Whenever the TM5n value matches the value of CR5n, INTTM5n is generated.

#### [Setting]

<1> Set each register.

- TCL5n: Select TI5n input edge.
  - TI5n falling edge  $\rightarrow$  TCL5n = 00H
  - TI5n rising edge  $\rightarrow$  TCL5n = 01H
- CR5n: Compare value
- TMC5n: Stop the count operation, select the mode in which clear & start occurs on match of TM5n and CR5n, disable the timer F/F inversion operation, disable timer output. (TMC5n = 0000××00B × = Don't care)
- <2> When TCE5n = 1 is set, the number of pulses input from TI5n is counted.
- <3> When the values of TM5n and CR5n match, INTTM5n is generated (TM5n is cleared to 00H).
- <4> After these settings, INTTM5n is generated each time the values of TM5n and CR5n match.

#### Figure 8-10. External Event Counter Operation Timing (with Rising Edge Specified)



**Remark** N = 00H to FFH n = 0. 1

n = 0, -

#### 8.4.3 Square-wave output operation

A square wave with any selected frequency is output at intervals of the value preset to 8-bit timer compare register 5n (CR5n).

The TO5n pin output status is inverted at intervals of the count value preset to CR5n by setting bit 0 (TOE5n) of 8bit timer mode control register 5n (TMC5n) to 1. This enables a square wave with any selected frequency to be output (duty = 50%).

#### [Setting]

<1> Set each register.

- Set the port latches (P17 and P33)<sup>Note</sup> and port mode registers (PM17 and PM33)<sup>Note</sup> to 0.
- TCL5n: Select the count clock.
- CR5n: Compare value
- TMC5n: Stop the count operation, select the mode in which clear & start occurs on a match of TM5n and CR5n.

| LVS5n | LVR5n | Timer Output F/F Status Setting |
|-------|-------|---------------------------------|
| 1     | 0     | High-level output               |
| 0     | 1     | Low-level output                |

Timer output F/F inversion enabled Timer output enabled (TMC5n = 00001011B or 00000111B)

- <2> After TCE5n = 1 is set, the count operation starts.
- <3> The timer output F/F is inverted by a match of TM5n and CR5n. After INTTM5n is generated, TM5n is cleared to 00H.
- <4> After these settings, the timer output F/F is inverted at the same interval and a square wave is output from TO5n.

The frequency is as follows.

Frequency = fcnt/2 (N + 1) (N: 00H to FFH, fcnt: Count clock)

- Note 8-bit timer/event counter 50: P17, PM17 8-bit timer/event counter 51: P33, PM33
- Caution Do not write other values to CR5n during operation.

#### $\textbf{Remark} \quad n=0, \ 1$

|                       | Figure 8-11. Squar | re-Wave Output Operation Timing |                 |
|-----------------------|--------------------|---------------------------------|-----------------|
| Count clock           |                    |                                 |                 |
| TMn count value<br>Co | 00H X 01H X 02H X  | X N-1 X N X 00H X 01H X 02H X   | X N-1 X N X 00H |
| CR5n                  | N                  |                                 |                 |
| TO5n <sup>Note</sup>  |                    |                                 |                 |

**Note** The initial value of TO5n output can be set by bits 2 and 3 (LVR5n, LVS5n) of 8-bit timer mode control register 5n (TMC5n).

#### 8.4.4 PWM output operation

8-bit timer/event counter 5n operates as a PWM output when bit 6 (TMC5n6) of 8-bit timer mode control register 5n (TMC5n) is set to 1.

The duty ratio pulse determined by the value set to 8-bit timer compare register 5n (CR5n) is output from TO5n.

Set the active level width of the PWM pulse to CR5n; the active level can be selected with bit 1 (TMC5n1) of TMC5n.

The count clock can be selected with bits 0 to 2 (TCL5n0 to TCL5n2) of timer clock selection register 5n (TCL5n). PWM output can be enabled/disabled with bit 0 (TOE5n) of TMC5n.

### Caution In PWM mode, make the CR5n rewrite period 3 count clocks of the count clock (clock selected by TCL5n) or more.

#### (1) PWM output basic operation

#### [Setting]

<1> Set each register.

- Set the port latches (P17, P33)<sup>Note</sup> and port mode registers (PM17, PM33)<sup>Note</sup> to 0.
- TCL5n: Select the count clock.
- CR5n: Compare value
- TMC5n: Stop the count operation, select PWM mode.
  - The timer output F/F is not changed.

| TMC5n1 | Active Level Selection |
|--------|------------------------|
| 0      | Active-high            |
| 1      | Active-low             |

Timer output enabled

(TMC5n = 01000001B or 01000011B)

- <2> The count operation starts when TCE5n = 1. Set TCE5n to 0 to stop the count operation.
- Note 8-bit timer/event counter 50: P17, PM17 8-bit timer/event counter 51: P33, PM33

#### [PWM output operation]

- <1> PWM output (output from TO5n) outputs an inactive level after the count operation starts until an overflow occurs.
- <2> When an overflow occurs, the active level set in <1> above is output. The active level is output until CR5n matches the count value of 8-bit timer counter 5n (TM5n).
- <3> After the CR5n matches the count value, the inactive level is output until an overflow occurs again.
- <4> Operations <2> and <3> are repeated until the count operation stops.
- <5> When the count operation is stopped with TCE5n = 0, PWM output becomes inactive.

**Remark** n = 0, 1



Figure 8-12. PWM Output Operation Timing



#### (2) Operation with CR5n changed

Figure 8-13. Timing of Operation with CR5n Changed

### (a) CR5n value is changed from N to M before clock rising edge of FFH $\rightarrow$ Value is reloaded to CR5n at overflow immediately after change.









#### 8.5 Cautions for 8-Bit Timer/Event Counters 50 and 51

#### (1) Timer start error

An error of up to one clock may occur in the time required for a match signal to be generated after timer start. This is because 8-bit timer counters 50 and 51 (TM50, TM51) are started asynchronously to the count clock.







#### CHAPTER 9 8-BIT TIMERS H0 AND H1

#### 9.1 Functions of 8-Bit Timers H0 and H1

8-bit timers H0 and H1 have the following functions.

- 8-bit-accuracy interval timer
- 8-bit-accuracy PWM pulse generator mode
- 8-bit-accuracy carrier generator mode (8-bit timer H1 only)

#### 9.2 Configuration of 8-Bit Timers H0 and H1

8-bit timers H0 and H1 consist of the following hardware.

#### Table 9-1. Configuration of 8-Bit Timers H0 and H1

| Item                                         | Configuration                                                                                               |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| Timer register 8-bit timer counter Hn (TMHn) |                                                                                                             |
| Registers                                    | 8-bit timer H compare register 0n (CMP0n)<br>8-bit timer H compare register 1n (CMP1n)                      |
| Timer output                                 | Two outputs (TOHn)                                                                                          |
| Control registers                            | 8-bit timer H mode register n (TMHMDn)<br>8-bit timer H carrier control register 1 (TMCYC1) <sup>Note</sup> |

Note 8-bit timer H1 only

#### **Remark** n = 0, 1

Figures 9-1 and 9-2 show the block diagrams.









#### (1) 8-bit timer H compare register 0n (CMP0n)

This register can be read/written by an 8-bit memory manipulation instruction. RESET input clears this register to 00H.



Caution This register cannot be rewritten during timer count operation.

#### (2) 8-bit timer H compare register 1n (CMP1n)

This register can be read/written by an 8-bit memory manipulation instruction. RESET input clears this register to 00H.



The CMP1n register can be rewritten during timer count operation.

An interrupt request signal (INTTMHn) is generated if the values of the timer counter and CMP1n register match after setting the CMP1n register. The timer counter value is cleared at the same time. If the CMP1n register value is rewritten during timer operation, reloading is performed at the timing at which the counter value and CMP1n register value match. If the transfer timing and writing from CPU to CMP1n register conflict, transfer is not performed.

Caution In the PWM pulse generator mode and carrier generator mode, be sure to set the CMP1n register when starting the timer count operation (TMHEn = 1) after the timer count operation was stopped (TMHEn = 0) (be sure to set again even if setting the same value to the CMP1n register).

**Remark** n = 0, 1

#### 9.3 Registers Controlling 8-Bit Timers H0 and H1

8-bit timers H0 and H1 are controlled by 8-bit timer H mode registers 0 and 1 (TMHMD0, TMHMD1) and 8-bit timer H carrier control register 1 (TMCYC1)<sup>Note</sup>.

Note 8-bit timer H1 only

#### (1) 8-bit timer H mode registers 0 and 1 (TMHMD0, TMHMD1)

These registers control the mode of timer H. These registers can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears these registers to 00H.

#### Figure 9-3. Format of 8-Bit Timer H Mode Register 0 (TMHMD0)

Address: FF69H After reset: 00H R/W

TMHMD0

| 7     | 6     | 5     | 4     | 3      | 2      | 1      | 0     |
|-------|-------|-------|-------|--------|--------|--------|-------|
| TMHE0 | CKS02 | CKS01 | CKS00 | TMMD01 | TMMD00 | TOLEV0 | TOEN0 |

| TMHE0 | Timer operation enable                                                   |  |  |  |
|-------|--------------------------------------------------------------------------|--|--|--|
| 0     | Stops timer count operation                                              |  |  |  |
| 1     | Enables timer count operation (count operation started by inputting cloc |  |  |  |

| CKS02 | CKS01            | CKS00 |                    | Count clock (fcnt) selection |
|-------|------------------|-------|--------------------|------------------------------|
| 0     | 0                | 0     | fx                 | (10 MHz)                     |
| 0     | 0                | 1     | fx/2               | (5 MHz)                      |
| 0     | 1                | 0     | fx/2 <sup>2</sup>  | (2.5 MHz)                    |
| 0     | 1                | 1     | fx/2 <sup>6</sup>  | (156.25 kHz)                 |
| 1     | 0                | 0     | fx/2 <sup>10</sup> | (9.77 kHz)                   |
| 1     | 0                | 1     | TO50               |                              |
| Oth   | Other than above |       |                    | prohibited                   |

| TMMD01           | TMMD00 | Timer operation mode     |  |
|------------------|--------|--------------------------|--|
| 0                | 0      | Interval timer mode      |  |
| 1                | 0      | PWM pulse generator mode |  |
| Other than above |        | Setting prohibited       |  |

| TOLEV0 | Timer output level control (in default mode) |
|--------|----------------------------------------------|
| 0      | Low level                                    |
| 1      | High level                                   |

| TOEN0 | Timer output control |
|-------|----------------------|
| 0     | Disables output      |
| 1     | Enables output       |

Cautions 1. When TMHE0 = 1, setting the other bits of the TMHMD0 register is prohibited.

In the PWM pulse generator mode, be sure to set 8-bit timer H compare register 10 (CMP10) when starting the timer count operation (TMHE0 = 1) after the timer count operation was stopped (TMHE0 = 0) (be sure to set again even if setting the same value to the CMP10 register).

#### Remarks 1. fx: X1 input clock oscillation frequency

2. Figures in parentheses apply to operation at fx = 10 MHz

\*

#### Figure 9-4. Format of 8-Bit Timer H Mode Register 1 (TMHMD1)

Address: FF6CH After reset: 00H R/W

|        | 7     | 6     | 5     | 4     | 3      | 2      | 1      | 0     |
|--------|-------|-------|-------|-------|--------|--------|--------|-------|
| TMHMD1 | TMHE1 | CKS12 | CKS11 | CKS10 | TMMD11 | TMMD10 | TOLEV1 | TOEN1 |

| TMHE1 | Timer operation enable                                                     |
|-------|----------------------------------------------------------------------------|
| 0     | Stops timer count operation                                                |
| 1     | Enables timer count operation (count operation started by inputting clock) |

| CKS12            | CKS11 | CKS10   | Count clock (fcnt) selection  |                   |  |
|------------------|-------|---------|-------------------------------|-------------------|--|
| 0                | 0     | 0       | fx                            | (10 MHz)          |  |
| 0                | 0     | 1       | fx/2 <sup>2</sup>             | (2.5 MHz)         |  |
| 0                | 1     | 0       | fx/24                         | (625 kHz)         |  |
| 0                | 1     | 1       | fx/2 <sup>6</sup>             | (156.25 kHz)      |  |
| 1                | 0     | 0       | fx/2 <sup>12</sup> (2.44 kHz) |                   |  |
| 1                | 0     | 1       | fr/27                         | (1.88 kHz (TYP.)) |  |
| Other than above |       | Setting | prohibited                    |                   |  |

| TMMD11           | TMMD10 | Timer operation mode     |  |  |
|------------------|--------|--------------------------|--|--|
| 0                | 0      | Interval timer mode      |  |  |
| 0                | 1      | Carrier generator mode   |  |  |
| 1                | 0      | PWM pulse generator mode |  |  |
| Other than above |        | Setting prohibited       |  |  |

| TOLEV1 | Timer output level control (in default mode) |
|--------|----------------------------------------------|
| 0      | Low level                                    |
| 1      | High level                                   |

| TOEN1 | Timer output control |
|-------|----------------------|
| 0     | Disables output      |
| 1     | Enables output       |

- Cautions 1. When TMHE1 = 1, setting the other bits of the TMHMD1 register is prohibited.
  - 2. In the PWM pulse generator mode and carrier generator mode, be sure to set 8-bit timer H compare register 11 (CMP11) when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register).
    - 3. When the carrier generator mode is used, set so that the count clock frequency of TMH1 becomes more than 6 times the count clock frequency of TM51.

Remarks 1. fx: X1 input clock oscillation frequency

- **2.** fR: Ring-OSC clock oscillation frequency
- **3.** Figures in parentheses apply to operation at fx = 10 MHz,  $f_R = 240$  kHz (TYP.).

# (2) 8-bit timer H carrier control register 1 (TMCYC1)

This register controls the remote control output and carrier pulse output status of 8-bit timer H1. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

# Figure 9-5. Format of 8-Bit Timer H Carrier Control Register 1 (TMCYC1)

| Address: FF | 6DH Af | ter reset: 0 | 0H R/W | Note |   |      |       |      |
|-------------|--------|--------------|--------|------|---|------|-------|------|
|             | 7      | 6            | 5      | 4    | 3 | 2    | 1     | 0    |
| TMCYC1      | 0      | 0            | 0      | 0    | 0 | RMC1 | NRZB1 | NRZ1 |
|             |        |              |        |      |   |      |       |      |

| RMC1 | NRZB1 | Remote control output |
|------|-------|-----------------------|
| 0    | 0     | Low-level output      |
| 0    | 1     | High-level output     |
| 1    | 0     | Low-level output      |
| 1    | 1     | Carrier pulse output  |

| NRZ1 | Carrier pulse output status flag                              |  |
|------|---------------------------------------------------------------|--|
| 0    | Carrier output disabled status (low-level status)             |  |
| 1    | Carrier output enabled status                                 |  |
|      | (RMC1 = 1: Carrier pulse output, RMC1 = 0: High-level status) |  |

Note Bit 0 is read-only.

# 9.4 Operation of 8-Bit Timers H0 and H1

# 9.4.1 Operation as interval timer

When 8-bit timer counter Hn and compare register 0n (CMP0n) match, an interrupt request signal (INTTMHn) is generated and 8-bit timer counter Hn is cleared to 00H.

Compare register 1n (CMP1n) is not used in interval timer mode. Since a match of 8-bit timer counter Hn and the CMP1n register is not detected even if the CMP1n register is set, timer output is not affected.

# (1) Usage

Generates the INTTMHn signal repeatedly at the same interval.

<1> Set each register.

#### Figure 9-6. Register Setting in Interval Timer Mode



# (i) Setting timer H mode register n (TMHMDn)

# (ii) CMP0n register setting

- Compare value (N)
- <2> Count operation starts when TMHEn = 1.
- <3> When the values of 8-bit timer counter Hn and the CMP0n register match, the INTTMHn signal is generated and 8-bit timer counter Hn is cleared to 00H.

Interval timer = (N +1)/fCNT

<4> Subsequently, the INTTMHn signal is generated at the same interval. To stop the count operation, set TMHEn to 0.

**Remark** n = 0, 1

# (2) Timing chart

The timing in interval timer mode is shown below.





# (a) Basic operation

- <1> The count operation is enabled by setting the TMHEn bit to 1. The count clock starts counting no more than 1 clock after the operation is enabled.
- <2> When the values of 8-bit timer counter Hn and the CMP0n register match, the value of 8-bit timer counter Hn is cleared, the TOHn output level is inverted, and the INTTMHn signal is output.
- <3> The INTTMHn signal and TOHn output become inactive by setting the TMHEn bit to 0 during timer Hn operation. If these are inactive from the first, the level is retained.

N = 00H to FFH

**Remark** n = 0, 1



# Figure 9-7. Timing of Interval Timer Operation (2/2)



# 9.4.2 Operation as PWM pulse generator

In PWM mode, a pulse with an arbitrary duty and arbitrary cycle can be output.

8-bit timer compare register 0n (CMP0n) controls the cycle of timer output (TOHn). Rewriting the CMP0n register during timer operation is prohibited.

8-bit timer compare register 1n (CMP1n) controls the duty of timer output (TOHn). Rewriting the CMP1n register during timer operation is possible.

The operation in PWM mode is as follows.

TOHn output becomes active and 8-bit timer counter Hn is cleared to 0 when 8-bit timer counter Hn and the CMP0n register match after the timer count is started. TOHn output becomes inactive when 8-bit timer counter Hn and the CMP1n register match.

# (1) Usage

In PWM mode, a pulse for which an arbitrary duty and arbitrary cycle can be set is output.

<1> Set each register.

# Figure 9-8. Register Setting in PWM Pulse Generator Mode

### (i) Setting timer H mode register n (TMHMDn)



### (ii) Setting CMP0n register

• Compare value (N): Cycle setting

# (iii) Setting CMP1n register

• Compare value (M): Duty setting

**Remarks 1.** n = 0, 1

- **2.**  $00H \le CMP1n (M) < CMP0n (N) < FFH$
- <2> The count operation starts when TMHEn = 1.
- <3> The CMP0n register is the compare register that is to be compared first after counter operation is enabled. When the values of 8-bit timer counter Hn and the CMP0n register match, 8-bit timer counter Hn is cleared, an interrupt request signal (INTTMHn) is generated, and TOHn output becomes active. At the same time, the compare register to be compared with 8-bit timer counter Hn is changed from the CMP0n register to the CMP1n register.

- <4> When 8-bit timer counter Hn and the CMP1n register match, TOHn output becomes inactive and the compare register to be compared with 8-bit timer counter Hn is changed from the CMP1n register to the CMP0n register. At this time, 8-bit timer counter Hn is not cleared and the INTTMHn signal is not generated.
- <5> By performing procedures <3> and <4> repeatedly, a pulse with an arbitrary duty ratio can be obtained.
- <6> To stop the count operation, set TMHEn = 0.

If the setting value of the CMP0n register is N, the setting value of the CMP1n register is M, and the count clock frequency is fcNT, the PWM pulse output cycle and duty ratio are as follows.

PWM pulse output cycle =  $(N+1)/f_{CNT}$ Duty ratio = Inactive width : Active width = (M + 1) : (N - M)

- Cautions 1. In PWM mode, three operation clocks (signal selected using the CKSn2 to CKSn0 bits of the TMHMDn register) are required to transfer the CMP1n register value after rewriting the register.
  - Be sure to set the CMP1n register when starting the timer count operation (TMHEn = 1) after the timer count operation was stopped (TMHEn = 0) (be sure to set again even if setting the same value to the CMP1n register).

# (2) Timing chart

The operation timing in PWM mode is shown below.

Caution Make sure that the CMP1n register setting value (M) and CMP0n register setting value (N) are within the following range. 00H ≤ CMP1n (M) < CMP0n (N) < FFH

**Remark** n = 0, 1



#### Figure 9-9. Operation Timing in PWM Pulse Generator Mode (1/4)

- <1> The count operation is enabled by setting the TMHEn bit to 1. Start 8-bit timer counter Hn by masking one count clock to count up. At this time, TOHn output remains inactive (when TOLEVn = 0).
- <2> When the values of 8-bit timer counter Hn and the CMP0n register match, the TOHn output level is inverted, the value of 8-bit timer counter Hn is cleared, and the INTTMHn signal is output.
- <3> When the values of 8-bit timer counter Hn and the CMP1n register match, the level of the TOHn output is returned. At this time, the 8-bit timer counter value is not cleared and the INTTMHn signal is not output.
- <4> Setting the TMHEn bit to 0 during timer Hn operation makes the INTTMHn signal and TOHn output inactive.

**Remark** n = 0, 1



Figure 9-9. Operation Timing in PWM Pulse Generator Mode (2/4)







**Remark** n = 0, 1



# Figure 9-9. Operation Timing in PWM Pulse Generator Mode (4/4)

# (e) Operation by changing CMP1n (CMP1n = 01H $\rightarrow$ 03H, CMP0n = A5H)

- <1> The count operation is enabled by setting TMHEn = 1. Start 8-bit timer counter Hn by masking one count clock to count up. At this time, the TOHn output remains inactive (when TOLEVn = 0).
- <2> The CMP1n register value can be changed during timer counter operation. This operation is asynchronous to the count clock.
- <3> When the values of 8-bit timer counter Hn and the CMP0n register match, the value of 8-bit timer counter Hn is cleared, the TOHn output becomes active, and the INTTMHn signal is output.
- If the CMP1n register value is changed, the value is latched and not transferred to the register. When the <4> values of 8-bit timer counter Hn and the CMP1n register before the change match, the value is transferred to the CMP1n register and the CMP1n register value is changed (<2>').

However, three count clocks or more are required from when the CMP1n register value is changed to when the value is transferred to the register. If a match signal is generated within three count clocks, the changed value cannot be transferred to the register.

- <5> When the values of 8-bit timer counter Hn and the CMP1n register after the change match, the TOHn output becomes inactive. 8-bit timer counter Hn is not cleared and the INTTMHn signal is not generated.
- Setting the TMHEn bit to 0 during timer Hn operation makes the INTTMHn signal and TOHn output inactive. <6>

**Remark** n = 0, 1

### 9.4.3 Carrier generator mode operation (8-bit timer H1 only)

The carrier clock generated by 8-bit timer H1 is output in the cycle set by 8-bit timer/event counter 51.

In carrier generator mode, the output of the 8-bit timer H1 carrier pulse is controlled by 8-bit timer/event counter 51, and the carrier pulse is output from the TOH1 output.

In carrier generator mode, the connection between 8-bit timer H1 and 8-bit timer/event counter 51 is as shown below.





# (1) Carrier generation

In carrier generator mode, 8-bit timer H compare register 01 (CMP01) generates a low-level width carrier pulse waveform and 8-bit timer H compare register 11 (CMP11) generates a high-level width carrier pulse waveform. Rewriting the CMP11 register during 8-bit timer H1 operation is possible but rewriting the CMP01 register is prohibited.

# (2) Carrier output control

Carrier output is controlled by the interrupt request signal (INTTM51) of 8-bit timer/event counter 51 and the NRZ1 and RMC1 bits of the 8-bit timer H carrier control register (TMCYC1). The relationship between the outputs is shown below.

| RMC1 Bit | NRZ1 Bit | Output               |
|----------|----------|----------------------|
| 0        | 0        | Low-level output     |
| 0        | 1        | High-level output    |
| 1        | 0        | Low-level output     |
| 1        | 1        | Carrier pulse output |

To control the carrier pulse output during a count operation, the NRZ1 and NRZB1 bits of the TMCYC1 register have a master and slave bit configuration. The NRZ1 bit is read-only but the NRZB1 bit can be read and written. The INTTM51 signal is synchronized with the 8-bit timer H1 count clock and output as the INTTM5H1 signal. The INTTM5H1 signal becomes the data transfer signal of the NRZ1 bit, and the NRZB1 bit value is transferred to the NRZ1 bit. The timing for transfer from the NRZB1 bit to the NRZ1 bit is as shown below.



Figure 9-11. Transfer Timing

- <1> The INTTM51 signal is synchronized with the count clock of 8-bit timer H1 and is output as the INTTM5H1 signal.
- <2> The value of the NRZB1 bit is transferred to the NRZ1 bit at the second clock from the rising edge of the INTTM5H1 signal.
- **Note** When 8-bit timer/event counter 51 is used in the carrier generator mode, an interrupt is generated at the timing of <1>. When 8-bit timer/event counter 51 is used in a mode other than the carrier generator mode, the timing of the interrupt generation differs.
- Caution Do not rewrite the NRZB1 bit again until at least the second clock after it has been rewritten, or else the transfer from the NRZB1 bit to the NRZ1 bit is not guaranteed.

# (3) Usage

Outputs an arbitrary carrier clock from the TOH1 pin.

<1> Set each register.

# Figure 9-12. Register Setting in Carrier Generator Mode

### (i) Setting 8-bit timer H mode register 1 (TMHMD1)



# (ii) CMP01 register setting

· Compare value

# (iii) CMP11 register setting

· Compare value

### (iv) TMCYC1 register setting

- RMC1 = 1 ... Remote control output enable bit
- NRZB1 = 0/1 ... carrier output enable bit

# (v) TCL51 and TMC51 register setting

- Refer to 8.3 Registers Controlling 8-Bit Timer/Event Counters 50 and 51.
- <2> When TMHE1 = 1, 8-bit timer H1 starts counting.
- <3> When TCE51 of 8-bit timer mode control register 51 (TMC51) is set to 1, 8-bit timer/event counter 51 starts counting.
- <4> After the count operation is enabled, the first compare register to be compared is the CMP01 register. When the count value of 8-bit timer counter H1 and the CMP01 register value match, the INTTMH1 signal is generated, 8-bit timer counter H1 is cleared, and at the same time, the compare register to be compared with 8-bit timer counter H1 is switched from the CMP01 register to the CMP11 register.
- <5> When the count value of 8-bit timer counter H1 and the CMP11 register value match, the INTTMH1 signal is generated, 8-bit timer counter H1 is cleared, and at the same time, the compare register to be compared with 8-bit timer counter H1 is switched from the CMP11 register to the CMP01 register.
- <6> By performing procedures <4> and <5> repeatedly, a carrier clock is generated.
- <7> The INTTM51 signal is synchronized with 8-bit timer H1 and output as the INTTM5H1 signal. The INTTM5H1 signal becomes the data transfer signal for the NRZB1 bit, and the NRZB1 bit value is transferred to the NRZ1 bit.
- <8> When the NRZ1 bit is high level, a carrier clock is output from the TOH1 pin.
- <9> By performing the procedures above, an arbitrary carrier clock is obtained. To stop the count operation, set TMHE1 to 0.

If the setting value of the CMP01 register is 1, the setting value of the CMP11 register is M, and the count clock frequency is f<sub>CNT</sub>, the carrier clock output cycle and duty ratio are as follows.

Carrier clock output cycle =  $(1 + M + 2)/f_{CNT}$ Duty ratio = High-level width : Low-level width = (M + 1) : (1 + 1)

- Cautions 1. Be sure to set the CMP11 register when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register).
  - 2. Set so that the count clock frequency of TMH1 becomes more than 6 times the count clock frequency of TM51.

#### (4) Timing chart

The carrier output control timing is shown below.

- Cautions 1. Set the values of the CMP01 and CMP11 registers in a range of 01H to FFH.
  - 2. In the carrier generator mode, three operating clocks (signal selected by CKSH12 to CKSH10 bits of TMHMD1 register) or more are required from when the CMP11 register value is changed to when the value is transferred to the register.
  - 3. Be sure to set the RMC1 bit before the count operation is started.



#### Figure 9-13. Carrier Generator Mode Operation Timing (1/3)

(a) Operation when CMP01 = 1, CMP11 = 1

- <1> When TMHE1 = 0 and TCE51 = 0, 8-bit timer H1 operation is stopped.
- <2> When TMHE1 = 1 is set, 8-bit timer H1 starts a count operation. At that time, the carrier clock is held at the inactive level.
- <3> When the count value of 8-bit timer counter H1 matches the CMP01 register value, the first INTTMH1 signal is generated, the carrier clock signal is inverted, and the compare register to be compared with 8-bit timer counter H1 is switched from the CMP01 register to the CMP11 register. 8-bit timer counter H1 is cleared to 00H.
- <4> When the count value of 8-bit timer counter H1 matches the CMP11 register value, the INTTMH1 signal is generated, the carrier clock signal is inverted, and the compare register to be compared with 8-bit timer counter H1 is switched from the CMP11 register to the CMP01 register. 8-bit timer counter H1 is cleared to 00H. By performing procedures <3> and <4> repeatedly, a carrier clock with duty ratio fixed to 50% is generated.
- <5> When the INTTM51 signal is generated, it is synchronized with 8-bit timer H1 count clock and output as the INTTM5H1 signal.
- <6> The INTTM5H1 signal becomes the data transfer signal for the NRZB1 bit, and the NRZB1 bit value is transferred to the NRZ1 bit.
- <7> When NRZ1 = 0 is set, the TOH1 output becomes low level.



#### Figure 9-13. Carrier Generator Mode Operation Timing (2/3)

(b) Operation when CMP01 = 1, CMP11 = M (operation when carrier clock phase is asynchronous to NRZ1 phase)

- <1> When TMHE1 = 0 and TCE51 = 0, 8-bit timer H1 operation is stopped.
- <2> When TMHE1 = 1 is set, 8-bit timer H1 starts a count operation. At that time, the carrier clock is held at the inactive level.
- <3> When the count value of 8-bit timer counter H1 matches the CMP01 register value, the first INTTMH1 signal is generated, the carrier clock signal is inverted, and the compare register to be compared with 8-bit timer counter H1 is switched from the CMP01 register to the CMP11 register. 8-bit timer counter H1 is cleared to 00H.
- <4> When the count value of 8-bit timer counter H1 matches the CMP11 register value, the INTTMH1 signal is generated, the carrier clock signal is inverted, and the compare register to be compared with 8-bit timer counter H1 is switched from the CMP11 register to the CMP01 register. 8-bit timer counter H1 is cleared to 00H. By performing procedures <3> and <4> repeatedly, a carrier clock with duty ratio fixed to other than 50% is generated.
- <5> When the INTTM51 signal is generated, it is synchronized with 8-bit timer H1 count clock and output as the INTTM5H1 signal.
- <6> When the carrier clock phase becomes asynchronous to the NRZ1 bit phase, a carrier signal is output at the first rising edge of the carrier clock if NRZ1 is set to 1.
- <7> When NRZ1 = 0, the TOH1 output is held at the high level and is not changed to low level while the carrier clock is high level (from <6> and <7>, the high-level width of the carrier clock waveform is guaranteed).



# Figure 9-13. Carrier Generator Mode Operation Timing (3/3)

# (c) Operation when CMP11 is changed

- <1> When TMHE1 = 1 is set, 8-bit timer H1 starts a count operation. At that time, the carrier clock is held at the inactive level.
- <2> When the count value of 8-bit timer counter H1 matches the CMP01 register value, 8-bit timer counter H1 is cleared and the INTTMH1 signal is output.
- <3> The CMP11 register can be rewritten during 8-bit timer H1 operation, however, the changed value (L) is latched. The CMP11 register is changed when the count value of 8-bit timer counter H1 and the CMP11 register value before the change (M) match (<3>').
- <4> When the count value of 8-bit timer counter H1 and the CMP11 register value before the change (M) match, the INTTMH1 signal is output, the carrier signal is inverted, and 8-bit timer counter H1 is cleared to 00H.
- <5> The timing at which the count value of 8-bit timer counter H1 and the CMP11 register value match again is indicated by the value after the change (L).

# CHAPTER 10 WATCH TIMER

# 10.1 Functions of Watch Timer

The watch timer has the following functions.

- Watch timer
- Interval timer

The watch timer and the interval timer can be used simultaneously. Figure 10-1 shows the watch timer block diagram.





Remark fx: X1 input clock oscillation frequency

- fxT: Subsystem clock oscillation frequency
- fw: Watch timer clock frequency

# (1) Watch timer

When the X1 input clock or subsystem clock is used, interrupt requests (INTWT) are generated at preset intervals.

# Table 10-1. Watch Timer Interrupt Time

| Interrupt Time      | When Operated at fxr = 32.768 kHz | When Operated at fx = 10 MHz |
|---------------------|-----------------------------------|------------------------------|
| 2⁴/fw               | 488 μs                            | 205 μs                       |
| 2⁵/fw               | 977 μs                            | 410 μs                       |
| 2 <sup>13</sup> /fw | 0.25 s                            | 0.105 s                      |
| 2 <sup>14</sup> /fw | 0.5 s                             | 0.210 s                      |

Remark fx: X1 input clock oscillation frequency

fxr: Subsystem clock oscillation frequency

fw: Watch timer clock frequency

#### (2) Interval timer

Interrupt requests (INTWTI) are generated at preset time intervals.

# Table 10-2. Interval Timer Interval Time

| Interval Time       | When Operated at fxT = 32.768 kHz | When Operated at fx = 10 MHz |
|---------------------|-----------------------------------|------------------------------|
| 2⁴/fw               | 488 µs                            | 205 μs                       |
| 2 <sup>5</sup> /fw  | 977 μs                            | 410 μs                       |
| 2 <sup>6</sup> /fw  | 1.95 ms                           | 820 μs                       |
| 2 <sup>7</sup> /fw  | 3.91 ms                           | 1.64 ms                      |
| 2 <sup>8</sup> /fw  | 7.81 ms                           | 3.28 ms                      |
| 2 <sup>°</sup> /fw  | 15.6 ms                           | 6.55 ms                      |
| 2 <sup>10</sup> /fw | 31.2 ms                           | 13.1 ms                      |
| 2 <sup>11</sup> /fw | 62.4 ms                           | 26.2 ms                      |

Remark fx: X1 input clock oscillation frequency

fxr: Subsystem clock oscillation frequency

fw: Watch timer clock frequency

# **10.2 Configuration of Watch Timer**

The watch timer consists of the following hardware.

# Table 10-3. Watch Timer Configuration

| Item             | Configuration                             |
|------------------|-------------------------------------------|
| Counter          | 5 bits $\times$ 1                         |
| Prescaler        | 11 bits $\times$ 1                        |
| Control register | Watch timer operation mode register (WTM) |

# 10.3 Register Controlling Watch Timer

The watch timer is controlled by the watch timer operation mode register (WTM).

# • Watch timer operation mode register (WTM)

This register sets the watch timer count clock, enables/disables operation, prescaler interval time, and 5-bit counter operation control.

WTM is set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears WTM to 00H.

# Figure 10-2. Format of Watch Timer Operation Mode Register (WTM)

|   | WTM7 | WTM6                     | WTM5                         | WTM4                | WTM3            | WTM2            | WTM1      | WTM |
|---|------|--------------------------|------------------------------|---------------------|-----------------|-----------------|-----------|-----|
|   |      |                          |                              |                     |                 |                 |           |     |
|   | WTM7 |                          |                              | Watch tim           | er count clocł  | selection       |           |     |
|   | 0    | fx/2 <sup>7</sup> (78.12 | 5 kHz)                       |                     |                 |                 |           |     |
|   | 1    | fxт <b>(32.768</b>       | kHz)                         |                     |                 |                 |           |     |
| 1 | WTM6 | WTM5                     | WTM4                         |                     | Prescale        | r interval time | selection |     |
|   | 0    | 0                        | 0                            | 2⁴/fw               |                 |                 |           |     |
|   | 0    | 0                        | 1                            | 2⁵/fw               |                 |                 |           |     |
|   | 0    | 1                        | 0                            | 2 <sup>6</sup> /fw  |                 |                 |           |     |
|   | 0    | 1                        | 1                            | 2 <sup>7</sup> /fw  |                 |                 |           |     |
|   | 1    | 0                        | 0                            | 2 <sup>8</sup> /fw  |                 |                 |           |     |
|   | 1    | 0                        | 1                            | 2º/fw               |                 |                 |           |     |
|   | 1    | 1                        | 0                            | 2 <sup>10</sup> /fw |                 |                 |           |     |
|   | 1    | 1                        | 1                            | 2 <sup>11</sup> /fw |                 |                 |           |     |
|   | WTM3 | WTM2                     |                              |                     |                 |                 |           |     |
|   |      | 0                        | 2 <sup>14</sup> /fw          |                     | Interrupt tin   | le selection    |           |     |
|   | 0    | 1                        | 2 /Iw<br>2 <sup>13</sup> /fw |                     |                 |                 |           |     |
|   | 1    | 0                        | 2 //w<br>2⁵/fw               |                     |                 |                 |           |     |
|   | 1    | 1                        | 2 //w<br>24/fw               |                     |                 |                 |           |     |
| ļ |      |                          | 2710                         |                     |                 |                 |           |     |
|   | WTM1 |                          |                              | 5-bit cou           | Inter operation | n control       |           |     |
|   | 0    | Clear after              | operation sto                | o                   |                 |                 |           |     |
|   | 1    | Start                    |                              |                     |                 |                 |           |     |
|   | WTM0 |                          |                              | Watch t             | mer operatior   | n enable        |           |     |
|   | 0    | Operation s              | top (clear bo                | h prescaler an      | d timer)        |                 |           |     |
|   | 1    | Operation e              | nable                        |                     |                 |                 |           |     |

- **Remarks 1.** fw: Watch timer clock frequency  $(fx/2^7 \text{ or } fx_T)$ 
  - 2. fx: X1 input clock oscillation frequency
  - **3.** fxT: Subsystem clock oscillation frequency
  - 4. Figures in parentheses apply to operation with fx = 10 MHz, fxT = 32.768 kHz.

# **10.4 Watch Timer Operations**

# 10.4.1 Watch timer operation

The watch timer generates an interrupt request (INTWT) at a specific time interval by using the X1 input clock or subsystem clock.

When bit 0 (WTM0) and bit 1 (WTM1) of the watch timer operation mode register (WTM) are set to 1, the count operation starts. When these bits are set to 0, the 5-bit counter is cleared and the count operation stops.

When the interval timer is simultaneously operated, zero-second start can be achieved only for the watch timer by setting WTM1 to 0. In this case, however, the 11-bit prescaler is not cleared. Therefore, an error up to  $2^{11} \times 1/f_W$ seconds occurs in the first overflow (INTWT) after zero-second start.

The interrupt request is generated at the following time intervals.

| WTM3 | WTM2 | Interrupt Time Selection | When Operated at $f_{XT} = 32.768 \text{ kHz}$<br>(WTM7 = 1) | When Operated at fx = 10 MHz<br>(WTM7 = 0) |
|------|------|--------------------------|--------------------------------------------------------------|--------------------------------------------|
| 0    | 0    | 2 <sup>14</sup> /fw      | 0.5 s                                                        | 0.210 s                                    |
| 0    | 1    | 2 <sup>13</sup> /fw      | 0.25 s                                                       | 0.105 s                                    |
| 1    | 0    | 2⁵/fw                    | 977 μs                                                       | 410 μs                                     |
| 1    | 1    | 2 <sup>4</sup> /fw       | 488 μs                                                       | 205 μs                                     |

#### Table 10-4. Watch Timer Interrupt Time

**Remark** fx: X1 input clock oscillation frequency

fxT: Subsystem clock oscillation frequency

fw: Watch timer clock frequency

#### 10.4.2 Interval timer operation

The watch timer operates as interval timer which generates interrupt requests (INTWTI) repeatedly at an interval of the preset count value.

The interval time can be selected with bits 4 to 6 (WTM4 to WTM6) of the watch timer operation mode register (WTM).

When bit 0 (WTM0) of the WTM is set to 1, the count operation starts. When this bit is set to 0, the count operation stops.

| WTM6 | WTM5 | WTM4 | Interval Time       | When Operated at<br>f <sub>XT</sub> = 32.768 kHz (WTM7 = 1) | When Operated at<br>fx = 10 MHz (WTM7 = 0) |
|------|------|------|---------------------|-------------------------------------------------------------|--------------------------------------------|
| 0    | 0    | 0    | 2 <sup>4</sup> /fw  | 488 μs                                                      | 205 μs                                     |
| 0    | 0    | 1    | 2 <sup>5</sup> /fw  | 977 μs                                                      | 410 μs                                     |
| 0    | 1    | 0    | 2 <sup>6</sup> /fw  | 1.95 ms                                                     | 820 μs                                     |
| 0    | 1    | 1    | 2 <sup>7</sup> /fw  | 3.91 ms                                                     | 1.64 ms                                    |
| 1    | 0    | 0    | 2 <sup>8</sup> /fw  | 7.81 ms                                                     | 3.28 ms                                    |
| 1    | 0    | 1    | 2 <sup>9</sup> /fw  | 15.6 ms                                                     | 6.55 ms                                    |
| 1    | 1    | 0    | 2 <sup>10</sup> /fw | 31.2 ms                                                     | 13.1 ms                                    |
| 1    | 1    | 1    | 2 <sup>11</sup> /fw | 62.4 ms                                                     | 26.2 ms                                    |

Table 10-5. Interval Timer Interval Time

Remark fx: X1 input clock oscillation frequency

- fxT: Subsystem clock oscillation frequency
- fw: Watch timer clock frequency



# Figure 10-3. Operation Timing of Watch Timer/Interval Timer

- Caution When operation of the watch timer and 5-bit counter is enabled by the watch timer mode control register (WTM) (by setting bits 0 (WTM0) and 1 (WTM1) of WTM to 1), the interval until the first interrupt request (INTWT) is generated after the register is set does not exactly match the specification made with bit 3 (WTM3) of WTM. This is because there is a delay of one 11-bit prescaler output cycle until the 5-bit counter starts counting. Subsequently, however, the INTWT signal is generated at the specified intervals.
- Remark fw: Watch timer clock frequency

n: The number of times of interval timer operations

Figures in parentheses are for operation with fw = 32.768 kHz (WTM7 = 1, WTM3, WTM2 = 0, 0)

# CHAPTER 11 WATCHDOG TIMER

# 11.1 Functions of Watchdog Timer

The watchdog timer detects an inadvertent program loop. If a program loop is detected, an internal reset signal (WDTRES) is generated.

When a reset occurs due to the watchdog timer, bit 4 (WDTRF) of the reset control flag register (RESF) is set to 1. For details of RESF, refer to **CHAPTER 22 RESET FUNCTION**.

| Loop Detection Time                         |                                 |  |  |  |  |  |  |
|---------------------------------------------|---------------------------------|--|--|--|--|--|--|
| During Ring-OSC Clock Operation             | During X1 Input Clock Operation |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>11</sup> (8.53 ms)   | fxp/2 <sup>13</sup> (819.2 μs)  |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>12</sup> (17.07 ms)  | fx₽/2 <sup>14</sup> (1.64 ms)   |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>13</sup> (34.13 ms)  | fxp/2 <sup>15</sup> (3.28 ms)   |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>14</sup> (68.27 ms)  | fx₽/2 <sup>16</sup> (6.55 ms)   |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>15</sup> (136.53 ms) | fxp/2 <sup>17</sup> (13.11 ms)  |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>16</sup> (273.07 ms) | fxp/2 <sup>18</sup> (26.21 ms)  |  |  |  |  |  |  |
| f <sub>R</sub> /2 <sup>17</sup> (546.13 ms) | fxp/2 <sup>19</sup> (52.43 ms)  |  |  |  |  |  |  |
| f⊩/2 <sup>18</sup> (1.09 s)                 | fxp/2 <sup>20</sup> (104.86 ms) |  |  |  |  |  |  |

Table 11-1. Loop Detection Time of Watchdog Timer

Remarks 1. fr: Ring-OSC clock oscillation frequency

2. fxp: X1 input clock oscillation frequency

3. Figures in parentheses apply to operation at  $f_R = 240 \text{ kHz}$  (TYP.),  $f_{XP} = 10 \text{ MHz}$ 

The operation mode of the watchdog timer (WDT) is switched according to the mask option setting of the on-chip Ring-OSC as shown in Table 11-2.

|                             | Mask Option                                                                                     |                                                                                                     |  |  |  |  |
|-----------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|
|                             | Ring-OSC Cannot Be Stopped                                                                      | Ring-OSC Can Be Stopped by Software                                                                 |  |  |  |  |
| Watchdog timer clock source | Fixed to $f_{H^{Note 1}}$ .                                                                     | <ul> <li>Selectable by software (fxp, fn or stopped)</li> <li>When reset is released: fn</li> </ul> |  |  |  |  |
| Operation after reset       | Operation starts with the maximum interval $(f_R/2^{18})$ .                                     | Operation starts with maximum interval (fr/2 <sup>18</sup> ).                                       |  |  |  |  |
| Operation mode selection    | The interval can be changed only once.                                                          | The clock selection/interval can be changed only once.                                              |  |  |  |  |
| Features                    | <ul> <li>The watchdog timer cannot be stopped.</li> <li>Current in STOP mode ≒ 10 μA</li> </ul> | The watchdog timer can be stopped in standby mode <sup>Note 2</sup> .                               |  |  |  |  |

#### Table 11-2. Mask Option Setting and Watchdog Timer Operation Mode

**Notes 1.** As long as power is being supplied, Ring-OSC oscillation cannot be stopped (except in the reset period).

- 2. Clock supply to the watchdog timer is stopped in accordance with the watchdog timer clock source as follows:
  - <1> When the clock source is fxp

Clock supply to the watchdog timer is stopped while  $f_{XP}$  is stopped, during HALT/STOP instruction execution, and during the oscillation stabilization time.

<2> When the clock source is fR

Clock supply to the watchdog timer is stopped if  $f_{R}$  is stopped by software before STOP instruction execution when the CPU clock is  $f_{XP}$  and during HALT/STOP instruction execution.

Remarks 1. fr: Ring-OSC clock oscillation frequency

2. fxp: X1 input clock oscillation frequency

# 11.2 Configuration of Watchdog Timer

The watchdog timer consists of following hardware.

#### Table 11-3. Configuration of Watchdog Timer

| Item              | Configuration                                                                |
|-------------------|------------------------------------------------------------------------------|
| Control registers | Watchdog timer mode register (WDTM)<br>Watchdog timer enable register (WDTE) |



# Figure 11-1. Block Diagram of Watchdog Timer

# 11.3 Registers Controlling Watchdog Timer

The watchdog timer is controlled by the following two registers.

- Watchdog timer mode register (WDTM)
- Watchdog timer enable register (WDTE)

# (1) Watchdog timer mode register (WDTM)

This register sets the overflow time and operation clock of the watchdog timer.

This register can be set by an 8-bit memory manipulation instruction and can be read many times, but can be written only once after reset is released.

RESET input sets this register to 67H.

| Address: FF98H |   | After reset: 67H | R/W |       |       |       |       |       |
|----------------|---|------------------|-----|-------|-------|-------|-------|-------|
| Symbol         | 7 | 6                | 5   | 4     | 3     | 2     | 1     | 0     |
| WDTM           | 0 | 1                | 1   | WDCS4 | WDCS3 | WDCS2 | WDCS1 | WDCS0 |

# Figure 11-2. Format of Watchdog Timer Mode Register (WDTM)

| WDCS4 <sup>Note 1</sup> | WDCS3 <sup>Note 1</sup> | Operation clock selection        |  |  |  |
|-------------------------|-------------------------|----------------------------------|--|--|--|
| 0                       | 0                       | Ring-OSC clock (f <sub>R</sub> ) |  |  |  |
| 0                       | 1                       | X1 input clock (fxp)             |  |  |  |
| 1                       | ×                       | Watchdog timer operation stopped |  |  |  |

| WDCS2 <sup>Note 2</sup> | WDCS1 <sup>Note 2</sup> | WDCS0 <sup>Note 2</sup> | Overflow time setting                       |                                 |  |  |
|-------------------------|-------------------------|-------------------------|---------------------------------------------|---------------------------------|--|--|
|                         |                         |                         | During Ring-OSC clock<br>operation          | During X1 input clock operation |  |  |
| 0                       | 0                       | 0                       | f <sub>R</sub> /2 <sup>11</sup> (8.53 ms)   | fxp/2 <sup>13</sup> (819.2 μs)  |  |  |
| 0                       | 0                       | 1                       | f <sub>R</sub> /2 <sup>12</sup> (17.07 ms)  | fxp/2 <sup>14</sup> (1.64 ms)   |  |  |
| 0                       | 1                       | 0                       | f <sub>R</sub> /2 <sup>13</sup> (34.13 ms)  | fxp/2 <sup>15</sup> (3.28 ms)   |  |  |
| 0                       | 1                       | 1                       | f <sub>R</sub> /2 <sup>14</sup> (68.27 ms)  | fxp/2 <sup>16</sup> (6.55 ms)   |  |  |
| 1                       | 0                       | 0                       | f <sub>R</sub> /2 <sup>15</sup> (136.53 ms) | fxp/2 <sup>17</sup> (13.11 ms)  |  |  |
| 1                       | 0                       | 1                       | f <sub>R</sub> /2 <sup>16</sup> (273.07 ms) | fxp/2 <sup>18</sup> (26.21 ms)  |  |  |
| 1                       | 1                       | 0                       | f <sub>R</sub> /2 <sup>17</sup> (546.13 ms) | fxp/2 <sup>19</sup> (52.43 ms)  |  |  |
| 1                       | 1                       | 1                       | fr/2 <sup>18</sup> (1.09 s)                 | fxp/2 <sup>20</sup> (104.86 ms) |  |  |

- Notes 1. If "Ring-OSC cannot be stopped" is specified by a mask option, this cannot be set. The Ring-OSC clock will be selected no matter what value is written.
  - **2.** Reset is released at the maximum cycle (WDCS2, 1, 0 = 1, 1, 1).
- Cautions 1. If data is written to WDTM, a wait cycle is generated. Do not write data to WDTM when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.
  - 2. Set bits 7, 6, and 5 to 0, 1, and 1, respectively (when "Ring-OSC cannot be stopped" is selected by a mask option, other values are ignored).
  - 3. After reset is released, WDTM can be written only once by an 8-bit memory manipulation instruction. If writing attempted a second time, an internal reset signal is generated.
  - 4. WDTM cannot be set by a 1-bit memory manipulation instruction.
- **Remarks 1.** fr.: Ring-OSC clock oscillation frequency
  - **2.** fxp: X1 input clock oscillation frequency
  - **3.**  $\times$ : Don't care
  - 4. Figures in parentheses apply to operation at  $f_R = 240$  kHz (TYP.),  $f_{XP} = 10$  MHz

# (2) Watchdog timer enable register (WDTE)

Writing ACH to WDTE clears the watchdog timer counter and starts counting again. This register can be set by an 8-bit memory manipulation instruction. RESET input sets this register to 9AH.

### Figure 11-3. Format of Watchdog Timer Enable Register (WDTE)

| Address: | FF99H | After reset: 9AH | R/W |   |   |   |   |   |
|----------|-------|------------------|-----|---|---|---|---|---|
| Symbol   | 7     | 6                | 5   | 4 | 3 | 2 | 1 | 0 |
| WDTE     |       |                  |     |   |   |   |   |   |

Cautions 1. If a value other than ACH is written to WDTE, an internal reset signal is generated.

- 2. If a 1-bit memory manipulation instruction is executed for WDTE, an internal reset signal is generated (an error occurs in the assembler).
- 3. The value read from WDTE is 9AH (this differs from the written value (ACH)).

# 11.4 Operation of Watchdog Timer

# 11.4.1 Watchdog timer operation when "Ring-OSC cannot be stopped" is selected by mask option

The operation clock of watchdog timer is fixed to the Ring-OSC.

After reset is released, operation is started at the maximum cycle (bits 2, 1, and 0 (WDCS2, WDCS1, WDCS0) of the watchdog timer mode register (WDTM) = 1, 1, 1). The watchdog timer operation cannot be stopped.

The following shows the watchdog timer operation after reset release.

- 1. The status after reset release is as follows.
  - Operation clock: Ring-OSC clock
  - Cycle:  $f_R/2^{18}$  (1.09 seconds: At operation with  $f_R = 240$  kHz (TYP.))
  - · Counting starts
- 2. The following should be set in the watchdog timer mode register (WDTM) by an 8-bit memory manipulation instruction<sup>Notes 1, 2</sup>.
  - Cycle: Set using bits 2 to 0 (WDCS2 to WDCS0)
- 3. After the above procedures are executed, writing ACH to WDTE clears the count to 0, enabling recounting.
- **Notes 1.** The operation clock (Ring-OSC clock) cannot be changed. If any value is written to bits 3 and 4 (WDCS3, WDCS4) of WDTM, it is ignored.
  - 2. As soon as WDTM is written, the counter of the watchdog timer is cleared.
- Caution In this mode, operation of the watchdog timer absolutely cannot be stopped even during STOP instruction execution. For 8-bit timer H1 (TMH1), a division of the Ring-OSC can be selected as the count source, so clear the watchdog timer using the interrupt request of TMH1 before the watchdog timer overflows. If this processing is not performed, an internal reset signal is generated when the watchdog timer overflows after STOP instruction execution.

11.4.2 Watchdog timer operation when "Ring-OSC can be stopped by software" is selected by mask option

The operation clock of the watchdog timer can be selected as either the Ring-OSC clock or the X1 input clock. After reset is released, operation is started at the maximum cycle (bits 2, 1, and 0 (WDCS2, WDCS1, WDCS0) of the watchdog timer mode register (WDTM) = 1, 1, 1).

The following shows the watchdog timer operation after reset release.

- 1. The status after reset release is as follows.
  - Operation clock: Ring-OSC clock oscillation frequency (fR)
  - Cycle:  $f_R/2^{18}$  (1.09 seconds: At operation with  $f_R = 240$  kHz (TYP.))
  - Counting starts
- 2. The following should be set in the watchdog timer mode register (WDTM) by an 8-bit memory manipulation instruction<sup>Notes 1, 2, 3</sup>.
  - Operation clock: Any of the following can be selected using bits 3 and 4 (WDCS3 and WDCS4).

Ring-OSC clock (fR)

X1 input clock (fxp)

Watchdog timer operation stopped

- Cycle: Set using bits 2 to 0 (WDCS2 to WDCS0)
- 3. After the above procedures are executed, writing ACH to WDTE clears the count to 0, enabling recounting.
- Notes 1. As soon as WDTM is written, the counter of the watchdog timer is cleared.
  - 2. Set bits 7, 6, and 5 to 0, 1, 1, respectively. If other values are set, the watchdog timer cannot be operated (an error occurs in the assembler).
  - **3.** If the watchdog timer is stopped by setting WDCS4 and WDCS3 to 1 and ×, respectively, an internal reset signal is not generated even if the following processing is performed.
    - WDTM is written a second time.
    - A 1-bit memory manipulation instruction is executed to WDTE.
    - A value other than ACH is written to WDTE.
- Caution In this mode, watchdog timer operation is stopped during HALT/STOP instruction execution. After HALT/STOP mode is released, counting is started again using the operation clock of the watchdog timer set before HALT/STOP instruction execution by WDTM. At this time, the counter is not cleared to 0.

For the watchdog timer operation during STOP mode and HALT mode in each status, refer to 11.4.3 Watchdog timer operation in STOP mode and 11.4.4 Watchdog timer operation in HALT mode.

11.4.3 Watchdog timer operation in STOP mode (when "Ring-OSC can be stopped by software" is selected by mask option)

The watchdog timer stops counting during STOP instruction execution regardless of whether the X1 input clock or Ring-OSC clock is being used.

# (1) When the CPU clock and the watchdog timer operation clock are the X1 input clock (fxp) when the STOP instruction is executed

When STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, counting stops for the oscillation stabilization time set by the oscillation stabilization time select register (OSTS) and then counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0.



Figure 11-4. Operation in STOP Mode (CPU Clock and WDT Operation Clock: X1 Input Clock)

# (2) When the CPU clock is the X1 input clock (fxP) and the watchdog timer operation clock is the Ring-OSC clock (fR) when the STOP instruction is executed

When the STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0.





# (3) When the CPU clock is the Ring-OSC clock (fR) and the watchdog timer operation clock is the X1 input clock (fxP) when the STOP instruction is executed

When the STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, counting is stopped until the timing of <1> or <2>, whichever is earlier, and then counting is started using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0.

- <1> The oscillation stabilization time set by the oscillation stabilization time select register (OSTS) elapses.
- <2> The CPU clock is switched to the X1 input clock (fxp).

# Figure 11-6. Operation in STOP Mode (CPU Clock: Ring-OSC Clock, WDT Operation Clock: X1 Input Clock)

<1> Timing when counting is started after the oscillation stabilization time set by the oscillation stabilization time select register (OSTS) has elapsed



<2> Timing when counting is started after the CPU clock is switched to the X1 input clock (fxP)



# **Note** Confirm the oscillation stabilization time of fxP using the oscillation stabilization time counter status register (OSTC).

# (4) When CPU clock and watchdog timer operation clock are the Ring-OSC clocks (f<sub>R</sub>) during STOP instruction execution

When the STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0.



Figure 11-7. Operation in STOP Mode (CPU Clock and WDT Operation Clock: Ring-OSC Clock)

# 11.4.4 Watchdog timer operation in HALT mode (when "Ring-OSC can be stopped by software" is selected by mask option)

The watchdog timer stops counting during HALT instruction execution regardless of whether the CPU clock is the X1 input clock ( $f_{XP}$ ), Ring-OSC clock ( $f_R$ ), or subsystem clock ( $f_{XT}$ ), or whether the operation clock of the watchdog timer is the X1 input clock ( $f_{XP}$ ) or Ring-OSC clock ( $f_R$ ). After HALT mode is released, counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0.



Figure 11-8. Operation in HALT Mode

# CHAPTER 12 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER

# 12.1 Functions of Clock Output/Buzzer Output Controller

The clock output controller is intended for carrier output during remote controlled transmission and clock output for supply to peripheral LSIs. The clock selected with the clock output selection register (CKS) is output. In addition, the buzzer output is intended for square-wave output of buzzer frequency selected with CKS.

Figure 12-1 shows the block diagram of clock output/buzzer output controller.





# 12.2 Configuration of Clock Output/Buzzer Output Controller

The clock output/buzzer output controller consists of the following hardware.

# Table 12-1. Clock Output/Buzzer Output Controller Configuration

| Item              | Configuration                                |  |  |  |
|-------------------|----------------------------------------------|--|--|--|
| Control registers | Clock output selection register (CKS)        |  |  |  |
|                   | Port mode register 14 (PM14) <sup>Note</sup> |  |  |  |

Note See Figure 4-23 Block Diagram of P140 and P141.

# 12.3 Register Controlling Clock Output/Buzzer Output Controller

The following two registers are used to control the clock output/buzzer output controller.

- Clock output selection register (CKS)
- Port mode register 14 (PM14)

# (1) Clock output selection register (CKS)

This register sets output enable/disable for clock output (PCL) and for the buzzer frequency output (BUZ), and sets the output clock.

CKS is set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets CKS to 00H.

# Figure 12-2. Format of Clock Output Selection Register (CKS)

| Address: FF | -40H After I | eset: 00H | R/W  |      |      |      |      |      |
|-------------|--------------|-----------|------|------|------|------|------|------|
| Symbol      | 7            | 6         | 5    | 4    | 3    | 2    | 1    | 0    |
| CKS         | BZOE         | BCS1      | BCS0 | CLOE | CCS3 | CCS2 | CCS1 | CCS0 |

| BZOE | BUZ output enable/disable specification                           |  |  |  |  |  |  |  |
|------|-------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | Clock division circuit operation stopped. BUZ fixed to low level. |  |  |  |  |  |  |  |
| 1    | Clock division circuit operation enabled. BUZ output enabled.     |  |  |  |  |  |  |  |

| BCS1 | BCS0 | BUZ output clock selection    |
|------|------|-------------------------------|
| 0    | 0    | fx/2 <sup>10</sup> (9.77 kHz) |
| 0    | 1    | fx/2 <sup>11</sup> (4.88 kHz) |
| 1    | 0    | fx/2 <sup>12</sup> (2.44 kHz) |
| 1    | 1    | fx/2 <sup>13</sup> (1.22 kHz) |

| CLOE | PCL output enable/disable specification                           |  |  |  |  |  |  |  |
|------|-------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | Clock division circuit operation stopped. PCL fixed to low level. |  |  |  |  |  |  |  |
| 1    | Clock division circuit operation enabled. PCL output enabled.     |  |  |  |  |  |  |  |

| CCS3         | CCS2 | CCS1 | CCS0 | PCL output clock selection     |
|--------------|------|------|------|--------------------------------|
| 0            | 0    | 0    | 0    | fx (10 MHz)                    |
| 0            | 0    | 0    | 1    | fx/2 (5 MHz)                   |
| 0            | 0    | 1    | 0    | fx/2 <sup>2</sup> (2.5 MHz)    |
| 0            | 0    | 1    | 1    | fx/2 <sup>3</sup> (1.25 MHz)   |
| 0            | 1    | 0    | 0    | fx/2 <sup>4</sup> (625 kHz)    |
| 0            | 1    | 0    | 1    | fx/2⁵ (312.5 kHz)              |
| 0            | 1    | 1    | 0    | fx/2 <sup>6</sup> (156.25 kHz) |
| 0            | 1    | 1    | 1    | fx/2 <sup>7</sup> (78.125 kHz) |
| 1            | 0    | 0    | 0    | fxт (32.768 kHz)               |
| Other than a | bove |      |      | Setting prohibited             |

**Remarks 1.** fx: X1 input clock oscillation frequency

2. fxT: Subsystem clock oscillation frequency

**3.** Figures in parentheses are for operation with fx = 10 MHz or fxT = 32.768 kHz.

# (2) Port mode register 14 (PM14)

This register sets port 14 input/output in 1-bit units. When using the P140/INTP6/PCL pin for clock output and the P141/BUSY0/INTP7/BUZ pin for buzzer output, set PM140, PM141 and the output latch of P140, P141 to 0. PM14 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets PM14 to FFH.

# Figure 12-3. Format of Port Mode Register 14 (PM14)

| Address: | FF2EH | After reset: | FFH R | /W    |       |       |       |       |
|----------|-------|--------------|-------|-------|-------|-------|-------|-------|
| Symbol   | 7     | 7 6          |       | 4     | 3     | 2     | 1     | 0     |
| PM14     | 1     | 1            | PM145 | PM144 | PM143 | PM142 | PM141 | PM140 |

| PM1 | 4n | P14n pin I/O mode selection (n = 0 to 5) |  |  |  |  |  |  |
|-----|----|------------------------------------------|--|--|--|--|--|--|
| 0   |    | Output mode (output buffer ON)           |  |  |  |  |  |  |
| 1   |    | Input mode (output buffer OFF)           |  |  |  |  |  |  |

# 12.4 Clock Output/Buzzer Output Controller Operations

# 12.4.1 Clock output operation

The clock pulse is output as the following procedure.

- <1> Select the clock pulse output frequency with bits 0 to 3 (CCS0 to CCS3) of the clock output selection register (CKS) (clock pulse output in disabled status).
- <2> Set bit 4 (CLOE) of CKS to 1 to enable clock output.
- **Remark** The clock output controller is designed not to output pulses with a small width during output enable/disable switching of the clock output. As shown in Figure 12-4, be sure to start output from the low period of the clock (marked with \* in the figure). When stopping output, do so after securing high level of the clock.





#### 12.4.2 Operation as buzzer output

The buzzer frequency is output as the following procedure.

- <1> Select the buzzer output frequency with bits 5 and 6 (BCS0, BCS1) of the clock output selection register (CKS) (buzzer output in disabled status).
- <2> Set bit 7 (BZOE) of CKS to 1 to enable buzzer output.

# CHAPTER 13 A/D CONVERTER

# 13.1 Functions of A/D Converter

The A/D converter converts an analog input signal into a digital value, and consists of up to eight channels (ANI0 to ANI7) with a resolution of 10 bits.

The A/D converter has the following two functions.

#### (1) 10-bit resolution A/D conversion

10-bit resolution A/D conversion is carried out repeatedly for one channel selected from analog inputs ANI0 to ANI7. Each time an A/D conversion operation ends, an interrupt request (INTAD) is generated.

# (2) Power-fail detection function

This function is used to detect a voltage drop in a battery. The A/D conversion result (ADCR register value) and power-fail comparison threshold register (PFT) value are compared. INTAD is generated only when a comparative condition has been matched.



Figure 13-1. Block Diagram of A/D Converter

Figure 13-2. Block Diagram of Power-Fail Detection Function



# 13.2 Configuration of A/D Converter

The A/D converter consists of the following hardware.

| Item              | Configuration                                                                                                                                                                         |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Analog input      | 8 channels (ANI0 to ANI7)                                                                                                                                                             |
| Registers         | Successive approximation register (SAR)<br>A/D conversion result register (ADCR)                                                                                                      |
| Control registers | A/D converter mode register (ADM)<br>Analog input channel specification register (ADS)<br>Power-fail comparison mode register (PFM)<br>Power-fail comparison threshold register (PFT) |

# (1) Successive approximation register (SAR)

This register compares the analog input voltage value with the voltage tap (compare voltage) value applied from the series resistor string, and holds the result starting from the most significant bit (MSB).

When the result up to the least significant bit (LSB) is held (end of A/D conversion), the SAR contents are transferred to the A/D conversion result register.

# (2) A/D conversion result register (ADCR)

The ADCR is 16-bit register that stores the A/D conversion result. The lower six bits are fixed to 0. Each time A/D conversion ends, the conversion result is loaded from the successive approximation register, and is stored in ADCR in order starting from the most significant bit (MSB).

ADCR can be read by a 16-bit memory manipulation instruction.

RESET input makes ADCR undefined.

#### Figure 13-3. Format of A/D Conversion Register (ADCR)

Address: FF08H, FF09H After reset: Undefined R

| Symbol | FF09H |  |  |  |  | <br>FF08H |  |  |  |   |   |   |   |   |   |
|--------|-------|--|--|--|--|-----------|--|--|--|---|---|---|---|---|---|
| ADCR   |       |  |  |  |  |           |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 |

- Cautions 1. When writing to the A/D converter mode register (ADM) and analog input channel specification register (ADS), the contents of ADCR may become undefined. Read the conversion result following conversion completion before writing to ADM and ADS. Using timing other than the above may cause an incorrect conversion result to be read.
  - 2. If data is read from ADCR, a wait cycle is generated. Do not read data from ADCR when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

# (3) Sample & hold circuit

The sample & hold circuit samples each analog input signal sequentially applied from the input circuit, and sends it to the voltage comparator. This circuit holds the sampled analog input voltage value during A/D conversion.

#### (4) Voltage comparator

The voltage comparator compares the analog input with the series resistor string output voltage.

# (5) Series resistor string

The series resistor string is connected between AV<sub>REF</sub> and AV<sub>SS</sub>, and generates a voltage to be compared with the analog input.

# (6) ANI0 to ANI7 pins

These eight-channel analog input pins input analog signals to undergo A/D conversion to the A/D converter. ANI0 to ANI7 are alternate-function pins that can also be used for digital input.

- Cautions 1. Observe the rated range of the ANI0 to ANI7 input voltage. If a voltage of AV<sub>REF</sub> or higher or a voltage of AV<sub>ss</sub> or lower (even if within the range of absolute maximum ratings) is input to an analog input channel, the converted value of that channel becomes undefined. In addition, the converted values of the other channels may also be affected.
  - 2. The analog input pins (ANI0 to ANI7) are also used as input port pins (P20 to P27). When A/D conversion is performed with any of ANI0 to ANI7 selected, do not execute the input instruction to port 2 while conversion is in progress; otherwise the conversion resolution may be degraded. If a digital pulse is applied to the pins adjacent to the pins currently used for A/D conversion, the expected value of the A/D conversion may not be obtained due to coupling noise. Therefore, do not apply a pulse to the pins adjacent to the pin undergoing A/D conversion.

# (7) AVREF pin

The AVREF pin inputs the A/D converter reference voltage.

It converts signals input to ANI0 to ANI7 into digital signals based on a voltage between AVREF and AVss. In a standby mode, the current flowing into series resistor strings can be reduced by changing the input voltage of

the AVREF pin to AVss level.

It can also be used as the analog power supply. When the A/D converter is used, be sure to use the AV<sub>REF</sub> pin for the power supply.

Caution A series resistor string of several tens of kΩ is connected between the AV<sub>REF</sub> and AV<sub>SS</sub> pins. Therefore, if the output impedance of the reference voltage source is high, this will result in series connection to the series resistor string between the AV<sub>REF</sub> and AV<sub>SS</sub> pins, resulting in a large reference voltage error.

#### (8) AVss pin

The AVss pin is the GND potential pin for the A/D converter. Always use the AVss pin at the same potential as the Vsso pin, even when the A/D converter is not used.

# 13.3 Registers Controlling A/D Converter

The following four registers are used to control the A/D converter.

- A/D converter mode register (ADM)
- Analog input channel specification register (ADS)
- Power-fail comparison mode register (PFM)
- Power-fail comparison threshold register (PFT)

#### (1) A/D converter mode register (ADM)

This register sets the conversion time for analog input to be A/D converted, and starts/stops conversion. ADM can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

| Address: | FF28H | After res | set: 00H | R/W |     |   |   |      |
|----------|-------|-----------|----------|-----|-----|---|---|------|
| Symbol   | 7     | 6         | 5        | 4   | 3   | 2 | 1 | 0    |
| ADM      | ADCS  | 0         | FR2      | FR1 | FR0 | 0 | 0 | ADCE |

Figure 13-4. Format of A/D Converter Mode Register (ADM)

| ADCS | A/D conversion operation control |  |  |  |
|------|----------------------------------|--|--|--|
| 0    | Stops conversion operation       |  |  |  |
| 1    | Enables conversion operation     |  |  |  |

| FR2 | FR1   | FR0 | Conversion time selection <sup>Note 1</sup> |                               |                                |                                |
|-----|-------|-----|---------------------------------------------|-------------------------------|--------------------------------|--------------------------------|
|     |       |     |                                             | fx = 2 MHz                    | fx = 8.38 MHz                  | fx = 10 MHz                    |
| 0   | 0     | 0   | 288/fx                                      | 144 $\mu$ S <sup>Note 1</sup> | 34.3 <i>µ</i> s                | 28.8 <i>µ</i> s                |
| 0   | 0     | 1   | 240/fx                                      | 120 $\mu$ s <sup>Note 1</sup> | 28.6 µs                        | 24.0 <i>µ</i> s                |
| 0   | 1     | 0   | 192/fx                                      | 96 µs                         | 22.9 <i>µ</i> s                | 19.2 <i>µ</i> s                |
| 1   | 0     | 0   | 144/fx                                      | 72 µs                         | 17.2 <i>µ</i> s                | 14.4 <i>µ</i> s                |
| 1   | 0     | 1   | 120/fx                                      | 60 µs                         | 14.3 <i>µ</i> s                | 12.0 $\mu$ s <sup>Note 1</sup> |
| 1   | 1     | 0   | 96/fx                                       | 48µs                          | 11.5 $\mu$ S <sup>Note 1</sup> | 9.6 µS <sup>Note 1</sup>       |
|     | Other |     | Setting pr                                  | ohibited                      |                                |                                |

| ADCE | Boost reference voltage generator operation control <sup>Note 2</sup> |
|------|-----------------------------------------------------------------------|
| 0    | Stops operation of reference voltage generator                        |
| 1    | Enables operation of reference voltage generator                      |

**Notes 1.** Set so that the A/D conversion time is 14  $\mu$ s or longer but less than 100  $\mu$ s.

2. A booster circuit is incorporated to realize low-voltage operation. The operation of the circuit that generates the reference voltage for boosting is controlled by ADCE, and it takes 14  $\mu$ s from operation start to operation stabilization. Therefore, when ADCS is set to 1 after 14  $\mu$ s or more has elapsed from the time ADCE is set to 1, the conversion result at that time has priority over the first conversion result.

| ADCS | ADCE | A/D Conversion Operation                                                         |
|------|------|----------------------------------------------------------------------------------|
| 0    | 0    | Stop status (DC power consumption path does not exist)                           |
| 0    | 1    | Conversion waiting mode (only reference voltage generator consumes power)        |
| 1    | 0    | Conversion mode (reference voltage generator operation stopped <sup>Note</sup> ) |
| 1    | 1    | Conversion mode (reference voltage generator operates)                           |

#### Table 13-2. Settings of ADCS and ADCE

Note Data of first conversion cannot be used.





Note  $14 \ \mu s$  or more is required for reference voltage stabilization.

- Cautions 1. A/D conversion must be stopped before rewriting bits FR0 to FR2 to values other than the identical data.
  - 2. For the sampling time of the A/D converter and the A/D conversion start delay time, refer to (11) in 13.6 Cautions for A/D Converter.
  - 3. If data is written to ADM, a wait cycle is generated. Do not write data to ADM when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

**Remark** fx: X1 input clock oscillation frequency

# (2) Analog input channel specification register (ADS)

This register specifies the input port of the analog voltage to be A/D converted. ADS can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

| Address: FF29H |      | After reset: 00H |      | R/W  |           |           |             |      |
|----------------|------|------------------|------|------|-----------|-----------|-------------|------|
| Symbol         | 7    | 6                | 5    | 4    | 3         | 2         | 1           | 0    |
| ADS            | 0    | 0                | 0    | 0    | 0         | ADS2      | ADS1        | ADS0 |
|                |      |                  |      |      |           |           |             |      |
|                | ADS2 | ADS1             | ADS0 | An   | alog inpu | t channel | specificati | on   |
|                | 0    | 0                | 0    | ANI0 |           |           |             |      |
|                | 0    | 0                | 1    | ANI1 |           |           |             |      |
|                | 0    | 1                | 0    | ANI2 |           |           |             |      |
|                | 0    | 1                | 1    | ANI3 |           |           |             |      |
|                | 1    | 0                | 0    | ANI4 |           |           |             |      |
|                | 1    | 0                | 1    | ANI5 |           |           |             |      |
|                | 1    | 1                | 0    | ANI6 |           |           |             |      |
|                | 1    | 1                | 1    | ANI7 |           |           |             |      |

#### Figure 13-6. Format of Analog Input Channel Specification Register (ADS)

Cautions 1. Be sure to set bits 3 to 7 of ADS to 0.

2. If data is written to ADS, a wait cycle is generated. Do not write data to ADS when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

# (3) Power-fail comparison mode register (PFM)

The power-fail comparison mode register (PFM) is a register that controls the comparison operation. PFM can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

# Figure 13-7. Format of Power-Fail Comparison Mode Register (PFM)

Address: FF2AH After reset: 00H R/W

| Symbol | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 |  |
|--------|------|------|---|---|---|---|---|---|--|
| PFM    | PFEN | PFCM | 0 | 0 | 0 | 0 | 0 | 0 |  |

| PFEN | Power-fail comparison enable                                  |
|------|---------------------------------------------------------------|
| 0    | Stops power-fail comparison (used as a normal A/D converter)  |
| 1    | Enables power-fail comparison (used for power-fail detection) |

|   | PFCM              | Power-fail comparison mode selection        |
|---|-------------------|---------------------------------------------|
| 0 | ADCR3 $\geq$ PFT3 | Interrupt request signal (INTAD) generation |
|   | ADCR3 < PFT3      | No INTAD generation                         |
| 1 | ADCR3 $\geq$ PFT3 | No INTAD generation                         |
|   | ADCR3 < PFT3      | INTAD generation                            |

# Caution If data is written to PFM, a wait cycle is generated. Do not write data to PFM when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

#### (4) Power-fail comparison threshold register (PFT)

The power-fail comparison threshold register (PFT) is a register that sets the threshold value when comparing the values with the A/D conversion result.

8-bit data in PFT is compared to the higher 8 bits (FF09H) of the 10-bit A/D conversion result.

PFT can be set by an 8-bit memory manipulation instruction.

RESET input clears this register to 00H.

# Figure 13-8. Format of Power-Fail Comparison Threshold Register (PFT)

| Address: FF2BH |      | After reset: 00H |      | R/W  |      |      |      |      |
|----------------|------|------------------|------|------|------|------|------|------|
| Symbol         | 7    | 6                | 5    | 4    | 3    | 2    | 1    | 0    |
| PFT            | PFT7 | PFT6             | PFT5 | PFT4 | PFT3 | PFT2 | PFT1 | PFT0 |

Caution If data is written to PFT, a wait cycle is generated. Do not write data to PFT when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

# 13.4 A/D Converter Operations

# 13.4.1 Basic operations of A/D converter

- <1> Select one channel for A/D conversion with analog input channel specification register (ADS).
- <2> The voltage input to the selected analog input channel is sampled by the sample & hold circuit.
- <3> When sampling has been done for a certain time, the sample & hold circuit is placed in the hold state and the input analog voltage is held until the A/D conversion operation is ended.
- <4> Bit 9 of the successive approximation register (SAR) is set. The series resistor string voltage tap is set to (1/2) AVREF by the tap selector.
- <5> The voltage difference between the series resistor string voltage tap and analog input is compared by the voltage comparator. If the analog input is greater than (1/2) AVREF, the MSB of SAR remains set to 1. If the analog input is smaller than (1/2) AVREF, the MSB is reset to 0.
- <6> Next, bit 8 of SAR is automatically set to 1, and the operation proceeds to the next comparison. The series resistor string voltage tap is selected according to the preset value of bit 9, as described below.
  - Bit 9 = 1: (3/4) VDD
  - Bit 9 = 0: (1/4) VDD

The voltage tap and analog input voltage are compared and bit 8 of SAR is manipulated as follows.

- Analog input voltage  $\geq$  Voltage tap: Bit 8 = 1
- Analog input voltage < Voltage tap: Bit 8 = 0
- <7> Comparison is continued in this way up to bit 0 of SAR.
- <8> Upon completion of the comparison of 10 bits, an effective digital result value remains in SAR, and the result value is transferred to the A/D conversion result register (ADCR) and then latched.

At the same time, the A/D conversion end interrupt request (INTAD) can also be generated.

# Caution The first A/D conversion value immediately after A/D conversion operations start may not fall within the rating.





A/D conversion operations are performed continuously until bit 7 (ADCS) of the A/D converter mode register (ADM) is reset (0) by software.

If a write operation is performed to one of the ADM, analog input channel specification register (ADS), power-fail comparison mode register (PFM), or power-fail comparison threshold register (PFT) during an A/D conversion operation, the conversion operation is initialized, and if the ADCS bit is set (1), conversion starts again from the beginning.

RESET input makes the A/D conversion result register (ADCR) undefined.

#### 13.4.2 Input voltage and conversion results

The relationship between the analog input voltage input to the analog input pins (ANI0 to ANI7) and the A/D conversion result (stored in the A/D conversion result register (ADCR)) is shown by the following expression.

$$\text{ADCR} = \text{INT} \; (\frac{\text{V}_{\text{IN}}}{\text{AV}_{\text{REF}}} \times 1024 + 0.5)$$

or

$$(ADCR - 0.5) \times \frac{AV_{REF}}{1024} - V_{IN} < (ADCR + 0.5) \times \frac{AV_{REF}}{1024}$$

where, INT(): Function which returns integer part of value in parentheses

VIN: Analog input voltage

AVREF: AVREF pin voltage

ADCR: A/D conversion result register (ADCR) value

Figure 13-10 shows the relationship between the analog input voltage and the A/D conversion result.





Input voltage/AVREF

# 13.4.3 A/D converter operation mode

The operation mode of the A/D converter is the select mode. One channel of analog input is selected from ANI0 to ANI7 by the analog input channel specification register (ADS) and A/D conversion is executed.

In addition, the following two functions can be selected by setting of bit 7 (PFEN) of the power-fail comparison mode register (PFM).

- Normal 10-bit A/D converter (PFEN = 0)
- Power-fail detection function (PFEN = 1)

# (1) A/D conversion operation (when PFEN = 0)

By setting bit 7 (ADCS) of the A/D converter mode register (ADM) to 1 and bit 7 (PFEN) of the power-fail comparison mode register (PFM) to 0, the A/D conversion operation of the voltage, which is applied to the analog input pin specified by the analog input channel specification register (ADS), is started.

When A/D conversion has been completed, the result of the A/D conversion is stored in the A/D conversion result register (ADCR), and an interrupt request signal (INTAD) is generated. Once the A/D conversion has started and when one A/D conversion has been completed, the next A/D conversion operation is immediately started. The A/D conversion operations are repeated until new data is written to ADS.

If ADS is rewritten during A/D conversion, the A/D conversion under execution is suspended, and the A/D conversion of the newly selected analog input channel is started.

If 0 is written to ADCS of ADM during A/D conversion, the conversion operation is immediately stopped.





**Remarks 1.** n = 0 to 7 **2.** m = 0 to 7

#### (2) Power-fail detection function (when PFEN = 1)

By setting bit 7 (ADCS) of the A/D converter mode register (ADM) to 1 and bit 7 (PFEN) of the power-fail comparison mode register (PFM) to 1, the A/D conversion operation of the voltage applied to the analog input pin specified by the analog input channel specification register (ADS) is started.

When the A/D conversion has been completed, the result of the A/D conversion is stored in the A/D conversion result register (ADCR), the values are compared with power-fail comparison threshold register (PFT), and an interrupt request signal (INTAD) is generated under the condition specified by bit 6 (PFCM) of PFM.

### <1> When PFEN = 0

INTAD is generated at the end of each A/D conversion.

<2> When PFEN = 1 and PFCM = 0

The ADCR and PFT values are compared when A/D conversion ends and INTAD is only generated when  $ADCR \ge PFT$ .

<3> When PFEN = 1 and PFCM = 1

The ADCR and PFT values are compared when A/D conversion ends and INTAD is only generated when ADCR < PFT.



Figure 13-12. Power-Fail Detection (When PFEN = 1 and PFCM = 0)

**Note** If the conversion result is not read before the end of the next conversion after INTAD is output, the result is replaced by the next conversion result.

**Remark** n = 0 to 7

The setting methods are described below.

- When used as A/D conversion operation
  - <1> Set bit 0 (ADCE) of the A/D converter mode register (ADM) to 1.
  - <2> Select the channel and conversion time using bits 2 to 0 (ADS2 to ADS0) of the analog input channel specification register (ADS) and bits 5 to 3 (FR2 to FR0) of ADM.
  - <3> Set bit 7 (ADCS) of ADM to 1.
  - <4> An interrupt request signal (INTAD) is generated.
  - <5> Transfer the A/D conversion data to the A/D conversion result register (ADCR).

<Change the channel>

- <6> Change the channel using bits 2 to 0 (ADS2 to ADS0) of ADS.
- <7> An interrupt request signal (INTAD) is generated.
- <8> Transfer the A/D conversion data to the A/D conversion result register (ADCR).
- <Complete A/D conversion>
  - <9> Clear ADCS to 0.
  - <10> Clear ADCE to 0.

Cautions 1. Make sure the period of <1> to <3> is 14  $\mu$ s or more.

- 2. It is no problem if the order of <1> and <2> is reversed.
- <1> can be omitted. However, do not use the first conversion result after <3> in this case.
- 4. The period from <4> to <7> differs from the conversion time set using bits 5 to 3 (FR2 to FR0) of ADM. The period from <6> to <7> is the conversion time set using FR2 to FR0.
- · When used as power-fail function
  - <1> Set bit 7 (PFEN) of the power-fail comparison mode register (PFM).
  - <2> Set power-fail comparison condition using bit 6 (PFCM) of PFM.
  - <3> Set bit 0 (ADCE) of the A/D converter mode register (ADM) to 1.
  - <4> Select the channel and conversion time using bits 2 to 0 (ADS2 to ADS0) of the analog input channel specification register (ADS) and bits 5 to 3 (FR2 to FR0) of ADM.
  - <5> Set a threshold value to the power-fail comparison threshold register (PFT).
  - <6> Set bit 7 (ADCS) of ADM to 1.
  - <7> Transfer the A/D conversion data to the A/D conversion result register (ADCR).
  - <8> ADCR and PFT are compared and an interrupt request signal (INTAD) is generated if the conditions match.

<Change the channel>

- <9> Change the channel using bits 2 to 0 (ADS2 to ADS0) of ADS.
- <10> Transfer the A/D conversion data to the A/D conversion result register (ADCR).
- <11> ADCR and the power-fail comparison threshold register (PFT) are compared and an interrupt request signal (INTAD) is generated if the conditions match.
- <Complete A/D conversion>

<12> Clear ADCS to 0.

<13> Clear ADCE to 0.

- Cautions 1. Make sure the period of <3> to <6> is 14  $\mu$ s or more.
  - 2. It is no problem if order of <3>, <4>, and <5> is changed.
  - 3. <3> can be omitted. However, do not use the first conversion result after <6> in this case.
  - 4. The period from <7> to <11> differs from the conversion time set using bits 5 to 3 (FR2 to FR0) of ADM. The period from <9> to <11> is the conversion time set using FR2 to FR0.

# 13.5 How to Read A/D Converter Characteristics Table

Here, special terms unique to the A/D converter are explained.

#### (1) Resolution

This is the minimum analog input voltage that can be identified. That is, the percentage of the analog input voltage per bit of digital output is called 1LSB (Least Significant Bit). The percentage of 1LSB with respect to the full scale is expressed by %FSR (Full Scale Range).

1LSB is as follows when the resolution is 10 bits.

 $1LSB = 1/2^{10} = 1/1024$ = 0.098%FSR

Accuracy has no relation to resolution, but is determined by overall error.

#### (2) Overall error

This shows the maximum error value between the actual measured value and the theoretical value. Zero-scale error, full-scale error, integral linearity error, and differential linearity errors that are combinations of these express the overall error.

Note that the quantization error is not included in the overall error in the characteristics table.

# (3) Quantization error

When analog values are converted to digital values, a  $\pm 1/2$ LSB error naturally occurs. In an A/D converter, an analog input voltage in a range of  $\pm 1/2$ LSB is converted to the same digital code, so a quantization error cannot be avoided.

Note that the quantization error is not included in the overall error, zero-scale error, full-scale error, integral linearity error, and differential linearity error in the characteristics table.



# Figure 13-13. Overall Error

#### Figure 13-14. Quantization Error



# (4) Zero-scale error

This shows the difference between the actual measurement value of the analog input voltage and the theoretical value (1/2LSB) when the digital output changes from 0.....000 to 0.....001.

If the actual measurement value is greater than the theoretical value, it shows the difference between the actual measurement value of the analog input voltage and the theoretical value (3/2LSB) when the digital output changes from 0.....001 to 0.....010.

#### (5) Full-scale error

This shows the difference between the actual measurement value of the analog input voltage and the theoretical value (Full-scale -3/2LSB) when the digital output changes from 1.....110 to 1.....111.

# (6) Integral linearity error

This shows the degree to which the conversion characteristics deviate from the ideal linear relationship. It expresses the maximum value of the difference between the actual measurement value and the ideal straight line when the zero-scale error and full-scale error are 0.

# (7) Differential linearity error

While the ideal width of code output is 1LSB, this indicates the difference between the actual measurement value and the ideal value.





Figure 13-17. Integral Linearity Error







Figure 13-18. Differential Linearity Error



#### (8) Conversion time

This expresses the time from when the analog input voltage was applied to the time when the digital output was obtained.

The sampling time is included in the conversion time in the characteristics table.

#### (9) Sampling time

This is the time the analog switch is turned on for the analog voltage to be sampled by the sample & hold circuit.



#### 13.6 Cautions for A/D Converter

#### (1) Current consumption in standby mode

The A/D converter stops operating in the standby mode. At this time, the current consumption can be reduced by stopping the conversion operation (by setting bit 7 (ADCS) of the A/D converter mode register (ADM) to 0). Figure 13-19 shows how to reduce the current consumption in the standby mode.

# Figure 13-19. Example of Method of Reducing Current Consumption in Standby Mode



#### (2) Input range of ANI0 to ANI7

Observe the rated range of the ANI0 to ANI7 input voltage. If a voltage of AV<sub>REF</sub> or higher and AVss or lower (even in the range of absolute maximum ratings) is input to an analog input channel, the converted value of that channel becomes undefined. In addition, the converted values of the other channels may also be affected.

# (3) Conflicting operations

<1> Conflict between A/D conversion result register (ADCR) write and ADCR read by instruction upon the end of conversion

ADCR read has priority. After the read operation, the new conversion result is written to ADCR. Old data can be read from ADCR at the timing of (1) and new data can be read from ADCR at the timing of (2) as shown in Figure 13-20. A master-slave configuration is employed for transferring the A/D conversion result to ADCR.

# Figure 13-20. Storing Conversion Result in ADCR and Timing of Data Read from ADCR



(1) Timing to read old data

<2> Conflict between ADCR write and A/D converter mode register (ADM) write or analog input channel specification register (ADS) write ADM or ADS write has priority. ADCR write is not performed, nor is the conversion end interrupt signal (INTAD) generated.

#### (4) Noise countermeasures

To maintain the 10-bit resolution, attention must be paid to noise input to the AVREF pin and pins ANI0 to ANI7. Because the effect increases in proportion to the output impedance of the analog input source, it is recommended that a capacitor be connected externally, as shown in Figure 13-21, to reduce noise.



#### Figure 13-21. Analog Input Pin Connection

#### (5) ANI0/P20 to ANI7/P27

The analog input pins (ANI0 to ANI7) are also used as input port pins (P20 to P27).

When A/D conversion is performed with any of ANI0 to ANI7 selected, do not execute the input instruction to port 2 while conversion is in progress; otherwise the conversion resolution may be degraded.

If a digital pulse is applied to the pins adjacent to the pins currently used for A/D conversion, the expected value of the A/D conversion may not be obtained due to coupling noise. Therefore, do not apply a pulse to the pins adjacent to the pin undergoing A/D conversion.

#### (6) Input impedance of ANI0 to ANI7 pins

In this A/D converter, the internal sampling capacitor is charged and sampling is performed for approx. one tenth of the conversion time.

Since only the leakage current flows other than during sampling and the current for charging the capacitor also flows during sampling, the input impedance fluctuates and has no meaning.

To perform sufficient sampling, however, it is recommended to make the output impedance of the analog input source 10 k $\Omega$  or lower, or attach a capacitor of around 100 pF to the ANI0 to ANI7 pins (see **Figure 13-21**).

### (7) AVREF pin input impedance

A series resistor string of several tens of 10 k $\Omega$  is connected between the AV<sub>REF</sub> and AV<sub>SS</sub> pins. Therefore, if the output impedance of the reference voltage source is high, this will result in a series connection to the series resistor string between the AV<sub>REF</sub> and AV<sub>SS</sub> pins, resulting in a large reference voltage error.

# (8) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even if the analog input channel specification register (ADS) is changed.

Therefore, if an analog input pin is changed during A/D conversion, the A/D conversion result and ADIF for the pre-change analog input may be set just before the ADS rewrite. Caution is therefore required since, at this time, when ADIF is read immediately after the ADS rewrite, ADIF is set despite the fact A/D conversion for the post-change analog input has not ended.

When A/D conversion is stopped and then resumed, clear ADIF before the A/D conversion operation is resumed.



Figure 13-22. Timing of A/D Conversion End Interrupt Request Generation

**Remarks 1.** n = 0 to 7

**2.** m = 0 to 7

#### (9) Conversion results just after A/D conversion start

The first A/D conversion value immediately after A/D conversion starts may not fall within the rating. Take measures such as polling the A/D conversion end interrupt request (INTAD) and removing the first conversion result.

# (10) A/D conversion result register (ADCR) read operation

When a write operation is performed to the A/D converter mode register (ADM) and analog input channel specification register (ADS), the contents of ADCR may become undefined. Read the conversion result following conversion completion before writing to ADM and ADS. Using timing other than the above may cause an incorrect conversion result to be read.

★ Do not read ADCR when the CPU is operating on the subsystem clock and oscillation of the X1 input clock is stopped.

# (11) A/D converter sampling time and A/D conversion start delay time

Wait

period

A/D

conversion

start delay time

The A/D converter sampling time differs depending on the set value of the A/D converter mode register (ADM). The delay time exists until actual sampling is started after A/D converter operation is enabled.

When using a set in which the A/D conversion time must be strictly observed, care is required for the contents shown in Figure 13-23 and Table 13-3.





Table 13-3. A/D Converter Sampling Time and A/D Conversion Start Delay Time (ADM Set Value)

Conversion time

Sampling

time

| FR2              | FR1 | FR0 | Conversion Time    | Sampling Time | A/D Conversion S | Start Delay Time <sup>Note</sup> |
|------------------|-----|-----|--------------------|---------------|------------------|----------------------------------|
|                  |     |     |                    |               | MIN.             | MAX.                             |
| 0                | 0   | 0   | 288/fx             | 40/fx         | 32/fx            | 36/fx                            |
| 0                | 0   | 1   | 240/fx             | 32/fx         | 28/fx            | 32/fx                            |
| 0                | 1   | 0   | 192/fx             | 24/fx         | 24/fx            | 28/fx                            |
| 1                | 0   | 0   | 144/fx             | 20/fx         | 16/fx            | 18/fx                            |
| 1                | 0   | 1   | 120/fx             | 16/fx         | 14/fx            | 16/fx                            |
| 1                | 1   | 0   | 96/fx              | 12/fx         | 12/fx            | 14/fx                            |
| Other than above |     | ove | Setting prohibited | _             | _                | -                                |

Note The A/D conversion start delay time is the time after wait period. For the wait function, refer to CHAPTER 32 CAUTIONS FOR WAIT.

Remark fx: X1 clock oscillation frequency

# CHAPTER 14 SERIAL INTERFACE UARTO

### 14.1 Functions of Serial Interface UART0

Serial interface UART0 has the following two modes.

#### (1) Operation stop mode

This mode is used when serial transfer is not executed and can enable a reduction in the power consumption. For details, refer to **14.4.1 Operation stop mode**.

# (2) Asynchronous serial interface (UART) mode

The functions of this mode are outlined below.

• Two-pin configuration TxD0: Transmit data output pin

RxB0: Receive data input pin

- Length of transfer data can be selected from 7 or 8 bits.
- Dedicated on-chip 5-bit baud rate generator allowing any baud rate to be set
- Transmission and reception can be performed independently.
- · Four operating clock inputs selectable
- Fixed to LSB-first transfer
- Cautions 1. The default value of the TxD0 pin is high level. Exercise care when using the TxD0 pin as a port pin.
  - 2. If clock supply to serial interface UART0 is not stopped (e.g., in the HALT mode), normal operation continues. If clock supply to serial interface UART0 is stopped (e.g., in the STOP mode), each register stops operating, and holds the value immediately before clock supply was stopped. The TxD0 pin also holds the value immediately before clock supply was stopped and outputs it. However, the operation is not guaranteed after clock supply is resumed. Therefore, reset the circuit so that POWER0 = 0, RXE0 = 0, and TXE0 = 0.
  - 3. Set POWER0 = 1 and then set TXE0 = 1 (transmission) or RXE0 = 1 (reception) to start communication.
  - 4. TXE0 and RXE0 are synchronized with the base clock (fxcLk) set by BRGC0. Therefore, the transmission unit may not be initialized if TXE0 = 1 is not set again 2 clocks after TXE0 = 0 is set. Similarly, the reception unit may not be initialized if RXE0 = 1 is not set again 2 clocks after RXE0 = 0 is set.

# 14.2 Configuration of Serial Interface UART0

Serial interface UART0 consists of the following hardware.

# Table 14-1. Configuration of Serial Interface UART0

| Item              | Configuration                                                                                                                                                                                |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | Receive buffer register 0 (RXB0)<br>Receive shift register 0 (RXS0)<br>Transmit shift register 0 (TXS0)                                                                                      |
| Control registers | Asynchronous serial interface operation mode register 0 (ASIM0)<br>Asynchronous serial interface reception error status register 0 (ASIS0)<br>Baud rate generator control register 0 (BRGC0) |





# (1) Receive buffer register 0 (RXB0)

This 8-bit register stores parallel data converted by receive shift register 0 (RXS0).

Each time 1 byte of data has been received, new receive data is transferred to this register from receive shift register 0 (RXS0).

If the data length is set to 7 bits the receive data is transferred to bits 0 to 6 of RXB0 and the MSB of RXB0 is always 0.

If an overrun error (OVE0) occurs, the receive data is not transferred to RXB0.

RESET input or POWER0 = 0 sets this register to FFH.

RXB0 can be read by an 8-bit memory manipulation instruction. No data can be written to this register.

# (2) Receive shift register 0 (RXS0)

This register converts the serial data input to the RxD0 pin into parallel data. RXS0 cannot be directly manipulated by a program.

# (3) Transmit shift register 0 (TXS0)

This register is used to set transmit data. Transmission is started when data is written to TXS0, and serial data is transmitted from the TxD0 pins.

RESET input, POWER0 = 0, or TXE0 = 0 sets this register to FFH.

TXS0 can be written by an 8-bit memory manipulation instruction. This register cannot be read.

# Caution Do not write the next transmit data to TXS0 before the transmission completion interrupt signal (INTST0) is generated.

# 14.3 Registers Controlling Serial Interface UART0

Serial interface UART0 is controlled by the following three registers.

- Asynchronous serial interface operation mode register 0 (ASIM0)
- Asynchronous serial interface reception error status register 0 (ASIS0)
- Baud rate generator control register 0 (BRGC0)

# (1) Asynchronous serial interface operation mode register 0 (ASIM0)

This 8-bit register controls the serial transfer operations of serial interface UART0. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

# Figure 14-2. Format of Asynchronous Serial Interface Operation Mode Register 0 (ASIM0) (1/2)

#### Address: FF70H After reset: 01H R/W



| POWER0            | Enables/disables operation of internal operation clock                                                                            |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| O <sup>Note</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronously resets the internal circuit. |
| 1                 | Enables operation of the internal operation clock.                                                                                |

| TXE0 | Enables/disables transmission                                        |  |  |  |  |  |  |
|------|----------------------------------------------------------------------|--|--|--|--|--|--|
| 0    | sables transmission (synchronously resets the transmission circuit). |  |  |  |  |  |  |
| 1    | Enables transmission.                                                |  |  |  |  |  |  |

| RXE0 | Enables/disables reception                                      |  |  |  |  |  |  |
|------|-----------------------------------------------------------------|--|--|--|--|--|--|
| 0    | isables reception (synchronously resets the reception circuit). |  |  |  |  |  |  |
| 1    | Enables reception.                                              |  |  |  |  |  |  |

**Note** The input from the RxD0 pin is fixed to high level when POWER0 = 0.

- Cautions 1. At startup, set POWER0 to 1 and then set TXE0 to 1. Clear TXE0 to 0 first, and then clear POWER0 to 0.
  - 2. At startup, set POWER0 to 1 and then set RXE0 to 1. Clear RXE0 to 0 first, and then clear POWER0 to 0.
  - 3. TXE0 and RXE0 are synchronized with the base clock (fxcLk) set by BRGC0. Therefore, the transmission unit may not be initialized if TXE0 = 1 is not set again 2 clocks after TXE0 = 0 is set. Similarly, the reception unit may not be initialized if RXE0 = 1 is not set again 2 clocks after RXE0 = 0 is set.
  - 4. Be sure to set bit 0 to 1.

| PS01 | PS00 | Transmission operation      | Reception operation                   |  |  |
|------|------|-----------------------------|---------------------------------------|--|--|
| 0    | 0    | Does not output parity bit. | Reception without parity              |  |  |
| 0    | 1    | Outputs 0 parity.           | Reception as 0 parity <sup>Note</sup> |  |  |
| 1    | 0    | Outputs odd parity.         | Judges as odd parity.                 |  |  |
| 1    | 1    | Outputs even parity.        | Judges as even parity.                |  |  |

### Figure 14-2. Format of Asynchronous Serial Interface Operation Mode Register 0 (ASIM0) (2/2)

| CL0 | Specifies character length of transmit/receive data |  |  |  |  |  |  |
|-----|-----------------------------------------------------|--|--|--|--|--|--|
| 0   | haracter length of data = 7 bits                    |  |  |  |  |  |  |
| 1   | Character length of data = 8 bits                   |  |  |  |  |  |  |

| SL0 | Specifies number of stop bits of transmit data |  |  |  |  |  |
|-----|------------------------------------------------|--|--|--|--|--|
| 0   | Number of stop bits = 1                        |  |  |  |  |  |
| 1   | Number of stop bits = 2                        |  |  |  |  |  |

**Note** If "reception as 0 parity" is selected, the parity is not judged. Therefore, bit 2 (PE0) of asynchronous serial interface status register 0 (ASIS0) is not set and the error interrupt does not occur.

Cautions 1. Clear the TXE0 and RXE0 bits to 0 before rewriting the PS01, PS00, and CL0 bits.

2. Make sure that TXE0 = 0 when rewriting the SL0 bit. Reception is always performed with "number of stop bits = 1", and therefore, is not affected by the set value of the SL0 bit.

# (2) Asynchronous serial interface reception error status register 0 (ASIS0)

This register indicates an error status on completion of reception by serial interface UART0. It includes three error flag bits (PE0, FE0, OVE0).

This register can be set by an 8-bit memory manipulation instruction and is read-only.

RESET input clears this register to 00H if bit 7 (POWER0) and bit 5 (RXE0) of ASIM0 = 0. 00H is read when this register is read.

#### Figure 14-3. Format of Asynchronous Serial Interface Reception Error Status Register 0 (ASIS0)

Address: FF73H After reset: 00H R

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|--------|---|---|---|---|---|-----|-----|------|
| ASIS0  | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | Status flag indicating parity error                                                      |  |  |  |  |  |  |
|-----|------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0   | If POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.                                |  |  |  |  |  |  |
| 1   | If the parity of transmit data does not match the parity bit on completion of reception. |  |  |  |  |  |  |

| FE0 | Status flag indicating framing error                        |  |  |  |  |  |  |
|-----|-------------------------------------------------------------|--|--|--|--|--|--|
| 0   | POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.      |  |  |  |  |  |  |
| 1   | If the stop bit is not detected on completion of reception. |  |  |  |  |  |  |

| OVE0 | Status flag indicating overrun error                                                                              |  |  |  |  |  |  |  |
|------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | If POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.                                                         |  |  |  |  |  |  |  |
| 1    | If receive data is set to the RXB register and the next reception operation is completed before the data is read. |  |  |  |  |  |  |  |

- Cautions 1. The operation of the PE0 bit differs depending on the set values of the PS01 and PS00 bits of asynchronous serial interface mode register 0 (ASIM0).
  - 2. Only the first bit of the receive data is checked as the stop bit, regardless of the number of stop bits.
  - 3. If an overrun error occurs, the next receive data is not written to receive buffer register 0 (RXB0) but discarded.
  - 4. If data is read from ASIS0, a wait cycle is generated. Do not read data from ASIS0 when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

#### (3) Baud rate generator control register 0 (BRGC0)

This register selects the base clock of serial interface UART0 and controls the baud rate. BRGC0 can be set by an 8-bit memory manipulation instruction. RESET input sets this register to 1FH.

# Figure 14-4. Format of Baud Rate Generator Control Register 0 (BRGC0)

Address: FF71H After reset: 1FH R/W

| Symbol | 7     | 6     | 5 | 4     | 3     | 2     | 1     | 0     |
|--------|-------|-------|---|-------|-------|-------|-------|-------|
| BRGC0  | TPS01 | TPS00 | 0 | MDL04 | MDL03 | MDL02 | MDL01 | MDL00 |

| TPS01 | TPS00 | Base clock (fxcLk) selection  |  |  |  |  |
|-------|-------|-------------------------------|--|--|--|--|
| 0     | 0     | M50 output (TO50)             |  |  |  |  |
| 0     | 1     | íx/2 (5 MHz)                  |  |  |  |  |
| 1     | 0     | fx/2³ (1.25 MHz)              |  |  |  |  |
| 1     | 1     | fx/2 <sup>s</sup> (312.5 kHz) |  |  |  |  |

| MDL04 | MDL03 | MDL02 | MDL01 | MDL00 | k  | Selection of 5-bit counter<br>output clock |
|-------|-------|-------|-------|-------|----|--------------------------------------------|
| 0     | 0     | ×     | ×     | ×     | ×  | Setting prohibited                         |
| 0     | 1     | 0     | 0     | 0     | 8  | fхс∟к/8                                    |
| 0     | 1     | 0     | 0     | 1     | 9  | fхс∟к/9                                    |
| 0     | 1     | 0     | 1     | 0     | 10 | fxclk/10                                   |
| •     | •     | •     | •     | •     | ٠  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| 1     | 1     | 0     | 1     | 0     | 26 | fxclк/26                                   |
| 1     | 1     | 0     | 1     | 1     | 27 | fxclk/27                                   |
| 1     | 1     | 1     | 0     | 0     | 28 | fxclк/28                                   |
| 1     | 1     | 1     | 1     | 0     | 30 | fхс∟к/30                                   |
| 1     | 1     | 1     | 1     | 1     | 31 | fxclk/31                                   |

Cautions 1. Make sure that bit 6 (TXE0) and bit 5 (RXE0) of the ASIM0 register = 0 when rewriting the MDL04 to MDL00 bits.

2. The baud rate is the output clock of the 5-bit counter divided by 2.

Remarks 1. fxcLk: Frequency of base clock (Clock) selected by the TPS01 and TPS00 bits

- 2. fx: X1 input clock oscillation frequency
- **3.** k: Value set by the MDL04 to MDL00 bits (k = 8, 9, 10, ..., 31)
- 4. X: Don't care
- 5. Figures in parentheses apply to operation at fx = 10 MHz

# 14.4 Operation of Serial Interface UART0

This section explains the two modes of serial interface UART0.

#### 14.4.1 Operation stop mode

In this mode, serial transfer cannot be executed, thus reducing the power consumption. In addition, the pins can be used as ordinary port pins in this mode.

### (1) Register setting

The operation stop mode is set by asynchronous serial interface operation mode register 0 (ASIM0). ASIM0 can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

Address: FF70H After reset: 01H R/W

| Symbol | 7      | 6    | 5    | 4    | 3    | 2   | 1   | 0 |
|--------|--------|------|------|------|------|-----|-----|---|
| ASIM0  | POWER0 | TXE0 | RXE0 | PS01 | PS00 | CL0 | SL0 | 1 |

| POWER0            | Enables/disables operation of internal operation clock                                                                            |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| O <sup>Note</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronously resets the internal circuit. |
| 1                 | Enables operation of the internal operation clock.                                                                                |

| TXE0 | Enables/disables transmission                                          |
|------|------------------------------------------------------------------------|
| 0    | Disables transmission (synchronously resets the transmission circuit). |
| 1    | Enables transmission.                                                  |

| RXE0 | Enables/disables reception                                       |
|------|------------------------------------------------------------------|
| 0    | Disables reception (synchronously resets the reception circuit). |
| 1    | Enables reception.                                               |

Note The input from the RxD0 pin is fixed to high level when POWER0 = 0.

- Cautions 1. At startup, set POWER0 to 1 and then set TXE0 to 1. Clear TXE0 to 0 first, and then clear POWER0 to 0.
  - 2. At startup, set POWER0 to 1 and then set RXE0 to 1. Clear RXE0 to 0 first, and then clear POWER0 to 0.
  - 3. TXE0 and RXE0 are synchronized with the base clock (fxcLk) set by BRGC0. Therefore, the transmission unit may not be initialized if TXE0 = 1 is not set again 2 clocks after TXE0 = 0 is set. Similarly, the reception unit may not be initialized if RXE0 = 1 is not set again 2 clocks after RXE0 = 0 is set.

# 14.4.2 Asynchronous serial interface (UART) mode

In this mode, 1-byte data is transmitted/received following a start bit, and a full-duplex operation can be performed.

A dedicated UART baud rate generator is incorporated, so that communication can be executed at a wide range of baud rates.

# (1) Register setting

The UART mode is set by asynchronous serial interface operation mode register 0 (ASIM0), asynchronous serial interface reception error status register 0 (ASIS0), and baud rate generator control register 0 (BRGC0).

# (a) Asynchronous serial interface operation mode register 0 (ASIM0)

This 8-bit register controls the serial transfer operations of serial interface UART0. ASIM0 can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

Address: FF70H After reset: 01H R/W

| Symbol | 7      | 6    | 5    | 4    | 3    | 2   | 1   | 0 |
|--------|--------|------|------|------|------|-----|-----|---|
| ASIM0  | POWER0 | TXE0 | RXE0 | PS01 | PS00 | CL0 | SL0 | 1 |

| POWER0            | Enables/disables operation of internal operation clock                                                                            |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| O <sup>Note</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronously resets the internal circuit. |
| 1                 | Enables operation of the internal operation clock.                                                                                |

| TXE0 | Enables/disables transmission                                          |
|------|------------------------------------------------------------------------|
| 0    | Disables transmission (synchronously resets the transmission circuit). |
| 1    | Enables transmission.                                                  |

| RXE0 | Enables/disables reception                                       |
|------|------------------------------------------------------------------|
| 0    | Disables reception (synchronously resets the reception circuit). |
| 1    | Enables reception                                                |

Note The input from the RxD0 pin is fixed to high level when POWER0 = 0.

- Cautions 1. At startup, set POWER0 to 1 and then set TXE0 to 1. Clear TXE0 to 0 first, and then clear POWER0 to 0.
  - 2. At startup, set POWER0 to 1 and then set RXE0 to 1. Clear RXE0 to 0 first, and then clear POWER0 to 0.
  - 3. TXE0 and RXE0 are synchronized with the base clock (fxcLK) set by BRGC0. Therefore, the transmission unit may not be initialized if TXE0 = 1 is not set again 2 clocks after TXE0 = 0 is set. Similarly, the reception unit may not be initialized if RXE0 = 1 is not set again 2 clocks after RXE0 = 0 is set.
  - 4. Be sure to set bit 0 to 1.

| PS01 | PS00 | Transmission operation      | Reception operation                   |  |  |
|------|------|-----------------------------|---------------------------------------|--|--|
| 0    | 0    | Does not output parity bit. | Reception without parity              |  |  |
| 0    | 1    | Outputs 0 parity.           | Reception as 0 parity <sup>Note</sup> |  |  |
| 1    | 0    | Outputs odd parity.         | Judges as odd parity.                 |  |  |
| 1    | 1    | Outputs even parity.        | Judges as even parity.                |  |  |

| CL0 | Specifies character length of transmit/receive data |  |
|-----|-----------------------------------------------------|--|
| 0   | Character length of data = 7 bits                   |  |
| 1   | Character length of data = 8 bits                   |  |

| SL0 | Specifies number of stop bits of transmit data |
|-----|------------------------------------------------|
| 0   | Number of stop bits = 1                        |
| 1   | Number of stop bits = 2                        |

- **Note** If "reception as 0 parity" is selected, the parity is not judged. Therefore, bit 2 (PE0) of asynchronous serial interface status register 0 (ASIS0) is not set and the error interrupt does not occur.
- Cautions 1. Clear the TXE0 and RXE0 bits to 0 before rewriting the PS01, PS00, and CL0 bits.
  - 2. Make sure that TXE0 = 0 when rewriting the SL0 bit. Reception is always performed with "number of stop bits = 1", and therefore, is not affected by the set value of the SL0 bit.

## (b) Asynchronous serial interface reception error status register 0 (ASIS0)

This register indicates an error status on completion of reception by serial interface UART0. It includes three error flag bits (PE0, FE0, OVE0).

This register can be set by an 8-bit memory manipulation instruction and is read-only.

RESET input clears this register to 00H if bit 7 (POWER0) and bit 5 (RXE0) of ASIM0 = 0. 00H is read when this register is read.

Address: FF73H After reset: 00H R

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|--------|---|---|---|---|---|-----|-----|------|
| ASIS0  | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | Status flag indicating parity error                                                      |
|-----|------------------------------------------------------------------------------------------|
| 0   | If POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.                                |
| 1   | If the parity of transmit data does not match the parity bit on completion of reception. |

| FE0 | Status flag indicating framing error                        |
|-----|-------------------------------------------------------------|
| 0   | If POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.   |
| 1   | If the stop bit is not detected on completion of reception. |

| OVE0 | Status flag indicating overrun error                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------|
| 0    | If POWER0 = 0 and RXE0 = 0, or if ASIS0 register is read.                                                         |
| 1    | If receive data is set to the RXB register and the next reception operation is completed before the data is read. |

- Cautions 1. The operation of the PE0 bit differs depending on the set values of the PS01 and PS00 bits of asynchronous serial interface mode register 0 (ASIM0).
  - 2. Only the first bit of the receive data is checked as the stop bit, regardless of the number of stop bits.
  - 3. If an overrun error occurs, the next receive data is not written to receive buffer register 0 (RXB0) but discarded.
  - 4. If data is read from ASIS0, a wait cycle is generated. Do not read data from ASIS0 when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

## (2) Communication operation

## (a) Normal transmit/receive data format

Figure 14-5 shows the format of the transmit/receive data.

## Figure 14-5. Format of Normal UART Transmit/Receive Data



One data frame consists of the following bits.

- Start bit ... 1 bit
- Character bits ... 7 or 8 bits (LSB first)
- Parity bit ... Even parity, odd parity, 0 parity, or no parity
- Stop bit ... 1 or 2 bits

The character bit length, parity, and stop bit length in one data frame are specified by asynchronous serial interface mode register 0 (ASIM0).

## Figure 14-6. Example of Normal UART Transmit/Receive Data Format

#### 1. Data length: 8 bits, Parity: Even parity, Stop bit: 1 bit, Transfer data: 55H



#### 2. Data length: 7 bits, Parity: Odd parity, Stop bit: 2 bits, Transfer data: 36H

|       | ▲ 1 data frame → |    |    |    |    |    |    |        |      |      |
|-------|------------------|----|----|----|----|----|----|--------|------|------|
| Start | D0               | D1 | D2 | D3 | D4 | D5 | D6 | Parity | Stop | Stop |

#### 3. Data length: 8 bits, Parity: None, Stop bit: 1 bit, Transfer data: 87H

|       | - 1 data frame |    |    |    |    |    |    |    |      |                          |
|-------|----------------|----|----|----|----|----|----|----|------|--------------------------|
| Start | D0             | D1 | D2 | D3 | D4 | D5 | D6 | D7 | Stop | <br> <br> <br> <br> <br> |

## (b) Parity types and operation

The parity bit is used to detect a bit error in communication data. Usually, the same type of parity bit is used on both the transmission and reception sides. With even parity and odd parity, a 1-bit (odd number) error can be detected. With zero parity and no parity, an error cannot be detected.

- (i) Even parity
  - Transmission

Transmit data, including the parity bit, is controlled so that the number of bits that are "1" is even. The value of the parity bit is as follows.

If transmit data has an odd number of bits that are "1": 1 If transmit data has an even number of bits that are "1": 0

Reception

The number of bits that are "1" in the receive data, including the parity bit, is counted. If it is odd, a parity error occurs.

## (ii) Odd parity

Transmission

Unlike even parity, transmit data, including the parity bit, is controlled so that the number of bits that are "1" is odd.

If transmit data has an odd number of bits that are "1": 0 If transmit data has an even number of bits that are "1": 1

Reception

The number of bits that are "1" in the receive data, including the parity bit, is counted. If it is even, a parity error occurs.

(iii) 0 parity

The parity bit is cleared to 0 when data is transmitted, regardless of the transmit data. The parity bit is not detected when the data is received. Therefore, a parity error does not occur regardless of whether the parity bit is "0" or "1".

(iv) No parity

No parity bit is appended to the transmit data.

Reception is performed assuming that there is no parity bit when data is received. Because there is no parity bit, a parity error does not occur.

## (c) Transmission

The TxD0 pin outputs a high level when bit 7 (POWER0) of asynchronous serial interface mode register 0 (ASIM0) is set to 1. If bit 6 (TXE0) of ASIM0 is then set to 1, transmission is enabled. Transmission can be started by writing transmit data to transmit shift register 0 (TXS0). The start bit, parity bit, and stop bit are automatically appended to the data.

When transmission is started, the start bit is output from the TxD0 pin, followed by the rest of the data in order starting from the LSB. When transmission is completed, the parity and stop bits set by ASIM0 are appended and a transmission completion interrupt request (INTST0) is generated.

Transmission is stopped until the data to be transmitted next is written to TXS0.

Figure 14-7 shows the timing of the transmission completion interrupt request (INTST0). This interrupt occurs as soon as the last stop bit has been output.

# Caution After transmit data is written to TXS0, do not write the next transmit data before the transmission completion interrupt signal (INTST0) is generated.

#### Figure 14-7. Normal Transmission Completion Interrupt Request Timing

#### 1. Stop bit length: 1



## (d) Reception

Reception is enabled and the RxD0 pin input is sampled when bit 7 (POWER0) of asynchronous serial interface mode register 0 (ASIM0) is set to 1 and then bit 5 (RXE0) of ASIM0 is set to 1.

The 5-bit counter of the baud rate generator starts counting when the falling edge of the RxD0 pin input is detected. When the set value of baud rate generator control register 0 (BRGC0) has been counted, the RxD0 pin input is sampled again ( $\bigtriangledown$  in Figure 14-8). If the RxD0 pin is low level at this time, it is recognized as a start bit.

When the start bit is detected, reception is started, and serial data is sequentially stored in receive shift register 0 (RXS0) at the set baud rate. When the stop bit has been received, the reception completion interrupt (INTSR0) is generated and the data of RXS0 is written to receive buffer register 0 (RXB0). If an overrun error (OVE0) occurs, however, the receive data is not written to RXB0.

Even if a parity error (PE0) or a framing error (FE0) occurs while reception is in progress, reception continues to the reception position of the stop bit, and an error interrupt (INTSR0) is generated after completion of reception.





- Cautions 1. Be sure to read receive buffer register 0 (RXB0) even if a reception error occurs. Otherwise, an overrun error will occur when the next data is received, and the reception error status will persist.
  - 2. Reception is always performed with the "number of stop bits = 1". The second stop bit is ignored.
  - 3. Be sure to read asynchronous serial interface reception error status register 0 (ASIS0) before reading RXB0.

## (e) Reception error

Three types of errors may occur during reception: a parity error, framing error, or overrun error. If the error flag of asynchronous serial interface reception error status register 0 (ASIS0) is set as a result of data reception, a reception error interrupt request (INTSR0) is generated.

Which error has occurred during reception can be identified by reading the contents of ASIS0 in the reception error interrupt servicing (INTSR0) (refer to **Table 14-2**).

The contents of ASIS0 are reset to 0 when ASIS0 is read.

| Table 14-2. | Cause of Reception Error |  |
|-------------|--------------------------|--|
|-------------|--------------------------|--|

| Reception Error | Cause                                                                                              | Value of ASIS0 |
|-----------------|----------------------------------------------------------------------------------------------------|----------------|
| Parity error    | The parity specified for transmission does not match the parity of the receive data.               | 04H            |
| Framing error   | Stop bit is not detected.                                                                          | 02H            |
| Overrun error   | Reception of the next data is completed before data is read from receive buffer register 0 (RXB0). | 01H            |

## (f) Noise filter of receive data

The RxD0 signal is sampled using the base clock output by the prescaler block.

If two sampled values are the same, the output of the match detector changes, and the data is sampled as input data.

Because the circuit is configured as shown in Figure 14-9, the internal processing of the reception operation is delayed by two clocks from the external signal status.





## 14.4.3 Dedicated baud rate generator

The dedicated baud rate generator consists of a source clock selector and a 5-bit programmable counter, and generates a serial clock for transmission/reception of UART0.

Separate 5-bit counters are provided for transmission and reception.

## (1) Configuration of baud rate generator

• Base clock (Clock)

The clock selected by bits 7 and 6 (TPS01 and TPS00) of baud rate generator control register 0 (BRGC0) is supplied to each module when bit 7 (POWER0) of asynchronous serial interface mode register 0 (ASIM0) is 1. This clock is called the base clock "Clock" and its frequency is called fxcLk. "Clock" is fixed to low level when POWER0 = 0.

Transmission counter

This counter stops, cleared to 0, when bit 7 (POWER0) or bit 6 (TXE0) of asynchronous serial interface mode register 0 (ASIM0) is 0.

It starts counting when POWER0 = 1 and TXE0 = 1.

The counter is cleared to 0 when the first data transmitted is written to transmit shift register 0 (TXS0).

Reception counter

This counter stops operation, cleared to 0, when bit 7 (POWER0) or bit 5 (RXE0) of asynchronous serial interface mode register 0 (ASIM0) is 0.

It starts counting when the start bit has been detected.

The counter stops operation after one frame has been received, until the next start bit is detected.





Remark POWER0: Bit 7 of asynchronous serial interface mode register 0 (ASIM0)

| TXE0: | Bit 6 of ASIM0 |
|-------|----------------|
| RXE0: | Bit 5 of ASIM0 |

RXE0: Bit 5 of ASIM0 BRGC0: Baud rate generator control register 0

## (2) Generation of serial clock

A serial clock can be generated by using baud rate generator control register 0 (BRGC0). Select the clock to be input to the 5-bit counter by using bits 7 and 6 (TPS01 and TPS00) of BRGC0. Bits 4 to 0 (MDL04 to MDL00) of BRGC0 can be used to select the division value of the 5-bit counter.

## (a) Baud rate generator control register 0 (BRGC0)

This register selects the base clock of serial interface UART0 and controls the baud rate. BRGC0 can be set by an 8-bit memory manipulation instruction. RESET input sets this register to 1FH.

#### Address: FF71H After reset: 1FH R/W

| Symbol |  |
|--------|--|
| BRGC0  |  |

 7
 6
 5
 4
 3
 2
 1

 TPS01
 TPS00
 0
 MDL04
 MDL03
 MDL02
 MDL01

| TPS01 | TPS00 | Base clock (fxcLK) selection  |
|-------|-------|-------------------------------|
| 0     | 0     | TM50 output (TO50)            |
| 0     | 1     | fx/2 (5 MHz)                  |
| 1     | 0     | fx/2³ (1.25 MHz)              |
| 1     | 1     | fx/2 <sup>s</sup> (312.5 kHz) |

0

MDL00

| MDL04 | MDL03 | MDL02 | MDL01 | MDL00 | k  | Selection of 5-bit counter<br>output clock |
|-------|-------|-------|-------|-------|----|--------------------------------------------|
| 0     | 0     | ×     | ×     | ×     | ×  | Setting prohibited                         |
| 0     | 1     | 0     | 0     | 0     | 8  | fxclk/8                                    |
| 0     | 1     | 0     | 0     | 1     | 9  | fxclk/9                                    |
| 0     | 1     | 0     | 1     | 0     | 10 | fxclĸ/10                                   |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| •     | •     | •     | •     | •     | •  | •                                          |
| 1     | 1     | 0     | 1     | 0     | 26 | fxclк/26                                   |
| 1     | 1     | 0     | 1     | 1     | 27 | fxclк/27                                   |
| 1     | 1     | 1     | 0     | 0     | 28 | fxclк/28                                   |
| 1     | 1     | 1     | 1     | 0     | 30 | fxclк/ <b>30</b>                           |
| 1     | 1     | 1     | 1     | 1     | 31 | fxclk/31                                   |

Cautions 1. Make sure that bit 6 (TXE0) and bit 5 (RXE0) of the ASIM0 register = 0 when rewriting the MDL04 to MDL00 bits.

2. The baud rate value is the output clock of the 5-bit counter divided by 2.

Remarks 1. fxcLk: Frequency of base clock (Clock) selected by the TPS01 and TPS00 bits

- 2. fx: X1 input clock oscillation frequency
- **3.** k: Value set by the MDL04 to MDL00 bits (k = 8, 9, 10, ..., 31)
- 4. ×: Don't care
- 5. Figures in parentheses apply to operation with fx = 10 MHz

## (b) Baud rate

The baud rate can be calculated by the following expression.

• Baud rate = 
$$\frac{f_{XCLK}}{2 \times k}$$
 [bps]

fxcLk: Frequency of base clock (Clock) selected by the TPS01 and TPS00 bits of the BRGC0 registerk: Value set by the MDL04 to MDL00 bits of the BRGC0 register (k = 8, 9, 10, ..., 31)

## (c) Error of baud rate

The baud rate error can be calculated by the following expression.

• Error (%) =  $\left(\frac{\text{Actual baud rate (baud rate with error)}}{\text{Desired baud rate (correct baud rate)}} - 1\right) \times 100 [\%]$ 

- Cautions 1. Keep the baud rate error during transmission to within the permissible error range at the reception destination.
  - 2. Make sure that the baud rate error during reception satisfies the range shown in (4) Permissible baud rate range during reception.
  - Example: Frequency of base clock (Clock) = 2.5 MHz = 2,500,000 Hz Set value of MDL04 to MDL00 bits of BRGC0 register = 10000B (k = 16) Target baud rate = 76,800 bps

Baud rate = 2.5 M/(2 × 16) = 2,500,000/(2 × 16) = 78,125 [bps]

Error = (78,125/76,800 - 1) × 100 = 1.725 [%]

## (3) Example of setting baud rate

| Baud Rate |                 | fx = | 10.0 MHz         |        |                 | fx = | 8.38 MHz            |        | fx = 4.19 MHz   |    |                     |        |
|-----------|-----------------|------|------------------|--------|-----------------|------|---------------------|--------|-----------------|----|---------------------|--------|
| [bps]     | TPS01,<br>TPS00 | k    | Calculated value | ERR[%] | TPS01,<br>TPS00 | k    | Calculated<br>Value | ERR[%] | TPS01,<br>TPS00 | k  | Calculated<br>Value | ERR[%] |
| 2400      | -               | -    | -                | -      | -               | -    | -                   | -      | 3               | 27 | 2425                | 1.03   |
| 4800      | _               | -    | -                | _      | 3               | 27   | 4850                | 1.03   | 3               | 14 | 4676                | -2.58  |
| 9600      | 3               | 16   | 9766             | 1.73   | 3               | 14   | 9353                | -2.58  | 2               | 27 | 9699                | 1.03   |
| 10400     | 3               | 15   | 10417            | 0.16   | 3               | 13   | 10072               | -3.15  | 2               | 25 | 10475               | 0.72   |
| 19200     | 3               | 8    | 19531            | 1.73   | 2               | 27   | 19398               | 1.03   | 2               | 14 | 18705               | -2.58  |
| 31250     | 2               | 20   | 31250            | 0      | 2               | 17   | 30809               | -1.41  | -               | -  | -                   | _      |
| 38400     | 2               | 16   | 39063            | 1.73   | 2               | 14   | 38796               | -2.58  | 2               | 27 | 38796               | 1.03   |
| 76800     | 2               | 8    | 78125            | 1.73   | 1               | 27   | 77593               | 1.03   | 1               | 14 | 74821               | -2.58  |
| 115200    | 1               | 22   | 113636           | -1.36  | 1               | 18   | 116389              | 1.03   | 1               | 9  | 116389              | 1.03   |
| 153600    | 1               | 16   | 156250           | 1.73   | 1               | 14   | 149643              | -2.58  | _               | -  | _                   | _      |
| 230400    | 1               | 11   | 227273           | -1.36  | 1               | 9    | 232778              | 1.03   | _               | -  | -                   | _      |

Table 14-3. Set Data of Baud Rate Generator

**Remark** TPS01, TPS00:

Bits 7 and 6 of baud rate generator control register 0 (BRGC0) (setting of base clock (fxcLk))

k: Value set by the MDL04 to MDL00 bits of BRGC0 (k = 8, 9, 10, ..., 31)fx: X1 input clock oscillation frequency

ERR:

: Baud rate error

#### (4) Permissible baud rate range during reception

The permissible error from the baud rate at the transmission destination during reception is shown below.

Caution Make sure that the baud rate error during reception is within the permissible error range, by using the calculation expression shown below.





As shown in Figure 14-11, the latch timing of the receive data is determined by the counter set by baud rate generator control register 0 (BRGC0) after the start bit has been detected. If the last data (stop bit) meets this latch timing, the data can be correctly received.

Assuming that 11-bit data is received, the theoretical values can be calculated as follows.

 $FL = (Brate)^{-1}$ 

Brate:Baud rate of UART0k:Set value of BRGC0FL:1-bit data lengthMargin of latch timing: 2 clocks

$$\label{eq:maintain} \mbox{Minimum permissible transfer rate: FLmin = 11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k} \ \mbox{FL}$$

Therefore, the maximum receivable baud rate at the transmission destination is as follows.

BRmax = 
$$(FLmin/11)^{-1} = \frac{22k}{21k+2}$$
 Brate

Similarly, the maximum permissible transfer rate can be calculated as follows.

$$\frac{10}{11} \times FLmax = 11 \times FL - \frac{k+2}{2 \times k} \times FL = \frac{21k-2}{2 \times k} FL$$

$$FLmax = \frac{21k-2}{20k} FL \times 11$$

Therefore, the minimum receivable baud rate at the transmission destination is as follows.

BRmin = 
$$(FLmax/11)^{-1} = \frac{20k}{21k - 2}$$
 Brate

The permissible baud rate error between UART0 and the transmission destination can be calculated from the above minimum and maximum baud rate expressions, as follows.

#### Table 14-4. Maximum/Minimum Permissible Baud Rate Error

| Division Ratio (k) | Maximum Permissible Baud Rate Error | Minimum Permissible Baud Rate Error |
|--------------------|-------------------------------------|-------------------------------------|
| 8                  | +3.53%                              | -3.61%                              |
| 16                 | +4.14%                              | -4.19%                              |
| 24                 | +4.34%                              | -4.38%                              |
| 31                 | +4.44%                              | -4.47%                              |

**Remarks 1.** The accuracy of reception depends on the number of bits in one frame, input clock frequency, and division ratio (k). The higher the input clock frequency and the higher the division ratio (k), the higher the accuracy.

2. k: Set value of BRGC0

## CHAPTER 15 SERIAL INTERFACE UART6

## 15.1 Functions of Serial Interface UART6

Serial interface UART6 has the following two modes.

#### (1) Operation stop mode

This mode is used when serial transfer is not executed and can enable a reduction in the power consumption. For details, refer to **15.4.1 Operation stop mode**.

#### (2) Asynchronous serial interface (UART) mode

This mode supports the LIN (Local Interconnect Network) bus. The functions of this mode are outlined below.

• Two-pin configuration TxD6: Transmit data output pin

RxB6: Receive data input pin

- Data length of transfer data can be selected from 7 or 8 bits.
- Dedicated internal 8-bit baud rate generator allowing any baud rate to be set
- Transmission and reception can be performed independently.
- Twelve operating clock inputs selectable
- MSB- or LSB-first transfer selectable
- Inverted transmission operation
- Tuning break field transmission from 13 to 20 bits
- More than 11 bits can be identified for tuning break field reception (SBF reception flag provided).
- Cautions 1. The default value of the TxD6 pin is the high level. Exercise care when using the TxD6 pin as a port pin.
  - 2. The TxD6 output inversion function inverts only the transmission side and not the reception side. To use this function, the reception side must be ready for reception of inverted data (it must be able to recognize a low-level start bit).
  - 3. If clock supply to serial interface UART6 is not stopped (e.g., in the HALT mode), normal operation continues. If clock supply to serial interface UART6 is stopped (e.g., in the STOP mode), each register stops operating, and holds the value immediately before clock supply was stopped. The TxD6 pin also holds the value immediately before clock supply was stopped and outputs it. However, the operation is not guaranteed after clock supply is resumed. Therefore, reset the circuit so that POWER6 = 0, RXE6 = 0, and TXE6 = 0.
  - 4. If data is continuously transmitted, the transfer rate from the stop bit to the next start bit is extended two clocks. However, this does not affect the result of transfer because the reception side initializes the timing when it has detected a start bit. Do not use the continuous transmission function if the interface is incorporated in LIN.

**Remark** LIN stands for Local Interconnect Network and is a low-speed (1 to 20 kbps) serial communication protocol intended to aid the cost reduction of an automotive network.

LIN communication is single-master communication, and up to 15 slaves can be connected to one master.

The LIN slaves are used to control the switches, actuators, and sensors, and these are connected to the LIN master via the LIN network.

Normally, the LIN master is connected to a network such as CAN (Controller Area Network).

In addition, the LIN bus uses a single-wire method and is connected to the nodes via a transceiver that complies with ISO9141.

In the LIN protocol, the master transmits a frame with baud rate information and the slave receives it and corrects the baud rate error. Therefore, communication is possible when the baud rate error in the slave is  $\pm 15\%$  or less.

Figures 15-1 and 15-2 outline the transmission and reception operations of LIN.



Figure 15-1. LIN Transmission Operation

Notes 1. The interval between each field is controlled by software.

- The tuning break field is output by hardware. The output width is equal to the bit length set by bits 5 to 3 (SBL62 to SBL60) of asynchronous serial interface control register 6 (ASICL6). If the output width needs to be adjusted more accurately, use baud rate generator control register 6 (BRGC6).
- 3. The wakeup signal frame is substituted by 80H transfer in the 8-bit mode.
- 4. INTST6 is output on completion of each transmission. It is also output when SBF is transmitted.



## Figure 15-2. LIN Reception Operation

- **Notes 1.** The wakeup signal is detected at the edge of the pin, and enables UART6 and sets the SBF reception mode.
  - Reception continues until the STOP bit is detected. When 11 bits or more of SBF have been detected, it is assumed that SBF reception has been completed correctly, and an interrupt signal is output. If less than 11 bits of SBF have been detected, it is assumed that an SBF reception error has occurred. The interrupt signal is not output and the SBF reception mode is restored.
  - **3.** If SBF reception has been completed correctly, an interrupt signal is output. This SBF reception completion interrupt enables the capture timer. Detection of errors OVE6, PE6, and FE6 is suppressed, and error detection processing of UART communication and data transfer of the shift register and RXB6 is not performed. The shift register holds the reset value FFH.
  - 4. Calculate the baud rate error from the value obtained from the capture timer, disable UART6 after SF reception, and then re-set baud rate generator control register 6 (BRGC6).
  - 5. Distinguish the checksum field by software. Also perform processing by software to initialize UART6 after reception of the checksum field and to set the SBF reception mode again.

To perform a LIN receive operation, use a configuration like the one shown in Figure 15-3.

The wakeup signal transmitted from the LIN master is received by detecting the edge of the external interrupt (INTPO). The length of the tuning break field transmitted from the LIN master can be measured using the external event capture operation of 16-bit timer/event counter 00, and the baud rate error can be calculated using the time and number of bits of the tuning break field.

The input signal of the reception port input (RxD6) can be input to the external interrupt (INTP0) and 16-bit timer/event counter 00 by port input switch control (ISC0/ISC1), without connecting RxD6 and INTP0/TI000 externally.



#### Figure 15-3. Port Configuration for LIN Reception Operation



The resources used in the LIN communication operation are shown below. <Resources used>

• External interrupt (INTP0); wakeup signal detection

Use: Detects the wakeup signal edges and detects start of communication.

- 16-bit timer/event counter 00 (TI000); baud rate error detection
- Use: Detects the baud rate error (measures the TI000 input edge interval in the capture mode) by detecting the tuning break field (SBF) length and divides it by the number of bits.
- Serial interface UART6

## 15.2 Configuration of Serial Interface UART6

Serial interface UART6 consists of the following hardware.

## Table 15-1. Configuration of Serial Interface UART6

| Item              | Configuration                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | Receive buffer register 6 (RXB6)<br>Receive shift register 6 (RXS6)<br>Transmit buffer register 6 (TXB6)<br>Transmit shift register 6 (TXS6)                                                                                                                                                                                                                            |
| Control registers | Asynchronous serial interface operation mode register 6 (ASIM6)<br>Asynchronous serial interface reception error status register 6 (ASIS6)<br>Asynchronous serial interface transmission status register 6 (ASIF6)<br>Clock selection register 6 (CKSR6)<br>Baud rate generator control register 6 (BRGC6)<br>Asynchronous serial interface control register 6 (ASICL6) |





## (1) Receive buffer register 6 (RXB6)

This 8-bit register stores parallel data converted by the receive shift register.

Each time 1 byte of data has been received, new receive data is transferred to this register from receive shift register 6 (RXS6). If the data length is set to 7 bits, data is transferred as follows.

- In LSB-first reception, the receive data is transferred to bits 0 to 6 of RXB6 and the MSB of RXB6 is always 0.
- In MSB-first reception, the receive data is transferred to bits 1 to 7 of RXB6 and the LSB of RXB6 is always 0. If an overrun error (OVE6) occurs, the receive data is not transferred to RXB6.

RXB6 can be read by an 8-bit memory manipulation instruction. No data can be written to this register. RESET input sets this register to FFH.

## (2) Receive shift register 6 (RXS6)

This register converts the serial data input to the RxD6 pin into parallel data. RXS6 cannot be directly manipulated by a program.

## (3) Transmit buffer register 6 (TXB6)

This buffer register is used to set transmit data. Transmission is started when data is written to TXB6. This register can be read or written by an 8-bit memory manipulation instruction. RESET input sets this register to FFH.

- Cautions 1. Do not write data to TXB6 when bit 1 (TXBF6) of asynchronous serial interface transmission status register 6 (ASIF6) is 1.
  - Do not refresh (write the same value to) TXB6 by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of asynchronous serial interface operation mode register 6 (ASIM6) are 1 or when bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 are 1). However, if the same value is continuously transmitted in the transmission mode (POWER6 = 1 and TXE6 = 1), the same value can be written.

## (4) Transmit shift register 6 (TXS6)

This register transmits the data transferred from TXB6 from the TxD6 pin as serial data. Data is transferred from TXB6 immediately after TXB6 is written for the first transmission, or immediately before INTST6 occurs after one frame was transmitted for continuous transmission. Data is transferred from TXB6 and transmitted from the TxD6 pin at the falling edge of the internal clock.

TXS6 cannot be directly manipulated by a program.

## 15.3 Registers Controlling Serial Interface UART6

Serial interface UART6 is controlled by the following six registers.

- Asynchronous serial interface operation mode register 6 (ASIM6)
- Asynchronous serial interface reception error status register 6 (ASIS6)
- Asynchronous serial interface transmission status register 6 (ASIF6)
- Clock selection register 6 (CKSR6)
- Baud rate generator control register 6 (BRGC6)
- Asynchronous serial interface control register 6 (ASICL6)

## (1) Asynchronous serial interface operation mode register 6 (ASIM6)

This 8-bit register controls the serial transfer operations of serial interface UART6. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

**Remark** ASIM6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

## Figure 15-5. Format of Asynchronous Serial Interface Operation Mode Register 6 (ASIM6) (1/2)

Address: FF50H After reset: 01H R/W

| Symbol | 7      | 6    | 5    | 4    | 3    | 2   | 1   | 0     |
|--------|--------|------|------|------|------|-----|-----|-------|
| ASIM6  | POWER6 | TXE6 | RXE6 | PS61 | PS60 | CL6 | SL6 | ISRM6 |

| POWER6              | Enables/disables operation of internal operation clock                                                                            |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0 <sup>Note 1</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronously resets the internal circuit. |
| 1 <sup>Note 2</sup> | Enables operation of the internal operation clock                                                                                 |

| TXE6 | Enables/disables transmission                                          |
|------|------------------------------------------------------------------------|
| 0    | Disables transmission (synchronously resets the transmission circuit). |
| 1    | Enables transmission                                                   |

- **Notes 1.** The output of the TxD6 pin goes high and the input from the RxD6 pin is fixed to the high level when POWER6 = 0.
  - 2. Operation of the internal operation clock is enabled at the second input clock after 1 is written to the POWER6 bit.
- Caution At startup, set POWER6 to 1 and then set TXE6 to 1. Clear TXE6 to 0 first, and then clear POWER6 to 0.

#### Figure 15-5. Format of Asynchronous Serial Interface Operation Mode Register 6 (ASIM6) (2/2)

| RXE6 | Enables/disables reception                                       |  |  |  |  |  |
|------|------------------------------------------------------------------|--|--|--|--|--|
| 0    | Disables reception (synchronously resets the reception circuit). |  |  |  |  |  |
| 1    | Enables reception                                                |  |  |  |  |  |

| PS61 | PS60 | Transmission operation      | Reception operation                   |
|------|------|-----------------------------|---------------------------------------|
| 0    | 0    | Does not output parity bit. | Reception without parity              |
| 0    | 1    | Outputs 0 parity.           | Reception as 0 parity <sup>Note</sup> |
| 1    | 0    | Outputs odd parity.         | Judges as odd parity.                 |
| 1    | 1    | Outputs even parity.        | Judges as even parity.                |

| CL6 | Specifies character length of transmit/receive data |  |  |  |  |  |
|-----|-----------------------------------------------------|--|--|--|--|--|
| 0   | Character length of data = 7 bits                   |  |  |  |  |  |
| 1   | Character length of data = 8 bits                   |  |  |  |  |  |

| SL6 | Specifies number of stop bits of transmit data |  |  |  |  |  |  |
|-----|------------------------------------------------|--|--|--|--|--|--|
| 0   | Number of stop bits = 1                        |  |  |  |  |  |  |
| 1   | Number of stop bits = 2                        |  |  |  |  |  |  |

| ISRM6 | Enables/disables occurrence of reception completion interrupt in case of error |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | "INTSRE6" occurs in case of error (at this time, INTSR6 does not occur).       |  |  |  |  |  |
| 1     | "INTSR6" occurs in case of error (at this time, INTSRE6 does not occur).       |  |  |  |  |  |

- **Note** If "reception as 0 parity" is selected, the parity is not judged. Therefore, bit 2 (PE6) of asynchronous serial interface status register 6 (ASIS6) is not set and the error interrupt does not occur.
- Cautions 1. At startup, set POWER6 to 1 and then set RXE6 to 1. Clear RXE6 to 0 first, and then clear POWER6 to 0.
  - 2. Clear the TXE6 and RXE6 bits to 0 before rewriting the PS61, PS60, and CL6 bits.
  - 3. Fix the PS61 and PS60 bits to 0 when mounting the device on LIN.
  - 4. Make sure that TXE6 = 0 when rewriting the SL6 bit. Reception is always performed with "the number of stop bits = 1", and therefore, is not affected by the set value of the SL6 bit.
  - 5. Make sure that RXE6 = 0 when rewriting the ISRM6 bit.

## (2) Asynchronous serial interface reception error status register 6 (ASIS6)

This register indicates an error status on completion of reception by serial interface UART6. It includes three error flag bits (PE6, FE6, OVE6).

This register can be set by an 8-bit memory manipulation instruction and is read-only.

RESET input clears this register to 00H if bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 0. 00H is read when this register is read.

#### Figure 15-6. Format of Asynchronous Serial Interface Reception Error Status Register 6 (ASIS6)

Address: FF53H After reset: 00H R

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|--------|---|---|---|---|---|-----|-----|------|
| ASIS6  | 0 | 0 | 0 | 0 | 0 | PE6 | FE6 | OVE6 |

| PE6 | Status flag indicating parity error                                                     |
|-----|-----------------------------------------------------------------------------------------|
| 0   | If POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read                                |
| 1   | If the parity of transmit data does not match the parity bit on completion of reception |

| FE6 | Status flag indicating framing error                       |  |  |  |  |  |  |  |
|-----|------------------------------------------------------------|--|--|--|--|--|--|--|
| 0   | POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read      |  |  |  |  |  |  |  |
| 1   | If the stop bit is not detected on completion of reception |  |  |  |  |  |  |  |

| OVE6 | Status flag indicating overrun error                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------|
| 0    | If POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read                                                          |
| 1    | If receive data is set to the RXB register and the next reception operation is completed before the data is read. |

- Cautions 1. The operation of the PE6 bit differs depending on the set values of the PS61 and PS60 bits of asynchronous serial interface mode register 6 (ASIM6).
  - 2. The first bit of the receive data is checked as the stop bit, regardless of the number of stop bits.
  - 3. If an overrun error occurs, the next receive data is not written to receive buffer register 6 (RXB6) but discarded.
  - 4. If data is read from ASIS6, a wait cycle is generated. Do not read data from ASIS6 when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

## (3) Asynchronous serial interface transmission status register 6 (ASIF6)

This register indicates the status of transmission by serial interface UART6. It includes two status flag bits (TXBF6 and TXSF6).

Transmission can be continued without disruption even during an interrupt period, by writing the next data to the TXB6 register after data has been transferred from the TXB6 register to the TXS6 register.

This register can be set by an 8-bit memory manipulation instruction, and is read-only.

RESET input clears this register to 00H if bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 0.

## Figure 15-7. Format of Asynchronous Serial Interface Transmission Status Register 6 (ASIF6)

Address: FF55H After reset: 00H R

| 0 | у  |   |    | v | 0 |
|---|----|---|----|---|---|
| A | 19 | s | 11 | F | 6 |

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|--------|---|---|---|---|---|---|-------|-------|
| ASIF6  | 0 | 0 | 0 | 0 | 0 | 0 | TXBF6 | TXSF6 |

| TXBF6 | Transmit buffer data flag                                                                |
|-------|------------------------------------------------------------------------------------------|
| 0     | If POWER6 = 0 or TXE6 = 0, or if data is transferred to transmit shift register 6 (TXS6) |
| 1     | If data is written to transmit buffer register 6 (TXB6) (if data exists in TXB6)         |

| TXSF6 | Transmit shift register data flag                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0     | If POWER6 = 0 or TXE6 = 0, or if the next data is not transferred from transmit buffer register 6 (TXB6) after completion of transfer |
| 1     | If data is transferred from transmit buffer register 6 (TXB6) (if data transmission is in progress)                                   |

- Cautions 1. To continuously transmit data, write the data of the first byte to TXB6, check that the value of the TXBF6 flag is 0, and then write the data of the second byte to TXB6. The operation is not guaranteed if data is written to TXB6 while the TXBF6 flag is 1.
  - 2. While continuous transmission is being executed, check the value of the TXSF6 flag after the transmission completion interrupt to determine the subsequent write processing to TXB6.
    - If TXSF6 is 1: Continuous transmission is in progress. Data of 1 byte can be written.
    - If TXSF6 is 0: Continuous transmission is complete. Data of 2 bytes can be written. When doing so, observe Caution 1 above.
  - 3. While continuous transmission is in progress, check that TXSF6 is 0 after the transmission completion interrupt, and then execute clearing (POWER6 = 0 or TXE6 = 0). If clearing is executed while the TXSF6 flag is 1, the transmit data cannot be guaranteed.

## (4) Clock selection register 6 (CKSR6)

This register selects the base clock of serial interface UART6. CKSR6 can be set by an 8-bit memory manipulation instruction. RESET input clears this register to 00H.

**Remark** CKSR6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

Figure 15-8. Format of Clock Selection Register 6 (CKSR6)

Address: FF56H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|--------|---|---|---|---|-------|-------|-------|-------|
| CKSR6  | 0 | 0 | 0 | 0 | TPS63 | TPS62 | TPS61 | TPS60 |

| TPS63 | TPS62 | TPS61 | TPS60 | Base clock (fxcLK)             |
|-------|-------|-------|-------|--------------------------------|
| 0     | 0     | 0     | 0     | fx (10 MHz)                    |
| 0     | 0     | 0     | 1     | fx/2 (5 MHz)                   |
| 0     | 0     | 1     | 0     | fx/2² (2.5 MHz)                |
| 0     | 0     | 1     | 1     | fx/2³ (1.25 MHz)               |
| 0     | 1     | 0     | 0     | fx/2⁴ (625 kHz)                |
| 0     | 1     | 0     | 1     | fx/2⁵ (312.5 kHz)              |
| 0     | 1     | 1     | 0     | fx/2 <sup>6</sup> (156.25 kHz) |
| 0     | 1     | 1     | 1     | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1     | 0     | 0     | 0     | fx/2 <sup>8</sup> (39.06 kHz)  |
| 1     | 0     | 0     | 1     | fx/2° (19.53 kHz)              |
| 1     | 0     | 1     | 0     | fx/2 <sup>10</sup> (9.77 kHz)  |
| 1     | 0     | 1     | 1     | TM50 output (TO50)             |
|       | Ot    | her   |       | Setting prohibited             |

#### Caution Make sure POWER6 = 0 when rewriting TPS63 to TPS60.

**Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz

2. fx: X1 input clock oscillation frequency

#### (5) Baud rate generator control register 6 (BRGC6)

This register selects the base clock of serial interface UART6. BRGC6 can be set by an 8-bit memory manipulation instruction. RESET input sets this register to FFH.

#### Figure 15-9. Format of Baud Rate Generator Control Register 6 (BRGC6)

Address: FF57H After reset: FFH R/W

| Symbol | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| BRGC6  | MDL67 | MDL66 | MDL65 | MDL64 | MDL63 | MDL62 | MDL61 | MDL60 |

| MDL67 | MDL66 | MDL65 | MDL64 | MDL63 | MDL62 | MDL61 | MDL60 | k   | Output clock selection of<br>8-bit counter |
|-------|-------|-------|-------|-------|-------|-------|-------|-----|--------------------------------------------|
| 0     | 0     | 0     | 0     | 0     | ×     | ×     | ×     | ×   | Setting prohibited                         |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 8   | fxclk/8                                    |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 9   | fxclk/9                                    |
| 0     | 0     | 0     | 0     | 1     | 0     | 1     | 0     | 10  | fxclk/10                                   |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 0     | 252 | fxclk/252                                  |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 1     | 253 | fxclk/253                                  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0     | 254 | fxclк/254                                  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 255 | fxclk/255                                  |

- Cautions 1. Make sure that bit 6 (TXE6) and bit 5 (RXE6) of the ASIM6 register = 0 when rewriting the MDL67 to MDL60 bits.
  - 2. The baud rate is the output clock of the 8-bit counter divided by 2.

Remarks 1. fxcLk: Frequency of base clock (Clock) selected by the TPS63 to TPS60 bits of CKSR6 register

- 2. k: Value set by MDL67 to MDL60 bits (k = 8, 9, 10, ..., 255)
- 3. ×: Don't care

**Remark** BRGC6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

## (6) Asynchronous serial interface control register 6 (ASICL6)

This register controls the serial transfer operations of serial interface UART6. ASICL6 can be set by a 1-bit transfer instruction or an 8-bit memory manipulation instruction. RESET input sets this register to16H.

Remark ASICL6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1). However, transfer is started by refresh because bit 6 (SBRT6) and bit 5 (SBTT6) of ASICL6 are cleared to 0 when communication is complete (when an interrupt signal is generated).

#### Figure 15-10. Format of Asynchronous Serial Interface Control Register 6 (ASICL6) (1/2)

Address: FF58H After reset: 16H R/W

7 Symbol 6 5 4 3 2 1 0 SBL60 ASICL6 SBRF6 SBRT6 SBTT6 SBL62 SBL61 DIR6 TXDLV6

| SBRF6 | SBF reception status flag                                                   |
|-------|-----------------------------------------------------------------------------|
| 0     | If POWER6 = 0 and RXE6 = 0 or if SBF reception has been completed correctly |
| 1     | SBF reception in progress                                                   |

| SBRT6 | SBF reception trigger |
|-------|-----------------------|
| 0     | _                     |
| 1     | SBF reception trigger |

| SBTT6 | SBF transmission trigger |
|-------|--------------------------|
| 0     | _                        |
| 1     | SBF transmission trigger |

Cautions 1. In the case of an SBF reception error, return the mode to the SBF reception mode and hold the status of the SBRF6 flag.

- 2. Before setting the SBRT6 bit, make sure that bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1.
- 3. The read value of the SBRT6 bit is always 0. SBRT6 is automatically cleared to 0 after SBF reception has been correctly completed.
- 4. Before setting the SBTT6 bit to 1, make sure that bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1.
- 5. The read value of the SBTT6 bit is always 0. SBTT6 is automatically cleared to 0 at the end of SBF transmission.

| SBL62 | SBL61 | SBL60 | SBF transmission output width control |  |
|-------|-------|-------|---------------------------------------|--|
| 1     | 0     | 1     | SBF is output with 13-bits length.    |  |
| 1     | 1     | 0     | SBF is output with 14-bits length.    |  |
| 1     | 1     | 1     | SBF is output with 15-bits length.    |  |
| 0     | 0     | 0     | SBF is output with 16-bits length.    |  |
| 0     | 0     | 1     | SBF is output with 17-bits length.    |  |
| 0     | 1     | 0     | SBF is output with 18-bits length.    |  |
| 0     | 1     | 1     | SBF is output with 19-bits length.    |  |
| 1     | 0     | 0     | SBF is output with 20-bits length.    |  |

## Figure 15-10. Format of Asynchronous Serial Interface Control Register 6 (ASICL6) (2/2)

| DIR6 | MSB/LSB-first transfer |
|------|------------------------|
| 0    | MSB-first transfer     |
| 1    | LSB-first transfer     |

| TXDLV6 | Enables/disables inverting TxD6 output |
|--------|----------------------------------------|
| 0      | Normal output of TxD6                  |
| 1      | Inverted output of TxD6                |

Caution Before rewriting the DIR6 and TXDLV6 bits, clear the TXE6 and RXE6 bits to 0.

## 15.4 Operation of Serial Interface UART6

This section explains the two modes of serial interface UART6.

#### 15.4.1 Operation stop mode

In this mode, serial transfer cannot be executed; therefore, the power consumption can be reduced. In addition, the pins can be used as ordinary port pins in this mode.

#### (1) Register setting

The operation stop mode is set by asynchronous serial interface operation mode register 6 (ASIM6). ASIM6 can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

**Remark** ASIM6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

Address: FF50H After reset: 01H R/W



| POWER6              | Enables/disables operation of internal operation clock                                                                         |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------|--|
| 0 <sup>Note 1</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronou resets the internal circuit. |  |
| 1 <sup>Note 2</sup> | Enables operation of the internal operation clock.                                                                             |  |

| TXE6 | Enables/disables transmission                                                    |
|------|----------------------------------------------------------------------------------|
| 0    | Disables transmission operation (synchronously resets the transmission circuit). |
| 1    | Enables transmission                                                             |

| RXE6 | Enables/disables reception                                       |
|------|------------------------------------------------------------------|
| 0    | Disables reception (synchronously resets the reception circuit). |
| 1    | Enables reception                                                |

- **Notes 1.** The output of the TxD6 pin goes high and the input from the RxD6 pin is fixed to the high level when POWER6 = 0.
  - 2. Operation of the internal operation clock is enabled at the second input clock after 1 is written to the POWER6 bit.
- Cautions 1. At startup, set POWER6 to 1 and then set TXE6 to 1. Clear TXE6 to 0 first, and then clear POWER6 to 0.
  - 2. At startup, set POWER6 to 1 and then set RXE6 to 1. Clear RXE6 to 0 first, and then clear POWER6 to 0.

## 15.4.2 Asynchronous serial interface (UART) mode

In this mode, data of 1 byte is transmitted/received following a start bit, and a full-duplex operation can be performed.

A dedicated UART baud rate generator is incorporated, so that communication can be executed at a wide range of baud rates.

## (1) Register setting

The UART mode is set by asynchronous serial interface operation mode register 6 (ASIM6), asynchronous serial interface reception error status register 6 (ASIS6), asynchronous serial interface transmission status register 6 (ASIF6), clock selection register 6 (CKSR6), baud rate generator control register 6 (BRGC6), and asynchronous serial interface control register 6 (ASIC6).

## (a) Asynchronous serial interface operation mode register 6 (ASIM6)

This 8-bit register controls the serial transfer operations of serial interface UART6. ASIM6 can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 01H.

**Remark** ASIM6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

#### Address: FF50H After reset: 01H R/W

| Symbol | 7      | 6    | 5    | 4    | 3    | 2   | 1   | 0     |
|--------|--------|------|------|------|------|-----|-----|-------|
| ASIM6  | POWER6 | TXE6 | RXE6 | PS61 | PS60 | CL6 | SL6 | ISRM6 |

| POWER6              | Enables/disables operation of internal operation clock                                                                            |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| 0 <sup>Note 1</sup> | Disables operation of the internal operation clock (fixes the clock to low level) and asynchronously resets the internal circuit. |  |
| 1 <sup>Note 2</sup> | Enables operation of the internal operation clock.                                                                                |  |

| TXE6 | Enables/disables transmission                                          |
|------|------------------------------------------------------------------------|
| 0    | Disables transmission (synchronously resets the transmission circuit). |
| 1    | Enables transmission                                                   |

- **Notes 1.** The output of the TxD6 pin goes high and the input from the RxD6 pin is fixed to the high level when POWER6 = 0.
  - 2. Operation of the internal operation clock is enabled at the second input clock after 1 is written to the POWER6 bit.
- Caution At startup, set POWER6 to 1 and then set TXE6 to 1. Clear TXE6 to 0 first, and then clear POWER6 to 0.

| RXE6 | Enables/disables reception                                       |
|------|------------------------------------------------------------------|
| 0    | Disables reception (synchronously resets the reception circuit). |
| 1    | Enables reception                                                |

| PS61 | PS60 | Transmission operation      | Reception operation                   |
|------|------|-----------------------------|---------------------------------------|
| 0    | 0    | Does not output parity bit. | Reception without parity              |
| 0    | 1    | Outputs 0 parity.           | Reception as 0 parity <sup>Note</sup> |
| 1    | 0    | Outputs odd parity.         | Judges as odd parity.                 |
| 1    | 1    | Outputs even parity.        | Judges as even parity.                |

| CL6 | Specifies character length of transmit/receive data |  |  |  |  |  |
|-----|-----------------------------------------------------|--|--|--|--|--|
| 0   | Character length of data = 7 bits                   |  |  |  |  |  |
| 1   | Character length of data = 8 bits                   |  |  |  |  |  |

| SL6 | Specifies number of stop bits of transmit data |  |  |  |  |  |
|-----|------------------------------------------------|--|--|--|--|--|
| 0   | Number of stop bits = 1                        |  |  |  |  |  |
| 1   | Number of stop bits = 2                        |  |  |  |  |  |

| ISRM6 | Enables/disables occurrence of reception completion interrupt in case of error |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | "INTSRE6" occurs in case of error (at this time, INTSR6 does not occur).       |  |  |  |  |  |
| 1     | "INTSR6" occurs in case of error (at this time, INTSRE6 does not occur).       |  |  |  |  |  |

- **Note** If "reception as 0 parity" is selected, the parity is not judged. Therefore, bit 2 (PE6) of asynchronous serial interface status register 6 (ASIS6) is not set and the error interrupt does not occur.
- Cautions 1. At startup, set POWER6 to 1 and then set RXE6 to 1. Clear RXE6 to 0 first, and then clear POWER6 to 0.
  - 2. Clear the TXE6 and RXE6 bits to 0 before rewriting the PS61, PS60, and CL6 bits.
  - 3. Fix the PS61 and PS60 bits to 0 when mounting the device on LIN.
  - 4. Make sure that TXE6 = 0 when rewriting the SL6 bit. Reception is always performed with "the number of stop bits = 1", and therefore, is not affected by the set value of the SL6 bit.
  - 5. Make sure that RXE6 = 0 when rewriting the ISRM6 bit.

## (b) Asynchronous serial interface reception error status register 6 (ASIS6)

This register indicates an error status on completion of reception by serial interface UART6. It includes three error flag bits (PE6, FE6, OVE6).

This register can be set by an 8-bit memory manipulation instruction and is read-only.

RESET input clears this register to 00H if bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 0. 00H is read when this register is read.

Address: FF53H After reset: 00H R

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|--------|---|---|---|---|---|-----|-----|------|
| ASIS6  | 0 | 0 | 0 | 0 | 0 | PE6 | FE6 | OVE6 |

| PE6 | Status flag indicating parity error                                                     |  |  |  |  |  |  |
|-----|-----------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0   | If POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read                                |  |  |  |  |  |  |
| 1   | If the parity of transmit data does not match the parity bit on completion of reception |  |  |  |  |  |  |

| FE6 | Status flag indicating framing error                       |  |  |  |  |  |
|-----|------------------------------------------------------------|--|--|--|--|--|
| 0   | If POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read   |  |  |  |  |  |
| 1   | If the stop bit is not detected on completion of reception |  |  |  |  |  |

| OVE6 | Status flag indicating overrun error                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------|
| 0    | If POWER6 = 0 and RXE6 = 0, or if ASIS6 register is read                                                          |
| 1    | If receive data is set to the RXB register and the next reception operation is completed before the data is read. |

- Cautions 1. The operation of the PE6 bit differs depending on the set values of the PS61 and PS60 bits of asynchronous serial interface mode register 6 (ASIM6).
  - 2. The first bit of the receive data is checked as the stop bit, regardless of the number of stop bits.
  - 3. If an overrun error occurs, the next receive data is not written to receive buffer register 6 (RXB6) but discarded.
  - 4. If data is read from ASIS6, a wait cycle is generated. Do not read data from ASIS6 when the CPU is operating on the subsystem clock and the X1 input clock is stopped. For details, refer to CHAPTER 32 CAUTIONS FOR WAIT.

## (c) Asynchronous serial interface transmission status register 6 (ASIF6)

This register indicates the status of transmission by serial interface UART6. It includes two status flag bits (TXBF6 and TXSF6).

Transmission can be continued without disruption even during an interrupt period, by writing the next data to the TXB6 register after data has been transferred from the TXB6 register to the TXS6 register.

This register can be set by an 8-bit memory manipulation instruction, and is read-only.

RESET input clears this register to 00H if bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 0.

Address: FF55H After reset: 00H R

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|--------|---|---|---|---|---|---|-------|-------|
| ASIF6  | 0 | 0 | 0 | 0 | 0 | 0 | TXBF6 | TXSF6 |

| TXBF6 | Transmit buffer data flag                                                                |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | If POWER6 = 0 or TXE6 = 0, or if data is transferred to transmit shift register 6 (TXS6) |  |  |  |  |  |
| 1     | If data is written to transmit buffer register 6 (TXB6) (if data exists in TXB6)         |  |  |  |  |  |

| TXSF6 | Transmit shift register data flag                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0     | If POWER6 = 0 or TXE6 = 0, or if the next data is not transferred from transmit buffer register 6 (TXB6) after completion of transfer |
| 1     | If data is transferred from transmit buffer register 6 (TXB6) (if data transmission is in progress)                                   |

- Cautions 1. To continuously transmit data, write the data of the first byte to TXB6, check that the value of the TXBF6 flag is 0, and then write the data of the second byte to TXB6. The operation is not guaranteed if data is written to TXB6 while the TXBF6 flag is 1.
  - 2. While continuous transmission is being executed, check the value of the TXSF6 flag after the transmission completion interrupt to determine the subsequent write processing to TXB6.
    - If TXSF6 is 1: Continuous transmission is in progress. Data of 1 byte can be written.
    - If TXSF6 is 0: Continuous transmission is complete. Data of 2 bytes can be written. When doing so, observe Caution 1 above.
  - 3. While continuous transmission is in progress, check that TXSF6 is 0 after the transmission completion interrupt, and then execute clearing (POWER6 = 0 or TXE6 = 0). If clearing is executed while the TXSF6 flag is 1, the transmit data cannot be guaranteed.

## (d) Asynchronous serial interface control register 6 (ASICL6)

This register controls the serial transfer operations of serial interface UART6. ASICL6 can be set by a 1-bit transfer instruction or an 8-bit memory manipulation instruction. RESET input sets this register to16H.

**Remark** ASICL6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1). However, transfer is started by refresh because bit 6 (SBRT6) and bit 5 (SBTT6) of ASICL6 are cleared to 0 when communication is complete (when an interrupt signal is generated).

#### Address: FF58H After reset: 16H R/W

| Symbol | 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0      |
|--------|-------|-------|-------|-------|-------|-------|------|--------|
| ASICL6 | SBRF6 | SBRT6 | SBTT6 | SBL62 | SBL61 | SBL60 | DIR6 | TXDLV6 |

| SBRF6 | SBF reception status flag                                                   |
|-------|-----------------------------------------------------------------------------|
| 0     | If POWER6 = 0 and RXE6 = 0 or if SBF reception has been completed correctly |
| 1     | SBF reception in progress                                                   |

| SBRT6 | SBF reception trigger |
|-------|-----------------------|
| 0     | _                     |
| 1     | SBF reception trigger |

| SBTT6 | SBF transmission trigger |
|-------|--------------------------|
| 0     | _                        |
| 1     | SBF transmission trigger |

- Cautions 1. In the case of an SBF reception error, return the mode to the SBF reception mode and hold the status of the SBRF6 flag.
  - 2. Before setting the SBRT6 bit, make sure that bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1.
  - 3. The read value of the SBRT6 bit is always 0. SBRT6 is automatically cleared to 0 after SBF reception has been correctly completed.
  - 4. Before setting the SBTT6 bit to 1, make sure that bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1.
  - 5. The read value of the SBTT6 bit is always 0. SBTT6 is automatically cleared to 0 at the end of SBF transmission.

| SBL62 | SBL61 | SBL60 | SBF transmission output width control |
|-------|-------|-------|---------------------------------------|
| 1     | 0     | 1     | SBF is output with 13-bit length.     |
| 1     | 1     | 0     | SBF is output with 14-bit length.     |
| 1     | 1     | 1     | SBF is output with 15-bit length.     |
| 0     | 0     | 0     | SBF is output with 16-bit length.     |
| 0     | 0     | 1     | SBF is output with 17-bit length.     |
| 0     | 1     | 0     | SBF is output with 18-bit length.     |
| 0     | 1     | 1     | SBF is output with 19-bit length.     |
| 1     | 0     | 0     | SBF is output with 20-bit length.     |

| DIR6 | MSB/LSB-first transfer |  |  |  |  |  |  |
|------|------------------------|--|--|--|--|--|--|
| 0    | MSB-first transfer     |  |  |  |  |  |  |
| 1    | LSB-first transfer     |  |  |  |  |  |  |

| TXDLV6 | Enables/disables inverting TxD6 output |  |  |  |  |  |  |  |
|--------|----------------------------------------|--|--|--|--|--|--|--|
| 0      | Normal output of TxD6                  |  |  |  |  |  |  |  |
| 1      | Inverted output of TxD6                |  |  |  |  |  |  |  |

Caution Before rewriting the DIR6 and TXDLV6 bits, clear the TXE6 and RXE6 bits to 0.

## (2) Communication operation

## (a) Normal transmit/receive data format

Figure 15-11 shows the format of the transmit/receive data.

## Figure 15-11. Format of Normal UART Transmit/Receive Data

## 1. LSB-first transmission/reception



## 2. MSB-first transmission/reception



One data frame consists of the following bits.

- Start bit ... 1 bit
- Character bits ... 7 or 8 bits
- Parity bit ... Even parity, odd parity, 0 parity, or no parity
- Stop bit ... 1 or 2 bits

The character bit length, parity, and stop bit length in one data frame are specified by asynchronous serial interface mode register 6 (ASIM6).

Whether data is transferred with the LSB or MSB first is specified by bit 1 (DIR6) of asynchronous serial interface control register 6 (ASICL6).

Whether the TxD6 pin outputs normal or inverted data is specified by bit 0 (TXDLV6) of ASICL6.

#### Figure 15-12. Example of Normal UART Transmit/Receive Data Format

## 1. Data length: 8 bits, LSB first, Parity: Even parity, Stop bit: 1 bit, Transfer data: 55H



## 2. Data length: 8 bits, MSB first, Parity: Even parity, Stop bit: 1 bit, Transfer data: 55H



3. Data length: 8 bits, MSB first, Parity: Even parity, Stop bit: 1 bit, Transfer data: 55H, TxD6 pin inverted output

| ◄ 1 data frame → |    |    |    |    |    |    |    |    |        |      |  |  |
|------------------|----|----|----|----|----|----|----|----|--------|------|--|--|
| Start            | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Parity | Stop |  |  |

## 4. Data length: 7 bits, LSB first, Parity: Odd parity, Stop bit: 2 bits, Transfer data: 36H

|       | 1 data frame |    |    |    |    |    |    |        |      |      |  |  |  |
|-------|--------------|----|----|----|----|----|----|--------|------|------|--|--|--|
| Start | D0           | D1 | D2 | D3 | D4 | D5 | D6 | Parity | Stop | Stop |  |  |  |

#### 5. Data length: 8 bits, LSB first, Parity: None, Stop bit: 1 bit, Transfer data: 87H

| -   | ▪ 1 data frame |    |    |    |    |    |    |    |    |      |  |  |  |
|-----|----------------|----|----|----|----|----|----|----|----|------|--|--|--|
| Sta | art            | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | Stop |  |  |  |

# (b) Parity types and operation

The parity bit is used to detect a bit error in communication data. Usually, the same type of parity bit is used on both the transmission and reception sides. With even parity and odd parity, a 1-bit (odd number) error can be detected. With zero parity and no parity, an error cannot be detected.

## Caution Fix the PS61 and PS60 bits to 0 when the device is incorporated in LIN.

- (i) Even parity
  - Transmission

Transmit data, including the parity bit, is controlled so that the number of bits that are "1" is even. The value of the parity bit is as follows.

If transmit data has an odd number of bits that are "1": 1 If transmit data has an even number of bits that are "1": 0

Reception

The number of bits that are "1" in the receive data, including the parity bit, is counted. If it is odd, a parity error occurs.

# (ii) Odd parity

Transmission

Unlike even parity, transmit data, including the parity bit, is controlled so that the number of bits that are "1" is odd.

If transmit data has an odd number of bits that are "1": 0 If transmit data has an even number of bits that are "1": 1

Reception

The number of bits that are "1" in the receive data, including the parity bit, is counted. If it is even, a parity error occurs.

(iii) 0 parity

The parity bit is cleared to 0 when data is transmitted, regardless of the transmit data.

The parity bit is not detected when the data is received. Therefore, a parity error does not occur regardless of whether the parity bit is "0" or "1".

(iv) No parity

No parity bit is appended to the transmit data.

Reception is performed assuming that there is no parity bit when data is received. Because there is no parity bit, a parity error does not occur.

# (c) Normal transmission

The TxD6 pin outputs a high level when bit 7 (POWER6) of asynchronous serial interface mode register 6 (ASIM6) is set to 1. If bit 6 (TXE6) of ASIM6 is then set to 1, transmission is enabled. Transmission can be started by writing transmit data to transmit buffer register 6 (TXB6). The start bit, parity bit, and stop bit are automatically appended to the data.

When transmission is started, the data in TXB6 is transferred to transmit shift register 6 (TXS6). After that, the data is sequentially output from TXS6 to the TxD6 pin, starting from the LSB. When transmission is completed, a transmission completion interrupt request (INTST6) is generated.

Transmission is stopped until the data to be transmitted next is written to TXB6.

Figure 15-13 shows the timing of the transmission completion interrupt request (INTST6). This interrupt occurs as soon as the last stop bit has been output.

#### Figure 15-13. Normal Transmission Completion Interrupt Request Timing

#### 1. Stop bit length: 1



# 2. Stop bit length: 2



# (d) Continuous transmission

When transmit shift register 6 (TXS6) has started the shift operation, the next transmit data can be written to transmit buffer register 6 (TXB6). As a result, data can be transmitted without intermission even while an interrupt that has occurred after transmission of one data frame is being serviced, thus realizing an efficient communication rate. To transmit data continuously, however, transmission processing must be executed while referencing bits 1 (TXBF6) and 0 (TXSF6) of asynchronous serial interface transmission status register 6 (ASIF6).

Caution When the device is incorporated in LIN, the continuous transmission function cannot be used. Make sure that asynchronous serial interface transmission status register 6 (ASIF6) is 00H before writing transmit data to transmit buffer register 6 (TXB6).

| TXBF6 | TXSF6 | Write Processing During Execution of<br>Continuous Transmission  | Writing to TXB6 During Execution of<br>Continuous Transmission |
|-------|-------|------------------------------------------------------------------|----------------------------------------------------------------|
| 0     | 0     | Enables writing 2 bytes or<br>transmission completion processing | Enables writing                                                |
| 0     | 1     | Enables writing 1 byte                                           | Enables writing                                                |
| 1     | 0     | Enables writing 2 bytes or<br>transmission completion processing | Disables writing                                               |
| 1     | 1     | Enables writing 1 byte                                           | Disables writing                                               |

#### Table 15-2. Write Processing and Writing to TXB6 During Execution of Continuous Transmission

- Cautions 1. To continuously transmit data, write the data of the first byte to TXB6, check that the value of the TXBF6 flag is 0, and then write the data of the second byte to TXB6. The operation is not guaranteed if data is written to TXB6 while the TXBF6 flag is 1.
  - 2. While continuous transmission is being executed, check the value of the TXSF6 flag after the transmission completion interrupt to determine the subsequent write processing to TXB6.
    - If TXSF6 is 1: Continuous transmission is in progress. Data of 1 byte can be written.
    - If TXSF6 is 0: Continuous transmission is completed. Data of 2 bytes can be written. To do so, observe Caution 1 above.
  - While continuous transmission is in progress, check that TXSF6 is 0 after the transmission completion interrupt, and then execute clearing (POWER6 = 0 or TXE6 = 0). If clearing is executed while the TXSF6 flag is 1, the transmit data cannot be guaranteed.

Figure 15-14 shows the processing flow of continuous transmission.





Remark TXB6: Transmit buffer register 6

ASIF6: Asynchronous serial interface transmission status register 6

TXBF6: Bit 1 of ASIF6 (transmit buffer data flag)

TXSF6: Bit 0 of ASIF6 (transmit shift register data flag)

Figure 15-15 shows the timing of starting continuous transmission, and Figure 15-16 shows the timing of ending continuous transmission.



Figure 15-15. Timing of Starting Continuous Transmission

**Note** When ASIF6 is read, there is a period in which TXBF6 and TXSF6 = 1, 1. Therefore, judge whether writing is enabled using only the TXBF6 bit.

**Remark** TxD6: TxD6 pin (output)

- INTST6: Interrupt request signal
- TXB6: Transmit buffer register 6
- TXS6: Transmit shift register 6
- ASIF6: Asynchronous serial interface transmission status register 6
- TXBF6: Bit 1 of ASIF6
- TXSF6: Bit 0 of ASIF6



# Figure 15-16. Timing of Ending Continuous Transmission

| nark | TxD6:   | TxD6 pin (output)                                            |
|------|---------|--------------------------------------------------------------|
|      | INTST6: | Interrupt request signal                                     |
|      | TXB6:   | Transmit buffer register 6                                   |
|      | TXS6:   | Transmit shift register 6                                    |
|      | ASIF6:  | Asynchronous serial interface transmission status register 6 |
|      | TXBF6:  | Bit 1 of ASIF6                                               |
|      | TXSF6:  | Bit 0 of ASIF6                                               |
|      | POWER6: | Bit 7 of asynchronous serial interface mode register (ASIM6) |
|      | TXE6:   | Bit 6 of asynchronous serial interface mode register (ASIM6) |
|      |         |                                                              |

# (e) Normal reception

Reception is enabled and the RxD6 pin input is sampled when bit 7 (POWER6) of asynchronous serial interface mode register 6 (ASIM6) is set to 1 and then bit 5 (RXE6) of ASIM6 is set to 1.

The 8-bit counter of the baud rate generator starts counting when the falling edge of the RxD6 pin input is detected. When the set value of baud rate generator control register 6 (BRGC6) has been counted, the RxD6 pin input is sampled again ( $\bigtriangledown$  in Figure 15-17). If the RxD6 pin is low level at this time, it is recognized as a start bit.

When the start bit is detected, reception is started, and serial data is sequentially stored in the receive shift register (RXS6) at the set baud rate. When the stop bit has been received, the reception completion interrupt (INTSR6) is generated and the data of RXS6 is written to receive buffer register 6 (RXB6). If an overrun error (OVE6) occurs, however, the receive data is not written to RXB6.

Even if a parity error (PE6) or a framing error (FE6) occurs while reception is in progress, reception continues to the reception position of the stop bit, and an error interrupt (INTSR6/INTSRE6) is generated on completion of reception.





- Cautions 1. Be sure to read receive buffer register 6 (RXB6) even if a reception error occurs. Otherwise, an overrun error will occur when the next data is received, and the reception error status will persist.
  - 2. Reception is always performed with the "number of stop bits = 1". The second stop bit is ignored.
  - 3. Be sure to read asynchronous serial interface reception error status register 6 (ASIS6) before reading RXB6.

## (f) Reception error

Three types of errors may occur during reception: a parity error, framing error, or overrun error. If the error flag of asynchronous serial interface reception error status register 6 (ASIS6) is set as a result of data reception, a reception error interrupt request (INTSR6/INTSRE6) is generated.

Which error has occurred during reception can be identified by reading the contents of ASIS6 in the reception error interrupt servicing (INTSR6/INTSRE6) (refer to **Table 15-3**).

The contents of ASIS6 are reset to 0 when ASIS6 is read.

| Table 15-3. | Cause of Reception Error |
|-------------|--------------------------|
|-------------|--------------------------|

| Reception Error | Cause                                                                                              | Value of ASIS6 |
|-----------------|----------------------------------------------------------------------------------------------------|----------------|
| Parity error    | The parity specified for transmission does not match the parity of the receive data.               | 04H            |
| Framing error   | Stop bit is not detected.                                                                          | 02H            |
| Overrun error   | Reception of the next data is completed before data is read from receive buffer register 6 (RXB6). | 01H            |

The error interrupt can be separated into INTSR6 and INTSRE6 by clearing bit 0 (ISRM6) of asynchronous serial interface mode register 6 (ASIM6) to 0.

# Figure 15-18. Reception Error Interrupt

#### 1. If ISRM6 is cleared to 0 (INTSR6 and INTSRE6 are separated)

| (a) No      | error during reception            | (b) Error during reception |                        |  |  |  |  |  |
|-------------|-----------------------------------|----------------------------|------------------------|--|--|--|--|--|
| INTSR6      |                                   | INTSR6                     |                        |  |  |  |  |  |
| INTSRE6     |                                   | INTSRE6                    |                        |  |  |  |  |  |
| 2. If ISRM6 | is set to 1 (error interrupt is i | ncluded in INTSR6)         |                        |  |  |  |  |  |
| (a) No      | error during reception            | (b)                        | Error during reception |  |  |  |  |  |
| INTSR6      |                                   | INTSR6                     |                        |  |  |  |  |  |
| INTSRE6     |                                   | INTSRE6                    |                        |  |  |  |  |  |

# (g) Noise filter of receive data

The RXD6 signal is sampled with the base clock output by the prescaler block.

If two sampled values are the same, the output of the match detector changes, and the data is sampled as input data.

Because the circuit is configured as shown in Figure 15-19, the internal processing of the reception operation is delayed by two clocks from the external signal status.





#### (h) SBF transmission

When the device is incorporated in LIN, the SBF (Synchronous Break Field) transmission control function is used for transmission. For the transmission operation of LIN, refer to **Figure 15-1 LIN Transmission Operation**.

The TxD6 pin outputs a high level when bit 7 (POWER6) of asynchronous serial interface mode register 6 (ASIM6) is set to 1. Transmission is enabled when bit 6 (TXE6) of ASIM6 is set to 1 next time, and SBF transmission operation is started when bit 5 (SBTT6) of asynchronous serial interface control register 6 (ASICL6) is set to 1.

After transmission has been started, the low levels of bits 13 to 20 (set by bits 4 to 2 (SBL62 to SBL60) of ASICL6) are output. When SBF transmission has been completed, a transmission completion interrupt request (INTST6) is generated, and SBTT6 is automatically cleared. After SBF transmission has been completed, the normal transmission mode is restored.

Transmission is stopped until the data to be transmitted next is written to transmit buffer register 6 (TXB6) or SBTT6 is set to 1.





Remark TxD6: TxD6 pin (output)

INTST6: Transmission completion interrupt request

SBTT6: Bit 5 of asynchronous serial interface control register 6 (ASICL6)

## (i) SBF reception

status.

When the device is incorporated in LIN, the SBF (Synchronous Break Field) reception control function is used for reception. For the reception operation of LIN, refer to **Figure 15-2 LIN Reception Operation**. Reception is enabled when bit 7 (POWER6) of asynchronous serial interface mode register 6 (ASIM6) is set to 1 and then bit 5 (RXE6) of ASIM6 is set to 1. SBF reception is enabled when bit 6 (SBRT6) of asynchronous serial interface control register 6 (ASICL6) is set to 1. In the SBF reception enabled status, the RxD6 pin is sampled and the start bit is detected in the same manner as the normal reception enable

When the start bit has been detected, reception is started, and serial data is sequentially stored in the receive shift register 6 (RXS6) at the set baud rate. When the stop bit is received and if the width of SBF is 11 bits or more, a reception completion interrupt request (INTSR6) is generated as normal processing. At this time, the SBRF6 and SBRT6 bits are automatically cleared, and SBF reception ends. Detection of errors, such as OVE6, PE6, and FE6 (bits 0 to 2 of asynchronous serial interface reception error status register 6 (ASIS6)) is suppressed, and error detection processing of UART communication is not performed. In addition, data transfer between receive shift register 6 (RXS6) and receive buffer register 6 (RXB6) is not performed, and the reset value of FFH is retained. If the width of SBF is 10 bits or less, an interrupt does not occur as error processing after the stop bit has been received, and the SBF reception mode is restored. In this case, the SBRF6 and SBRT6 bits are not cleared.

#### Figure 15-21. SBF Reception



# 1. Normal SBF reception (stop bit is detected with a width of more than 10.5 bits)

#### 2. SBF reception error (stop bit is detected with a width of 10.5 bits or less)

| RxD6              | 1 | 1 | 2 | 1 | 3 | 4 | <br>5 | 1 | 6 | <br> <br> | 7 | <br>8 | <br>9 | <br>10 |  |
|-------------------|---|---|---|---|---|---|-------|---|---|-----------|---|-------|-------|--------|--|
|                   |   |   |   |   |   |   |       |   |   |           |   |       |       |        |  |
| SBRT6<br>/SBRF6   |   |   |   |   |   |   |       |   |   |           |   |       |       |        |  |
| INTSR6 <u>"0"</u> |   |   |   |   |   |   |       |   |   |           |   |       |       |        |  |

 Remark
 RxD6:
 RxD6 pin (input)

 SBRT6:
 Bit 6 of asynchronous serial interface control register 6 (ASICL6)

 SBRF6:
 Bit 7 of ASICL6

 INTSR6:
 Reception completion interrupt request

## 15.4.3 Dedicated baud rate generator

The dedicated baud rate generator consists of a source clock selector and an 8-bit programmable counter, and generates a serial clock for transmission/reception of UART6.

Separate 8-bit counters are provided for transmission and reception.

# (1) Configuration of baud rate generator

• Base clock (Clock)

The clock selected by bits 3 to 0 (TPS63 to TPS60) of clock selection register 6 (CKSR6) is supplied to each module when bit 7 (POWER6) of asynchronous serial interface mode register 6 (ASIM6) is 1. This clock is called the base clock (Clock) and its frequency is called  $f_{XCLK}$ . Clock is fixed to the low level when POWER6 = 0.

Transmission counter

This counter stops, cleared to 0, when bit 7 (POWER6) or bit 6 (TXE6) of asynchronous serial interface mode register 6 (ASIM6) is 0.

It starts counting when POWER6 = 1 and TXE6 = 1.

The counter is cleared to 0 when the first data transmitted is written to transmit buffer register 6 (TXB6).

If data are continuously transmitted, the counter is cleared to 0 again when one frame of data has been completely transmitted. If there is no data to be transmitted next, the counter is not cleared to 0 and continues counting until POWER6 or TXE6 is cleared to 0.

Reception counter

This counter stops operation, cleared to 0, when bit 7 (POWER6) or bit 5 (RXE6) of asynchronous serial interface mode register 6 (ASIM6) is 0.

It starts counting when the start bit has been detected.

The counter stops operation after one frame has been received, until the next start bit is detected.





Remark POWER6: Bit 7 of asynchronous serial interface mode register 6 (ASIM6)

- TXE6: Bit 6 of ASIM6
- RXE6: Bit 5 of ASIM6

CKSR6: Clock selection register 6

BRGC6: Baud rate generator control register 6

## (2) Generation of serial clock

A serial clock can be generated by using clock selection register 6 (CKSR6) and baud rate generator control register 6 (BRGC6).

Select the clock to be input to the 8-bit counter by using bits 3 to 0 (TPS63 to TPS60) of CKSR6. Bits 7 to 0 (MDL67 to MDL60) of BRGC6 can be used to select the division value of the 8-bit counter.

# (a) Clock selection register 6 (CKSR6)

This register selects the base clock of serial interface UART6. CKSR6 can be set by an 8-bit memory manipulation instruction. RESET input clears this register to 00H.

Address: FF56H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|--------|---|---|---|---|-------|-------|-------|-------|
| CKSR6  | 0 | 0 | 0 | 0 | TPS63 | TPS62 | TPS61 | TPS60 |

| TPS63 | TPS62 | TPS61 | TPS60 | Base clock (fxclk)             |
|-------|-------|-------|-------|--------------------------------|
| 0     | 0     | 0     | 0     | fx (10 MHz)                    |
| 0     | 0     | 0     | 1     | fx/2 (5 MHz)                   |
| 0     | 0     | 1     | 0     | fx/2 <sup>2</sup> (2.5 MHz)    |
| 0     | 0     | 1     | 1     | fx/2³ (1.25 MHz)               |
| 0     | 1     | 0     | 0     | fx/2⁴ (625 kHz)                |
| 0     | 1     | 0     | 1     | fx/2⁵ (312.5 kHz)              |
| 0     | 1     | 1     | 0     | fx/2 <sup>6</sup> (156.25 kHz) |
| 0     | 1     | 1     | 1     | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1     | 0     | 0     | 0     | fx/2 <sup>s</sup> (39.06 kHz)  |
| 1     | 0     | 0     | 1     | fx/2 <sup>°</sup> (19.53 kHz)  |
| 1     | 0     | 1     | 0     | fx/2 <sup>10</sup> (9.77 kHz)  |
| 1     | 0     | 1     | 1     | TM50 output                    |
|       | Otl   | her   |       | Setting prohibited             |

Caution Make sure POWER6 = 0 when rewriting TPS63 to TPS60.

**Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz

2. fx: X1 input clock oscillation frequency

**Remark** CKSR6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

### (b) Baud rate generator control register 6 (BRGC6)

This register selects the base clock of serial interface UART6. BRGC6 can be set by an 8-bit memory manipulation instruction. RESET input sets this register to FFH.

**Remark** BRGC6 can be refreshed (the same value is written) by software during a communication operation (when bit 7 (POWER6) and bit 6 (TXE6) of ASIM6 = 1 or bit 7 (POWER6) and bit 5 (RXE6) of ASIM6 = 1).

Address: FF57H After reset: FFH R/W

| Symbol | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| BRGC6  | MDL67 | MDL66 | MDL65 | MDL64 | MDL63 | MDL62 | MDL61 | MDL60 |

| MDL67 | MDL66 | MDL65 | MDL64 | MDL63 | MDL62 | MDL61 | MDL60 | k   | Output clock selection of<br>8-bit counter |
|-------|-------|-------|-------|-------|-------|-------|-------|-----|--------------------------------------------|
| 0     | 0     | 0     | 0     | 0     | ×     | ×     | ×     | ×   | Setting prohibited                         |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 8   | fxclk/8                                    |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 9   | fxclk/9                                    |
| 0     | 0     | 0     | 0     | 1     | 0     | 1     | 0     | 10  | fxclk/10                                   |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •                                          |
| •     | •     | •     | •     | •     | •     | •     | •     | ٠   | •                                          |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 0     | 252 | fxclк/ <b>252</b>                          |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 1     | 253 | fxclк/253                                  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0     | 254 | fxclк/254                                  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 255 | fxclк/255                                  |

- Cautions 1. Make sure that bit 6 (TXE6) and bit 5 (RXE6) of the ASIM6 register = 0 when rewriting the MDL67 to MDL60 bits.
  - 2. The baud rate is the output clock of the 8-bit counter divided by 2.
- Remarks 1. fxcLk: Frequency of base clock (Clock) selected by the TPS63 to TPS60 bits of CKSR6 register
  - 2. k: Value set by MDL67 to MDL60 bits (k = 8, 9, 10, ..., 255)
  - 3.  $\times$ : Don't care

## (c) Baud rate

The baud rate can be calculated by the following expression.

• Baud rate = 
$$\frac{f_{XCLK}}{2 \times k}$$
 [bps]

 $f_{\text{XCLK}}$ : Frequency of base clock (Clock) selected by TPS63 to TPS60 bits of CKSR6 register

k: Value set by MDL67 to MDL60 bits of BRGC6 register (k = 8, 9, 10, ..., 255)

# (d) Error of baud rate

The baud rate error can be calculated by the following expression.

• Error (%) =  $\left(\frac{\text{Actual baud rate (baud rate with error)}}{\text{Desired baud rate (correct baud rate)}} - 1\right) \times 100 [\%]$ 

- Cautions 1. Keep the baud rate error during transmission to within the permissible error range at the reception destination.
  - 2. Make sure that the baud rate error during reception satisfies the range shown in (4) Permissible baud rate range during reception.
  - Example: Frequency of base clock (Clock) = 20 MHz = 20,000,000 Hz Set value of MDL67 to MDL60 bits of BRGC6 register = 01000001B (k = 65) Target baud rate = 153600 bps

Baud rate = 20 M/(2 × 65) = 20000000/(2 × 65) = 153,846 [bps]

Error = (153846/153600 - 1) × 100 = 0.160 [%]

# (3) Example of setting baud rate

| Baud Rate |                   | fx = | 10.0 MHz         |        |                   | fx = | 8.38 MHz         |        | fx = 4.19 MHz     |     |                  |        |
|-----------|-------------------|------|------------------|--------|-------------------|------|------------------|--------|-------------------|-----|------------------|--------|
| [bps]     | TPS63 to<br>TPS60 | k    | Calculated value | ERR[%] | TPS63 to<br>TPS60 | k    | Calculated value | ERR[%] | TPS63 to<br>TPS60 | k   | Calculated value | ERR[%] |
| 600       | 6H                | 130  | 601              | 0.16   | 6H                | 109  | 601              | 0.11   | 5H                | 109 | 601              | 0.11   |
| 1200      | 5H                | 130  | 1202             | 0.16   | 5H                | 109  | 1201             | 0.11   | 4H                | 109 | 1201             | 0.11   |
| 2400      | 4H                | 130  | 2404             | 0.16   | 4H                | 109  | 2403             | 0.11   | ЗH                | 109 | 2403             | 0.11   |
| 4800      | ЗН                | 130  | 4808             | 0.16   | ЗH                | 109  | 4805             | 0.11   | 2H                | 109 | 4805             | 0.11   |
| 9600      | 2H                | 130  | 9615             | 0.16   | 2H                | 109  | 9610             | 0.11   | 1H                | 109 | 9610             | 0.11   |
| 10400     | 2H                | 120  | 10417            | 0.16   | 2H                | 101  | 10371            | 0.28   | 1H                | 101 | 10475            | -0.28  |
| 19200     | 1H                | 130  | 19231            | 0.16   | 1H                | 109  | 19200            | 0.11   | ОH                | 109 | 19220            | 0.11   |
| 31250     | 1H                | 80   | 31250            | 0.00   | он                | 134  | 31268            | 0.06   | OН                | 67  | 31268            | 0.06   |
| 38400     | ОH                | 130  | 38462            | 0.16   | он                | 109  | 38440            | 0.11   | OН                | 55  | 38090            | -0.80  |
| 76800     | ОH                | 65   | 76923            | 0.16   | он                | 55   | 76182            | -0.80  | OН                | 27  | 77593            | 1.03   |
| 115200    | ОH                | 43   | 116279           | 0.94   | ОH                | 36   | 116388           | 1.03   | OН                | 18  | 116389           | 1.03   |
| 153600    | ОH                | 33   | 151515           | -1.36  | он                | 27   | 155185           | 1.03   | ОH                | 14  | 149643           | -2.58  |
| 230400    | ОH                | 22   | 227272           | -1.36  | он                | 18   | 232777           | 1.03   | ОH                | 9   | 232778           | 1.03   |

Table 15-4. Set Data of Baud Rate Generator

# Caution The maximum permissible frequency (fxcLK) of the base clock is 25 MHz.

| Remark | TPS63 to TPS60: | Bits 3 to 0 of clock selection register 6 (CKSR6) (setting of base clock (fxclk)) |  |  |  |  |  |  |  |
|--------|-----------------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|        | k:              | Value set by MDL67 to MDL60 bits of baud rate generator control register 6        |  |  |  |  |  |  |  |
|        |                 | (BRGC6) (k = 8, 9, 10,, 255)                                                      |  |  |  |  |  |  |  |
|        | fx:             | X1 input clock oscillation frequency                                              |  |  |  |  |  |  |  |
|        | ERR:            | Baud rate error                                                                   |  |  |  |  |  |  |  |
|        |                 |                                                                                   |  |  |  |  |  |  |  |

#### (4) Permissible baud rate range during reception

The permissible error from the baud rate at the transmission destination during reception is shown below.

Caution Make sure that the baud rate error during reception is within the permissible error range, by using the calculation expression shown below.





As shown in Figure 15-23, the latch timing of the receive data is determined by the counter set by baud rate generator control register 6 (BRGC6) after the start bit has been detected. If the last data (stop bit) meets this latch timing, the data can be correctly received.

Assuming that 11-bit data is received, the theoretical values can be calculated as follows.

 $FL = (Brate)^{-1}$ 

Brate:Baud rate of UART6k:Set value of BRGC6FL:1-bit data lengthMargin of latch timing: 2 clocks

 $\label{eq:maintain} \mbox{Minimum permissible transfer rate: FLmin = 11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k} \ \mbox{FL}$ 

Therefore, the maximum receivable baud rate at the transmission destination is as follows.

BRmax = 
$$(FLmin/11)^{-1} = \frac{22k}{21k + 2}$$
 Brate

Similarly, the maximum permissible transfer rate can be calculated as follows.

$$\frac{10}{11} \times FLmax = 11 \times FL - \frac{k+2}{2 \times k} \times FL = \frac{21k-2}{2 \times k} FL$$

$$FLmax = \frac{21k - 2}{20k} FL \times 11$$

Therefore, the minimum receivable baud rate at the transmission destination is as follows.

BRmin = 
$$(FLmax/11)^{-1} = \frac{20k}{21k - 2}$$
 Brate

The permissible baud rate error between UART6 and the transmission destination can be calculated from the above minimum and maximum baud rate expressions, as follows.

| Division Ratio (k) | Maximum Permissible Baud Rate Error | Minimum Permissible Baud Rate Error |  |  |
|--------------------|-------------------------------------|-------------------------------------|--|--|
| 8                  | +3.53%                              | -3.61%                              |  |  |
| 20                 | +4.26%                              | -4.31%                              |  |  |
| 50                 | +4.56%                              | -4.58%                              |  |  |
| 100                | +4.66%                              | -4.67%                              |  |  |
| 255                | +4.72%                              | -4.73%                              |  |  |

Remarks 1. The accuracy of reception depends on the number of bits in one frame, input clock frequency, and division ratio (k). The higher the input clock frequency and the higher the division ratio (k), the higher the accuracy.

2. k: Set value of BRGC6

#### (5) Transfer rate during continuous transmission

When data is continuously transmitted, the transfer rate from a stop bit to the next start bit is extended by two clocks from the normal value. However, the result of transfer is not affected because the timing is initialized on the reception side when the start bit is detected.





Where the 1-bit data length is FL, the stop bit length is FLstp, and base clock frequency is fxclk, the following expression is satisfied.

FLstp = FL + 2/fxcLK

Therefore, the transfer rate during continuous transmission is:

Transfer rate =  $11 \times FL + 2/f_{XCLK}$ 

# CHAPTER 16 SERIAL INTERFACES CSI10 AND CSI11

The  $\mu$ PD780143 and 780144 incorporate serial interface CSI10, and the  $\mu$ PD780146, 780148, and 78F0148 incorporate serial interfaces CSI10 and CSI11.

# 16.1 Functions of Serial Interfaces CSI10 and CSI11

Serial interfaces CSI10 and CSI11<sup>Note</sup> have the following two modes.

- Operation stop mode
- 3-wire serial I/O mode

#### (1) Operation stop mode

This mode is used when serial transfer is not performed and can enable a reduction in the power consumption.

#### (2) 3-wire serial I/O mode (MSB/LSB-first selectable)

This mode is used to transfer 8-bit data using three lines: a serial clock line (SCK1n) and two serial data lines (SI1n and SO1n).

The processing time of data transfer can be shortened in the 3-wire serial I/O mode because transmission and reception can be simultaneously executed.

In addition, whether 8-bit data is transferred with the MSB or LSB first can be specified, so this interface can be connected to any device.

The 3-wire serial I/O mode is useful for connecting peripheral I/Os and display controllers with a conventional clocked serial interface, such as the 75XL Series, 78K Series, and 17K Series.

**Note** μPD780146, 780148, and 78F0148 only

## 16.2 Configuration of Serial Interfaces CSI10 and CSI11

Serial interfaces CSI10 and CSI11 consist of the following hardware.

# Table 16-1. Configuration of Serial Interfaces CSI10 and CSI11

| Item              | Configuration                                                                             |
|-------------------|-------------------------------------------------------------------------------------------|
| Registers         | Transmit buffer register 1n (SOTB1n)<br>Serial I/O shift register 1n (SIO1n)              |
| Control registers | Serial operation mode register 1n (CSIM1n)<br>Serial clock selection register 1n (CSIC1n) |

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148



### Figure 16-1. Block Diagram of Serial Interface CSI10





#### (1) Transmit buffer register 1n (SOTB1n)

This register sets the transmit data.

Transmission/reception is started by writing data to SOTB1n when bit 6 (TRMD1n) of serial operation mode register 1n (CSIM1n) is 1.

The data written to SOTB1n is converted from parallel data into serial data by serial I/O shift register 1n, and output to the serial output pin (SO1n).

SOTB1n can be written or read by an 8-bit memory manipulation instruction.

RESET input makes this register undefined.

#### Caution Do not access SOTB1n when CSOT1n = 1 (during serial communication).

- **Remarks 1.** When using serial interface CSI11 in the slave mode, the operation is as follows if bit 5 (SSE11) of serial operation mode register 11 (CSIM11) is 1.
  - (1) If SSI11 is low

... This chip is selected and transmission is started by writing data to SOTB11.

- (2) If SSI11 is high
- ... Transmission is not started even if data is written to SOTB11 because this chip is not selected (transmission held pending).
- (3) If data is written to SOTB11 when transmission is held pending because SSI11 is high and then SSI11 goes low

... Transmission is started.

(4) If SSI11 goes high after transmission has been started by writing data to SOTB11 when SSI11 is low

... Transmission is aborted.

- **2.** n = 0: μPD780143, 780144
  - n = 0, 1: μPD780146, 780148, 78F0148

# (2) Serial I/O shift register 1n (SIO1n)

This is an 8-bit register that converts data from parallel data into serial data and vice versa. This register can be read by an 8-bit memory manipulation instruction.

Reception is started by reading data from SIO1n if bit 6 (TRMD1n) of serial operation mode register 1n (CSIM1n) is 0.

During reception, the data is read from the serial input pin (SI1n) to SIO1n.

RESET input clears this register to 00H.

# Caution Do not access SIO1n when CSOT1n = 1 (during serial communication).

- **Remark** When using serial interface CSI11 in the slave mode, the operation is as follows if bit 5 (SSE11) of serial operation mode register 11 (CSIM11) is 1.
  - (1) If SSI11 is low
    - ... This chip is selected and reception is started by reading data from SIO11.
  - (2) If SSI11 is high
    - ... Reception is not started even if data is read from SIO11 because this chip is not selected (reception held pending).
  - (3) If data is read from SIO11 when reception is held pending because SSI11 is high and then SSI11 goes low
    - ... Reception is started.
  - (4) If SSI11 goes high after reception has been started by reading data from SIO11 when SSI11 is low ... Reception is aborted.

# 16.3 Registers Controlling Serial Interfaces CSI10 and CSI11

Serial interfaces CSI10 and CSI11 are controlled by the following two registers.

- Serial operation mode register 1n (CSIM1n)
- Serial clock selection register 1n (CSIC1n)

# (1) Serial operation mode register 1n (CSIM1n)

CSIM1n is used to select the operation mode and enable or disable operation. CSIM1n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 16-3. Format of Serial Operation Mode Register 10 (CSIM10)

Address: FF80H After reset: 00H R/WNote 1

| Symbol | 7      | 6      | 5 | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|---|-------|---|---|---|--------|
| CSIM10 | CSIE10 | TRMD10 | 0 | DIR10 | 0 | 0 | 0 | CSOT10 |

| CSIE10 | Operation control in 3-wire serial I/O mode                                                                  |
|--------|--------------------------------------------------------------------------------------------------------------|
| 0      | Stops operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins can be used as general-purpose port pins). |
| 1      | Enables operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins are at active level).                    |

| TRMD10 <sup>Note 2</sup> | Note 2         Transmit/receive mode control           Receive mode (transmission disabled). |  |
|--------------------------|----------------------------------------------------------------------------------------------|--|
| O <sup>Note 3</sup>      |                                                                                              |  |
| 1 Transmit/receive mode  |                                                                                              |  |

| DIR10 <sup>Note 4</sup> | First bit specification |  |
|-------------------------|-------------------------|--|
| 0                       | MSB                     |  |
| 1                       | LSB                     |  |

| CSOT10 <sup>Note 5</sup> | Operation mode flag           |  |
|--------------------------|-------------------------------|--|
| 0                        | Communication is stopped.     |  |
| 1                        | Communication is in progress. |  |

Notes 1. Bit 0 is a read-only bit.

- 2. Do not rewrite TRMD10 when CSOT10 = 1 (during serial communication).
- **3.** The SO10 pin is fixed to the low level when TRMD10 is 0. Reception is started when data is read from SIO10.
- **4.** Do not rewrite DIR10 when CSOT10 = 1 (during serial communication).
- 5. CSOT10 is cleared if CSIE10 is set to 0 (operation stopped).

Caution Be sure to set bit 5 to 0.

## Figure 16-4. Format of Serial Operation Mode Register 11 (CSIM11)

Address: FF88H After reset: 00H R/WNote1

| Symbol | 7      | 6      | 5     | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|-------|-------|---|---|---|--------|
| CSIM11 | CSIE11 | TRMD11 | SSE11 | DIR11 | 0 | 0 | 0 | CSOT11 |

| CSIE11 | SIE11 Operation control in 3-wire serial I/O mode                                                  |  |
|--------|----------------------------------------------------------------------------------------------------|--|
| 0      | Stops operation (SI11/P03, SO11/P02, and SCK11/P04 pins can be used as general-purpose port pins). |  |
| 1      | Enables operation (SI11/P03, SO11/P02, and SCK11/P04 pins are at active level).                    |  |

| TRMD11 <sup>Note 2</sup> | Transmit/receive mode control                             |  |
|--------------------------|-----------------------------------------------------------|--|
| 0 <sup>Note 3</sup>      | 0 <sup>Note 3</sup> Receive mode (transmission disabled). |  |
| 1 Transmit/receive mode  |                                                           |  |

| SSE11 <sup>Notes 4, 5</sup> | SSI11 pin use selection |  |
|-----------------------------|-------------------------|--|
| 0                           | SSI11 pin is not used   |  |
| 1                           | SSI11 pin is used       |  |

| DIR11 <sup>Note 6</sup> | First bit specification |
|-------------------------|-------------------------|
| 0                       | MSB                     |
| 1                       | LSB                     |

| CSOT11 <sup>Note 7</sup> | Operation mode flag           |
|--------------------------|-------------------------------|
| 0                        | Communication is stopped.     |
| 1                        | Communication is in progress. |

**Notes 1.** Bit 0 is a read-only bit.

- 2. Do not rewrite TRMD11 when CSOT11 = 1 (during serial communication).
- **3.** The SO11 pin is fixed to the low level when TRMD11 is 0. Reception is started when data is read from SIO11.
- 4. Do not rewrite SSE11 when CSOT11 = 1 (during serial communication).
- 5. Before setting this bit to 1, fix the  $\overline{SSI11}$  pin input level to 0 or 1.
- 6. Do not rewrite DIR11 when CSOT11 = 1 (during serial communication).
- 7. CSOT11 is cleared if CSIE11 is set to 0 (operation stopped).

### (2) Serial clock selection register 1n (CSIC1n)

CSIC1n is used to select the phase of the data clock and set the count clock. CSIC1n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

## Figure 16-5. Format of Serial Clock Selection Register 10 (CSIC10)

Address: FF81H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4     | 3     | 2      | 1      | 0      |
|--------|---|---|---|-------|-------|--------|--------|--------|
| CSIC10 | 0 | 0 | 0 | CKP10 | DAP10 | CKS102 | CKS101 | CKS100 |

| CKP10 | DAP10 | Data clock phase selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Туре |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 0     | 0     | SCK10            SO10            SO10            SI10 input timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1    |
| 0     | 1     | SCK10         SCK10 <th< td=""><td>2</td></th<> | 2    |
| 1     | 0     | SCK10            SO10            SO10            SI10 input timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3    |
| 1     | 1     | SCK10            SO10         XD7XD6XD5XD4XD3XD2XD1XD0           SI10 input timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4    |

| CKS102 | CKS101 | CKS100 | CSI10 count clock selection    |
|--------|--------|--------|--------------------------------|
| 0      | 0      | 0      | fx/2 (5 MHz)                   |
| 0      | 0      | 1      | fx/2² (2.5 MHz)                |
| 0      | 1      | 0      | fx/2 <sup>3</sup> (1.25 MHz)   |
| 0      | 1      | 1      | fx/2 <sup>4</sup> (625 kHz)    |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (312.5 kHz)  |
| 1      | 0      | 1      | fx/2 <sup>e</sup> (156.25 kHz) |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1      | 1      | 1      | External clock input to SCK10  |

Cautions 1. Do not write CSIC10 during a communication operation or when using P10/SCK10/TxD0, P11/SI10/RxD0, and P12/SO10 as general-purpose port pins.

- 2. The phase type of the data clock is type 1 after reset.
- **Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz
  - 2. fx: X1 input clock oscillation frequency

| Figure 16-6. | Format of Serial Clock Selection Register 11 (CSIC11) |
|--------------|-------------------------------------------------------|
|--------------|-------------------------------------------------------|

| Address: FF8 | 89H After rese | t: 00H R/W |   |       |       |        |        |        |
|--------------|----------------|------------|---|-------|-------|--------|--------|--------|
| Symbol       | 7              | 6          | 5 | 4     | 3     | 2      | 1      | 0      |
| CSIC11       | 0              | 0          | 0 | CKP11 | DAP11 | CKS112 | CKS111 | CKS110 |

| CKP11 | DAP11 | Data clock phase selection                                                         | Туре |
|-------|-------|------------------------------------------------------------------------------------|------|
| 0     | 0     | SCK11                                                                              | 1    |
| 0     | 1     | SCK11                                                                              | 2    |
| 1     | 0     | SCK11            SO11            SO11            SI11 input timing                 | 3    |
| 1     | 1     | SCK11            SO11         XD7XD6XD5XD4XD3XD2XD1XD0           SI11 input timing | 4    |

| CKS112 | CKS111 | CKS110 | CSI11 count clock selection    |
|--------|--------|--------|--------------------------------|
| 0      | 0      | 0      | fx/2 (5 MHz)                   |
| 0      | 0      | 1      | fx/2² (2.5 MHz)                |
| 0      | 1      | 0      | fx/2³ (1.25 MHz)               |
| 0      | 1      | 1      | fx/2⁴ (625 kHz)                |
| 1      | 0      | 0      | fx/2⁵ (312.5 kHz)              |
| 1      | 0      | 1      | fx/2 <sup>e</sup> (156.25 kHz) |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1      | 1      | 1      | External clock input to SCK11  |

Cautions 1. Do not write CSIC11 during a communication operation or when using P02/SO11, P03/SI11, and P04/SCK11 as general-purpose port pins.

2. The phase type of the data clock is type 1 after reset.

**Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz

2. fx: X1 input clock oscillation frequency

# 16.4 Operation of Serial Interfaces CSI10 and CSI11

Serial interface CSI10 and CSI11 can be used in the following two modes.

- Operation stop mode
- 3-wire serial I/O mode

# 16.4.1 Operation stop mode

Serial transfer is not executed in this mode. Therefore, the power consumption can be reduced. In addition, the P10/SCK10/TxD0, P11/SI10/RxD0, P12/SO10, P02/SO11<sup>Note</sup>, P03/SI11<sup>Note</sup>, and P04/SCK11<sup>Note</sup> pins can be used as ordinary I/O port pins in this mode.

**Note** μPD780146, 780148, and 78F0148 only

### (1) Register setting

The operation stop mode is set by serial operation mode register 1n (CSIM1n).

# (a) Serial operation mode register 1n (CSIM1n)

CSIM1n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets CSIM1n to 00H.

**Remark** n = 0: μPD780143, 780144

n = 0, 1: µPD780146, 780148, 78F0148

• Serial operation mode register 10 (CSIM10)

#### Address: FF80H After reset: 00H R/W

| Symbol | 7      | 6      | 5 | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|---|-------|---|---|---|--------|
| CSIM10 | CSIE10 | TRMD10 | 0 | DIR10 | 0 | 0 | 0 | CSOT10 |

| CSIE10 | Operation control in 3-wire serial I/O mode                                                                  |
|--------|--------------------------------------------------------------------------------------------------------------|
| 0      | Stops operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins can be used as general-purpose port pins). |
| 1      | Enables operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins are at active level).                    |

• Serial operation mode register 11 (CSIM11)

#### Address: FF88H After reset: 00H R/W

| Symbol | 7      | 6      | 5     | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|-------|-------|---|---|---|--------|
| CSIM11 | CSIE11 | TRMD11 | SSE11 | DIR11 | 0 | 0 | 0 | CSOT11 |

| CSIE11 | Operation control in 3-wire serial I/O mode                                                        |
|--------|----------------------------------------------------------------------------------------------------|
| 0      | Stops operation (SI11/P03, SO11/P02, and SCK11/P04 pins can be used as general-purpose port pins). |
| 1      | Enables operation (SI11/P03, SO11/P02, and SCK11/P04 pins are at active level).                    |

#### 16.4.2 3-wire serial I/O mode

The 3-wire serial I/O mode is useful for connecting peripheral I/Os and display controllers that have a conventional clocked serial interface, such as the 75XL Series, 78K Series, and 17K Series.

In this mode, communication is executed by using three lines: the serial clock (SCK1n), serial output (SO1n), and serial input (SI1n) lines.

## (1) Register setting

The 3-wire serial I/O mode is set by serial operation mode register 1n (CSIM1n) and serial clock selection register 1n (CSIC1n).

#### (a) Serial operation mode register 1n (CSIM1n)

This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148 • Serial operation mode register 10 (CSIM10)

# Address: FF80H After reset: 00H R/W<sup>Note 1</sup>

| Symbol | 7      | 6      | 5 | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|---|-------|---|---|---|--------|
| CSIM10 | CSIE10 | TRMD10 | 0 | DIR10 | 0 | 0 | 0 | CSOT10 |

| CSIE10 | Operation control in 3-wire serial I/O mode                                                                  |
|--------|--------------------------------------------------------------------------------------------------------------|
| 0      | Stops operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins can be used as general-purpose port pins). |
| 1      | Enables operation (SI10/P11/RxD0, SO10/P12, and SCK10/P10/TxD0 pins are at active level).                    |

| TRMD10 <sup>Note 2</sup> | Transmit/receive mode control         |  |
|--------------------------|---------------------------------------|--|
| O <sup>Note 3</sup>      | Receive mode (transmission disabled). |  |
| 1                        | Transmit/receive mode                 |  |

| DIR10 <sup>Note 4</sup> | First bit specification |
|-------------------------|-------------------------|
| 0                       | MSB                     |
| 1                       | LSB                     |

| CSOT10 <sup>Note 5</sup> | Operation mode flag           |
|--------------------------|-------------------------------|
| 0                        | Communication is stopped.     |
| 1                        | Communication is in progress. |

## Notes 1. Bit 0 is a read-only bit.

- 2. Do not rewrite TRMD10 when CSOT10 = 1 (during serial communication).
- **3.** The SO10 pin is fixed to the low level when TRMD10 is 0. Reception is started when data is read from SIO10.
- **4.** Do not rewrite DIR10 when CSOT10 = 1 (during serial communication).
- 5. CSOT10 is cleared if CSIE10 is set to 0 (operation stopped).

Caution Be sure to set bit 5 to 0.

• Serial operation mode register 11 (CSIM11)

Address: FF88H After reset: 00H R/W<sup>Note 1</sup>

| Symbol | 7      | 6      | 5     | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|-------|-------|---|---|---|--------|
| CSIM11 | CSIE11 | TRMD11 | SSE11 | DIR11 | 0 | 0 | 0 | CSOT11 |

| CSIE11 | Operation control in 3-wire serial I/O mode                                                        |
|--------|----------------------------------------------------------------------------------------------------|
| 0      | Stops operation (SI11/P03, SO11/P02, and SCK11/P04 pins can be used as general-purpose port pins). |
| 1      | Enables operation (SI11/P03, SO11/P02, and SCK11/P04 pins are at active level).                    |

| TRMD11 <sup>Note 2</sup> Transmit/receive mode control |     | Transmit/receive mode control         |  |
|--------------------------------------------------------|-----|---------------------------------------|--|
| 0 <sup>Note</sup>                                      | e 3 | Receive mode (transmission disabled). |  |
| 1                                                      |     | Transmit/receive mode                 |  |

| SSE11 <sup>Notes 4, 5</sup> | SSI11 pin use selection |
|-----------------------------|-------------------------|
| 0                           | SSI11 pin is not used   |
| 1                           | SSI11 pin is used       |

| DIR11 <sup>Note 6</sup> | First bit specification |
|-------------------------|-------------------------|
| 0                       | MSB                     |
| 1                       | LSB                     |

| CSOT11 <sup>Note 7</sup> | Operation mode flag           |
|--------------------------|-------------------------------|
| 0                        | Communication is stopped.     |
| 1                        | Communication is in progress. |

**Notes 1.** Bit 0 is a read-only bit.

- 2. Do not rewrite TRMD11 when CSOT11 = 1 (during serial communication).
- **3.** The SO11 pin is fixed to the low level when TRMD11 is 0. Reception is started when data is read from SIO11.
- 4. Do not rewrite SSE11 when CSOT11 = 1 (during serial communication).
- 5. Before setting this bit to 1, fix the  $\overline{SSI11}$  pin input level to 0 or 1.
- 6. Do not rewrite DIR11 when CSOT11 = 1 (during serial communication).
- 7. CSOT11 is cleared if CSIE11 is set to 0 (operation stopped).

4

CKP10

3

DAP10

2

CKS102

0

CKS100

1

CKS101

## (b) Serial clock selection register 1n (CSIC1n)

CSIC1n can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

5

0

**Remark** n = 0: *µ*PD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

Serial clock selection register 10 (CSIC10)

6

0

Address: FF81H After reset: 00H R/W 7

0

Symbol CSIC10

| CKP10 | DAP10 | Data clock phase selection                                                                                | Туре |
|-------|-------|-----------------------------------------------------------------------------------------------------------|------|
| 0     | 0     | SCK10            SO10            SO10            SI10 input timing                                        | 1    |
| 0     | 1     | SCK10         SCK10           SO10         XD7XD6XD5XD4XD3XD2XD1XD0           SI10 input timing         I | 2    |
| 1     | 0     | SCK10            SO10            SO10            SI10 input timing                                        | 3    |
| 1     | 1     | SCK10            SO10         XD7XD6XD5XD4XD3XD2XD1XD0           SI10 input timing                        | 4    |

| CKS102 | CKS101 | CKS100 | CSI10 count clock selection    |
|--------|--------|--------|--------------------------------|
| 0      | 0      | 0      | fx/2 (5 MHz)                   |
| 0      | 0      | 1      | fx/2² (2.5 MHz)                |
| 0      | 1      | 0      | fx/2³ (1.25 MHz)               |
| 0      | 1      | 1      | fx/2⁴ (625 kHz)                |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (312.5 kHz)  |
| 1      | 0      | 1      | fx/2 <sup>6</sup> (156.25 kHz) |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1      | 1      | 1      | External clock input to SCK10  |

- Cautions 1. Do not write CSIC10 during a communication operation or when using P10/SCK10/TxD0, P11/SI10/RxD0, and P12/SO10 as general-purpose port pins.
  - 2. The phase type of the data clock is type 1 after reset.
- **Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz
  - 2. fx: X1 input clock oscillation frequency

• Serial clock selection register 11 (CSIC11)

| Address: FF89H After reset: 00H R/W |   |   |   |       |       |        |        |        |
|-------------------------------------|---|---|---|-------|-------|--------|--------|--------|
| Symbol                              | 7 | 6 | 5 | 4     | 3     | 2      | 1      | 0      |
| CSIC11                              | 0 | 0 | 0 | CKP11 | DAP11 | CKS112 | CKS111 | CKS110 |

| CKP11 | DAP11 | Data clock phase selection                                                         | Туре |
|-------|-------|------------------------------------------------------------------------------------|------|
| 0     | 0     | SCK11                                                                              | 1    |
| 0     | 1     | SCK11                                                                              | 2    |
| 1     | 0     | SCK11            SO11            SO11            SI11 input timing                 | 3    |
| 1     | 1     | SCK11            SO11         XD7XD6XD5XD4XD3XD2XD1XD0           SI11 input timing | 4    |

| CKS112 | CKS111 | CKS110 | CSI11 count clock selection    |
|--------|--------|--------|--------------------------------|
| 0      | 0      | 0      | fx/2 (5 MHz)                   |
| 0      | 0      | 1      | fx/2² (2.5 MHz)                |
| 0      | 1      | 0      | fx/2³ (1.25 MHz)               |
| 0      | 1      | 1      | f∞/2⁴ (625 kHz)                |
| 1      | 0      | 0      | fx/2⁵ (312.5 kHz)              |
| 1      | 0      | 1      | fx/2 <sup>e</sup> (156.25 kHz) |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (78.13 kHz)  |
| 1      | 1      | 1      | External clock input to SCK11  |

Cautions 1. Do not write CSIC11 during a communication operation or when using P02/SO11, P03/SI11, and P04/SCK11 as general-purpose port pins.

2. The phase type of the data clock is type 1 after reset.

**Remarks 1.** Figures in parentheses are for operation with fx = 10 MHz

2. fx: X1 input clock oscillation frequency

# (2) Setting of ports

- Serial interface CSI10
- <1> Transmit/receive mode

# (a) To use externally input clock as system clock (SCK10)

- Bit 1 (PM11) of port mode register 1: Set to 1
- Bit 2 (PM12) of port mode register 1: Cleared to 0
- Bit 0 (PM10) of port mode register 1: Set to 1
- Bit 2 (P12) of port 1: Cleared to 0

# (b) To use internal clock as system clock (SCK10)

- (Bit 1 (PM11) of port mode register 1: Set to 1
- Bit 2 (PM12) of port mode register 1: Cleared to 0
- Bit 0 (PM10) of port mode register 1: Cleared to 0
- Bit 2 (P12) of port 1: Cleared to 0
- Bit 0 (P10) of port 1: Set to 1

# <2> Receive mode (with transmission disabled)

# (a) To use externally input clock as system clock (SCK10)

- $\int$  Bit 1 (PM11) of port mode register 1: Set to 1
- Bit 0 (PM10) of port mode register 1: Set to 1

# (b) To use internal clock as system clock (SCK10)

- Bit 1 (PM11) of port mode register 1: Set to 1
- Bit 0 (PM10) of port mode register 1: Cleared to 0
- Bit 0 (P10) of port 1: Set to 1
- **Remark** The transmit/receive mode or receive mode is selected by using bit 6 (TRMD10) of serial operation mode register 10 (CSIM10).

### • Serial interface CSI11

# <1> Transmit/receive mode

# (a) To use externally input clock as system clock (SCK11)

Bit 3 (PM03) of port mode register 0: Set to 1

- Bit 2 (PM02) of port mode register 0: Cleared to 0
- Bit 4 (PM04) of port mode register 0: Set to 1
- Bit 2 (P02) of port 0: Cleared to 0

### (b) To use internal clock as system clock (SCK11)

Fit 3 (PM03) of port mode register 0: Set to 1

- Bit 2 (PM02) of port mode register 0: Cleared to 0
- Bit 4 (PM04) of port mode register 0: Cleared to 0
- Bit 2 (P02) of port 0: Cleared to 0
- Bit 4 (P04) of port 0: Set to 1

# <2> Receive mode (with transmission disabled)

- (a) To use externally input clock as system clock (SCK11)
  - $\int$  Bit 3 (PM03) of port mode register 0: Set to 1
  - Bit 4 (PM04) of port mode register 0: Set to 1

# (b) To use internal clock as system clock (SCK11)

Bit 3 (PM03) of port mode register 0: Set to 1

Bit 4 (PM04) of port mode register 0: Cleared to 0

Bit 4 (P04) of port 0: Set to 1

**Remark** The transmit/receive mode or receive mode is selected by using bit 6 (TRMD11) of serial operation mode register 11 (CSIM11).

# (3) Communication operation

In the 3-wire serial I/O mode, data is transmitted or received in 8-bit units. Each bit of the data is transmitted or received in synchronization with the serial clock.

Data can be transmitted or received if bit 6 (TRMD1n) of serial operation mode register 1n (CSIM1n) is 1. Transmission/reception is started when a value is written to transmit buffer register 1n (SOTB1n). In addition, data can be received when bit 6 (TRMD1n) of serial operation mode register 1n (CSIM1n) is 0.

Reception is started when data is read from serial I/O shift register 1n (SIO1n).

When using serial interface CSI11, however, the communication operation is not started if bit 5 (SSE11) of CSIM11 is 1 in the slave mode, and the  $\overline{SSI11}$  pin is at the high level.

After communication has been started, bit 0 (CSOT1n) of CSIM1n is set to 1. When communication of 8-bit data has been completed, a communication completion interrupt request flag (CSIIF1n) is set, and CSOT1n is cleared to 0. Then the next communication is enabled.

- Cautions 1. Do not access the control register and data register when CSOT1n = 1 (during serial communication).
  - 2. When using serial interface CSI11, wait for the duration of at least one clock before the clock operation is started to change the level of the SSI11 pin in the slave mode; otherwise, malfunctioning may occur.

**Remark** n = 0, 1



## Figure 16-7. Timing in 3-Wire Serial I/O Mode (1/2)



- Note The SSE11 flag and SSI11 pin are available only for serial interface CSI11, and are used in the slave mode.
- **Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

<sup>55</sup>H is written to SOTB1n.



## Figure 16-7. Timing in 3-Wire Serial I/O Mode (2/2)



Note The SSE11 flag and SSI11 pin are available only for serial interface CSI11, and are used in the slave mode.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

#### Figure 16-8. Timing of Clock/Data Phase

## (a) Type 1; CKP1n = 0, DAP1n = 0



### (b) Type 2; CKP1n = 0, DAP1n = 1



## (c) Type 3; CKP1n = 1, DAP1n = 0



(d) Type 4; CKP1n = 1, DAP1n = 1





## (4) Timing of output to SO1n pin (first bit)

When communication is started, the value of transmit buffer register 1n (SOTB1n) is output from the SO1n pin. The output operation of the first bit at this time is described below.

Figure 16-9. Output Operation of First Bit





The first bit is directly latched by the SOTB1n register to the output latch at the falling (or rising) edge of  $\overline{SCK1n}$ , and output from the SO1n pin via an output selector. Then, the value of the SOTB1n register is transferred to the SIO1n register at the next rising (or falling) edge of  $\overline{SCK1n}$ , and shifted one bit. At the same time, the first bit of the receive data is stored in the SIO1n register via the SI1n pin.

The second and subsequent bits are latched by the SIO1n register to the output latch at the next falling (or rising) edge of SCK1n, and the data is output from the SO1n pin.





The first bit is directly latched by the SOTB1n register at the falling edge of the write signal of the SOTB1n register or the read signal of the SIO1n register, and output from the SO1n pin via an output selector. Then, the value of the SOTB1n register is transferred to the SIO1n register at the next falling (or rising) edge of SCK1n, and shifted one bit. At the same time, the first bit of the receive data is stored in the SIO1n register via the SI1n pin. The second and subsequent bits are latched by the SIO1n register to the output latch at the next rising (or falling) edge of SCK1n, and the data is output from the SO1n pin.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

### (5) Output value of SO1n pin (last bit)

After communication has been completed, the SO1n pin holds the output value of the last bit.

Figure 16-10. Output Value of SO1n Pin (Last Bit)





(2) Type 2; when CKP1n = 0 and DAP1n = 1 (or CKP1n = 1, DAP1n = 1)



**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

## (6) SO1n pin

The status of the SO1n pin is as follows if bit 7 (CSIE1n) of serial operation mode register 1n (CSIM1n) is cleared to 0.

| TRMD1n              | DAP1n     | DIR1n     | SO1n Pin                                  |
|---------------------|-----------|-----------|-------------------------------------------|
| $TRMD1n = 0^{Note}$ | _         | _         | Outputs low level <sup>Note</sup> .       |
| TRMD1n = 1          | DAP1n = 0 | _         | Value of SO1n latch<br>(low-level output) |
|                     | DAP1n = 1 | DIR1n = 0 | Value of bit 7 of SOTB1n                  |
|                     |           | DIR1n = 1 | Value of bit 0 of SOTB1n                  |

Table 16-2. SO1n Pin Status

**Note** Status after reset

Caution If a value is written to TRMD1n, DAP1n, and DIR1n, the output value of the SO1n pin changes.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

## **CHAPTER 17 SERIAL INTERFACE CSIA0**

## 17.1 Functions of Serial Interface CSIA0

Serial interface CSIA0 has the following three modes.

- Operation stop mode
- 3-wire serial I/O mode
- 3-wire serial I/O mode with automatic transmit/receive function

#### (1) Operation stop mode

This mode is used when serial transfer is not performed and can enable a reduction in the power consumption.

#### (2) 3-wire serial I/O mode (MSB/LSB-first selectable)

This mode is used to transfer 8-bit data using three lines: a serial clock line (SCKA0) and two serial data lines (SIA0 and SOA0).

The processing time of data transfer can be shortened in the 3-wire serial I/O mode because transmission and reception can be simultaneously executed.

In addition, whether 8-bit data is transferred MSB or LSB first can be specified, so this interface can be connected to any device.

## (3) 3-wire serial I/O mode with automatic transmit/receive function (MSB/LSB-first selectable)

This mode is used to transfer 8-bit data using three lines: a serial clock line (SCKA0) and two serial data lines (SIA0 and SOA0).

The processing time of data transfer can be shortened in the 3-wire serial I/O mode because transmission and reception can be simultaneously executed.

In addition, whether 8-bit data is transferred MSB or LSB first can be specified, so this interface can be connected to any device.

Data can be transferred to/from a display driver etc. without using software since a 32-byte transfer buffer RAM is incorporated. Also, the incorporation of handshake pins (STB0, BUSY0) has made connection to peripheral LSIs easy.

- Master mode/slave mode selectable
- Transfer data length: 8 bits
- MSB/LSB-first selectable for transfer data
- Automatic transmit/receive function:

Number of transfer bytes can be specified between 1 and 32

Transfer interval can be specified (0 to 63 clocks)

Single transfer/repeat transfer selectable

- On-chip dedicated baud rate generator (6/8/16/32 divisions)
- 3-wire SOA0: Serial data output

SIA0: Serial data input

SCKA0: Serial clock I/O

Handshake function incorporated STB0: Strobe output

#### BUSY0: Busy input

- Transmission/reception completion interrupt: INTACSI
- Internal 32-byte buffer RAM

# 17.2 Configuration of Serial Interface CSIA0

Serial interface CSIA0 consists of the following hardware.

# Table 17-1. Configuration of Serial Interface CSIA0

| Item              | Configuration                                                                                                                                                                                                                                                                                                            |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register          | Serial I/O shift register 0 (SIOA0)<br>Automatic data transfer address count register 0 (ADTC0)                                                                                                                                                                                                                          |
| Control registers | Serial operation mode specification register 0 (CSIMA0)<br>Serial status register 0 (CSIS0)<br>Serial trigger register 0 (CSIT0)<br>Divisor selection register 0 (BRGCA0)<br>Automatic data transfer address point specification register 0 (ADTP0)<br>Automatic data transfer interval specification register 0 (ADTI0) |





Preliminary User's Manual U15947EJ1V1UD

## (1) Serial I/O shift register 0 (SIOA0)

This is an 8-bit register used to store transmit/receive data in 1-byte transfer mode (bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) = 0). Writing transmit data to SIOA0 starts the transfer. In addition, after a transfer completion interrupt request (INTACSI) is output (bit 0 (TSF0) of serial status register 0 (CSIS0) = 0), data can be received by reading data from SIOA0.

This register can be written or read by an 8-bit memory manipulation instruction. However, writing to SIOA0 is prohibited when bit 0 (TSF0) of serial status register 0 (CSIS0) = 1

RESET input sets this register 00H.

- Cautions 1. A transfer operation is started by writing to SIOA0. Consequently, when transmission is disabled (bit 3 (TXEA0) of CSIMA0 = 0), write dummy data to the SIOA0 register to start the transfer operation, and then perform a receive operation.
  - 2. Do not write data to SIOA0 while the automatic transmit/receive function is operating.

## (2) Automatic data transfer address count register 0 (ADTC0)

This is a register used to indicate buffer RAM addresses during automatic transfer. When automatic transfer is stopped, the data position when transfer stopped can be ascertained by reading ADTC0 register value. This register can be set by an 8-bit memory manipulation instruction.

RESET input sets this register to 00H. However, reading from ADTC0 is prohibited when bit 0 (TSF0) of serial status register 0 (CSIS0) = 1.

#### Figure 17-2. Format of Automatic Data Transfer Address Count Register 0 (ADTC0)

| Address: FF97 | H After res | et: 00H R |   |        |        |        |        |        |
|---------------|-------------|-----------|---|--------|--------|--------|--------|--------|
| Symbol        | 7           | 6         | 5 | 4      | 3      | 2      | 1      | 0      |
| ADTC0         | 0           | 0         | 0 | ADTC04 | ADTC03 | ADTC02 | ADTC01 | ADTP00 |

## 17.3 Registers Controlling Serial Interface CSIA0

Serial interface CSIA0 is controlled by the following six registers.

- Serial operation mode specification register 0 (CSIMA0)
- Serial status register 0 (CSIS0)
- Serial trigger register 0 (CSIT0)
- Divisor selection register 0 (BRGCA0)
- Automatic data transfer address point specification register 0 (ADTP0)
- Automatic data transfer interval specification register 0 (ADTI0)

### (1) Serial operation mode specification register 0 (CSIMA0)

This is an 8-bit register used to control the serial transfer operation. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

## Figure 17-3. Format of Serial Operation Mode Specification Register 0 (CSIMA0)

Address: FF90H After reset: 00H R/W

| Symbol | 7      | 6    | 5    | 4       | 3     | 2     | 1    | 0 |
|--------|--------|------|------|---------|-------|-------|------|---|
| CSIMA0 | CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | Control of CSIA0 operation enable/disable                     |  |
|--------|---------------------------------------------------------------|--|
| 0      | CSIA0 operation disabled (SOA0: Low level, SCKA0: High level) |  |
| 1      | CSIA0 operation enabled                                       |  |

| ATE0 | Control of automatic transfer operation enable/disable |  |
|------|--------------------------------------------------------|--|
| 0    | 1-byte transfer mode                                   |  |
| 1    | Automatic transfer mode                                |  |

| ATM0 | Automatic transfer mode specification                                                                 |
|------|-------------------------------------------------------------------------------------------------------|
| 0    | Single transfer mode (stops at the address specified by the ADTP0 register)                           |
| 1    | Repeat transfer mode (after transfer is complete, clear the ADTC0 register to 00H to resume transfer) |

| MASTER0 | CSIA0 master/slave mode specification           |
|---------|-------------------------------------------------|
| 0       | Slave mode (synchronous with SCKA0 input clock) |
| 1       | Master mode (synchronous with internal clock)   |

| TXEA0 | Control of transmit operation enable/disable  |  |
|-------|-----------------------------------------------|--|
| 0     | Transmit operation disabled (SOA0: Low level) |  |
| 1     | Transmit operation enabled                    |  |

| RXEA0 | Control of receive operation enable/disable |  |
|-------|---------------------------------------------|--|
| 0     | Receive operation disabled                  |  |
| 1     | Receive operation enabled                   |  |

| DIR0 | First bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

Cautions 1. When CSIAE0 = 0, the buffer RAM cannot be accessed.

- 2. When CSIAE0 is changed from 1 to 0, all the registers of the CSIA0 unit are initialized asynchronously. To set CSIAE0 = 1 again, be sure to re-set the registers of the CSIA0 unit.
- 3. When CSIAE0 is re-set to 1 after CSIAE0 is changed from 1 to 0, it is not guaranteed that the value of the buffer RAM will be retained.

### (2) Serial status register 0 (CSIS0)

This is an 8-bit register used to select the input clock and to control the transfer operation of CSIA0. This register can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets this register to 00H. However, rewriting CSIS0 is prohibited when bit 0 (TSF0).

#### Figure 17-4. Format of Serial Status Register 0 (CSIS0) (1/2)

Address: FF91H After reset: 00H R/WNote 1



| STBE0 <sup>Notes 2, 3</sup> | Strobe output enable/disable |
|-----------------------------|------------------------------|
| 0                           | Strobe output disabled       |
| 1                           | Strobe output enabled        |

| BUSYE0 | BUSYE0 Busy signal detection enable/disable                                |  |  |  |  |  |  |
|--------|----------------------------------------------------------------------------|--|--|--|--|--|--|
| 0      | 0 Busy signal detection disabled (input via BUSY0 pin is ignored)          |  |  |  |  |  |  |
| 1      | Busy signal detection enabled and transfer wait by busy signal is executed |  |  |  |  |  |  |

| BUSYLV0 <sup>Note 4</sup> | Busy signal active level setting |
|---------------------------|----------------------------------|
| 0                         | Low level                        |
| 1                         | High level                       |

Notes 1. Bits 0 and 1 are read-only.

- 2. STBE0 is valid only in master mode. In slave mode, 1-byte transfer ends after eight transfer clocks regardless of the STBE0 set value.
- 3. When STBE0 is set to 1, two transfer clocks are consumed between byte transfers regardless of the setting of automatic data transfer interval specification register 0 (ADTI0). That is, 10 transfer clocks are used for 1-byte transfer even if ADTI0 = 00H is set.
- 4. In bit error detection by busy input, the active level specified by BUSYLV0 is detected.

Caution Be sure to set bits 6 and 7 to 0.

| ERRE0 <sup>№</sup> | Bit error detection enable/disable |
|--------------------|------------------------------------|
| 0                  | Error detection disabled           |
| 1                  | Error detection enabled            |

## Figure 17-4. Format of Serial Status Register 0 (CSIS0) (2/2)

| ERRF0 | Bit error detection flag                                                                          |
|-------|---------------------------------------------------------------------------------------------------|
| 0     | • Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0                   |
|       | At reset input                                                                                    |
|       | • When transfer is started by setting bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) to 1 or |
|       | writing to SIOA0.                                                                                 |
| 1     | Bit error detected (when ERRE0 = 1, the level specified by BUSYLV0 during the data bit transfer   |
|       | period is detected via BUSY0 pin input).                                                          |
|       |                                                                                                   |
| TSF0  | Transfer status detection flag                                                                    |

| TSF0 | Transfer status detection flag                                                                 |  |  |  |  |  |  |
|------|------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0    | • Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0                |  |  |  |  |  |  |
|      | At reset input                                                                                 |  |  |  |  |  |  |
|      | At the end of the specified transfer                                                           |  |  |  |  |  |  |
|      | • When transfer is stopped by setting bit 1 (ATSTP0) of serial trigger register 0 (CSIT0) to 1 |  |  |  |  |  |  |
| 1    | From the transfer start to the end of the specified transfer                                   |  |  |  |  |  |  |

**Note** The ERRE0 setting is valid even when BUSYE0 = 0.

Caution When TSF0 is 1, rewriting serial operation mode specification register 0 (CSIMA0), serial status register 0 (CSIS0), divisor selection register 0 (BRGCA0), automatic data transfer address point specification register 0 (ADTP0), automatic data transfer interval specification register 0 (ADTI0), and serial I/O shift register 0 (SIOA0) are prohibited. However, these registers can be read and re-written to the same value. In addition, the buffer RAM can be rewritten during transfer.

### (3) Serial trigger register 0 (CSIT0)

This is an 8-bit register used to control execution/stop of automatic data transfer.

This register can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets this register to 00H. However, manipulate only when bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) is 1 (manipulation prohibited when ATE0 = 0).

#### Figure 17-5. Format of Serial Trigger Register 0 (CSIT0)

Address: FF92H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
|--------|---|---|---|---|---|---|--------|--------|
| CSIT0  | 0 | 0 | 0 | 0 | 0 | 0 | ATSTP0 | ATSTA0 |

| ATSTP0 | Automatic data transfer stop    |  |  |  |  |  |
|--------|---------------------------------|--|--|--|--|--|
| 0      | Normal mode                     |  |  |  |  |  |
| 1      | Automatic data transfer stopped |  |  |  |  |  |

| ATSTA0 | Automatic data transfer start   |  |  |  |  |
|--------|---------------------------------|--|--|--|--|
| 0      | Normal mode                     |  |  |  |  |
| 1      | Automatic data transfer started |  |  |  |  |

Cautions 1. Even if ATSTP0 or ATSTA0 is set to 1, automatic transfer cannot be started/stopped until 1byte transfer is complete.

- 2. ATSTP0 and ATSTA0 retain 1 until immediately before the interrupt signal INTACSI is generated, and then change to 0 automatically.
- 3. After automatic data transfer is stopped, the data address when the transfer stopped is stored in automatic data transfer address count register 0 (ADTC0). However, since no function to restart automatic data transfer is incorporated, when transfer is stopped by setting ATSTP0 = 1, start automatic data transfer by ATSTA0 after re-setting the registers.

### (4) Divisor selection register 0 (BRGCA0)

This is an 8-bit register used to control the serial transfer speed (divisor of CSIA input clock). This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting BRGCA0 is prohibited.

#### Figure 17-6. Format of Divisor Selection Register 0 (BRGCA0)

| Address: FF93H After reset: 03H R/W                             |   |   |   |   |   |   |         |         |
|-----------------------------------------------------------------|---|---|---|---|---|---|---------|---------|
| Symbol                                                          | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
| BRGCA0                                                          | 0 | 0 | 0 | 0 | 0 | 0 | BRGCA01 | BRGCA00 |
|                                                                 |   |   |   |   |   |   |         |         |
| BRGCA01 BRGCA00 CSIA0 input clock (fw) division ratio selection |   |   |   |   |   |   |         |         |
|                                                                 |   |   |   |   |   |   |         |         |

| BRGCA01 | BRGCA00 | CSIA0 input clock (fw) division ratio selection |
|---------|---------|-------------------------------------------------|
| 0       | 0       | fw/6 (1.67 MHz)                                 |
| 0       | 1       | fw/2 <sup>3</sup> (1.25 MHz)                    |
| 1       | 0       | fw/2 <sup>4</sup> (625 kHz)                     |
| 1       | 1       | fw/2 <sup>5</sup> (312.5 kHz)                   |

**Remark** Figures in parentheses apply to operation with fw = 10 MHz, fw = fx (X1 input clock oscillation frequency).

### (5) Automatic data transfer address point specification register 0 (ADTP0)

This is an 8-bit register used to specify the buffer RAM address that ends transfer during automatic data transfer (bit 6 (ATE0) of serial operation mode specification register 0 = 1).

This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting ADTP0 is prohibited.

In the 78K0/KF1 Series, 00H to 1FH can be specified because 32 bytes of buffer RAM are incorporated.

#### Example When ADTP0 is set to 07H

8 bytes of 00H to 07H are transferred.

In repeat transfer mode (bit 5 (ATM0) of CSIMA0 = 1), transfer is performed repeatedly up to the address value set in ADTP0.

**Example** When 07H is transferred to ADTP0 (repeat transfer mode) Transfer is repeated as 00H to 07H, 00H to 07H, ....

### Figure 17-7. Format of Automatic Data Transfer Address Point Specification Register 0 (ADTP0)

Address: FF94H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |
|--------|---|---|---|--------|--------|--------|--------|--------|
| ADTP0  | 0 | 0 | 0 | ADTP04 | ADTP03 | ADTP02 | ADTP01 | ADTP00 |

Caution Be sure to set bits 7 to 5 to 0.

The relationship between buffer RAM address values and ADTP0 setting values is shown below.

| Buffer RAM Address Value | ADTP0 Setting Value | Buffer RAM Address Value | ADTP0 Setting Value |
|--------------------------|---------------------|--------------------------|---------------------|
| FA00H                    | 00H                 | FA10H                    | 10H                 |
| FA01H                    | 01H                 | FA11H                    | 11H                 |
| FA02H                    | 02H                 | FA12H                    | 12H                 |
| FA03H                    | 03H                 | FA13H                    | 13H                 |
| FA04H                    | 04H                 | FA14H                    | 14H                 |
| FA05H                    | 05H                 | FA15H                    | 15H                 |
| FA06H                    | 06H                 | FA16H                    | 16H                 |
| FA07H                    | 07H                 | FA17H                    | 17H                 |
| FA08H                    | 08H                 | FA18H                    | 18H                 |
| FA09H                    | 09H                 | FA19H                    | 19H                 |
| FA0AH                    | 0AH                 | FA1AH                    | 1AH                 |
| FA0BH                    | 0BH                 | FA1BH                    | 1BH                 |
| FA0CH                    | 0CH                 | FA1CH                    | 1CH                 |
| FA0DH                    | 0DH                 | FA1DH                    | 1DH                 |
| FA0EH                    | 0EH                 | FA1EH                    | 1EH                 |
| FA0FH                    | 0FH                 | FA1FH                    | 1FH                 |

## Table 17-2. Relationship Between Buffer RAM Address Values and ADTP0 Setting Values

#### (6) Automatic data transfer interval specification register 0 (ADTI0)

This is an 8-bit register used to specify the interval period between 1-byte transfers during automatic data transfer (bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) = 1).

Set this register when in master mode (bit 4 (MASTER0) of CSIMA0 = 1) (setting is unnecessary in slave mode). Setting in 1-byte transfer mode (bit 6 (ATE0) of CSIMA0 = 0) is also valid. When the interval time specified by ADTI0 after the end of 1-byte transfer has elapsed, an interrupt request signal (INTACSI) is output. The number of clocks for the interval can be set to between 0 and 63 clocks.

The specified interval time is the transfer clock (specified by divisor selection register 0 (BRGCA0)) multiplied by an integer value.

#### Example When ADTI0 = 03H



This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting ADTI0 is prohibited.

#### Figure 17-8. Format of Automatic Data Transfer Interval Specification Register 0 (ADTI0)

| Address: FF95 | 5H After rese | et: 00H R/W |        |        |        |        |        |        |
|---------------|---------------|-------------|--------|--------|--------|--------|--------|--------|
| Symbol        | 7             | 6           | 5      | 4      | 3      | 2      | 1      | 0      |
| ADTI0         | 0             | 0           | ADTI05 | ADTI04 | ADTI03 | ADTI02 | ADTI01 | ADTI00 |

Caution Because the setting of bit 5 (STBE0) and bit 4 (BUSYE0) of serial status register 0 (CSIS0) takes priority over the ADTI0 setting, the interval time based on the setting of STBE0 and BUSYE0 is generated even when ADTI0 is set to 00H.

Example <1> When STBE = 1, BUSYE = 0: Interval time of two transfer clocks is generated <2> When STBE = 0, BUSYE = 1: Interval time of one transfer clock is generated <3> When STBE = 1, BUSYE = 1: Interval time of two transfer clocks is generated

Therefore, setting STBE0 and BUSYE0 to 0 is required to perform no-wait transfer.

## 17.4 Operation of Serial Interface CSIA0

Serial interface CSIA0 can be used in the following three modes.

- Operation stop mode
- 3-wire serial I/O mode
- 3-wire serial I/O mode with automatic transmit/receive function

#### 17.4.1 Operation stop mode

Serial transfer is not executed in this mode. Therefore, the power consumption can be reduced. In addition, the P142/SCKA0, P143/SIA0, and P144/SOA0 pins can be used as ordinary I/O port pins in this mode.

## (1) Register setting

The operation stop mode is set by serial operation mode specification register 0 (CSIMA0).

#### (a) Serial operation mode specification register 0 (CSIMA0)

This is an 8-bit register used to control the serial transfer operation. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

Address: FF90H After reset: 00H R/W

CSIMA0

|      | 7      | 6    | 5    | 4       | 3     | 2     | 1    | 0 |
|------|--------|------|------|---------|-------|-------|------|---|
| IMA0 | CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | Control of CSIA0 operation enable/disable                     |
|--------|---------------------------------------------------------------|
| 0      | CSIA0 operation disabled (SOA0: Low level, SCKA0: High level) |
| 1      | CSIA0 operation enabled                                       |

#### 17.4.2 3-wire serial I/O mode

The one-byte data transmission/reception is executed in the mode in which bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) is set to 0.

The 3-wire serial I/O mode is useful for connecting peripheral I/Os and display controllers having a conventional clocked serial interface, such as the 75XL Series, 78K Series, and 17K Series.

In this mode, communication is executed by using three lines: serial clock (SCKA0), serial output (SOA0), and serial input (SIA0) lines.

### (1) Register setting

Serial interface CSIA0 is controlled by the following three registers.

- Serial operation mode specification register 0 (CSIMA0)
- Serial status register 0 (CSIS0)
- Divisor selection register 0 (BRGCA0)

#### (a) Serial operation mode specification register 0 (CSIMA0)

This is an 8-bit register used to control the serial transfer operation. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

Address: FF90H After reset: 00H R/W

| Symbol | 7      | 6    | 5    | 4       | 3     | 2     | 1    | 0 |
|--------|--------|------|------|---------|-------|-------|------|---|
| CSIMA0 | CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | Control of CSIA0 operation enable/disable                     |  |  |  |  |  |  |
|--------|---------------------------------------------------------------|--|--|--|--|--|--|
| 0      | CSIA0 operation disabled (SOA0: Low level, SCKA0: High level) |  |  |  |  |  |  |
| 1      | CSIA0 operation enabled                                       |  |  |  |  |  |  |

| ATE0 | Control of automatic transfer operation enable/disable |
|------|--------------------------------------------------------|
| 0    | 1-byte transfer mode                                   |
| 1    | Automatic transfer mode                                |

| ATM0 | Automatic transfer mode specification                                                                 |  |  |  |  |  |  |
|------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0    | Single transfer mode (stops at the address specified by the ADTP0 register)                           |  |  |  |  |  |  |
| 1    | Repeat transfer mode (after transfer is complete, clear the ADTC0 register to 00H to resume transfer) |  |  |  |  |  |  |

| MASTER0 | CSIA0 master/slave mode specification           |  |  |  |  |  |
|---------|-------------------------------------------------|--|--|--|--|--|
| 0       | Slave mode (synchronous with SCKA0 input clock) |  |  |  |  |  |
| 1       | Master mode (synchronous with internal clock)   |  |  |  |  |  |

| TXEA0 | Control of transmit operation enable/disable  |  |  |  |  |  |  |
|-------|-----------------------------------------------|--|--|--|--|--|--|
| 0     | Transmit operation disabled (SOA0: Low level) |  |  |  |  |  |  |
| 1     | Transmit operation enabled                    |  |  |  |  |  |  |

| RXEA0 | Control of receive operation enable/disable |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|
| 0     | Receive operation disabled                  |  |  |  |  |
| 1     | Receive operation enabled                   |  |  |  |  |

| DIR0 | First bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

Cautions 1. When CSIAE0 = 0, the buffer RAM cannot be accessed.

- 2. When CSIAE0 is changed from 1 to 0, all the registers of the CSIA0 unit are initialized asynchronously. To set CSIAE0 = 1 again, be sure to re-set the registers of the CSIA0 unit.
- 3. When CSIAE0 is re-set to 1 after CSIAE0 is changed from 1 to 0, it is not guaranteed that the value of the buffer RAM will be retained.

### (b) Serial status register 0 (CSIS0)

This is an 8-bit register used to select the input clock and to control the transfer operation of CSIA0. This register can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets this register to 00H. However, rewriting CSIS0 is prohibited when bit 0 (TSF0) is 1.

### Address: FF91H After reset: 00H R/WNote 1

| Symbol | 7 | 6 | 5     | 4      | 3       | 2     | 1     | 0    |
|--------|---|---|-------|--------|---------|-------|-------|------|
| CSIS0  | 0 | 0 | STBE0 | BUSYE0 | BUSYLV0 | ERRE0 | ERRF0 | TSF0 |

| STBE0 <sup>Notes 2, 3</sup> | Strobe output enable/disable |
|-----------------------------|------------------------------|
| 0                           | Strobe output disabled       |
| 1                           | Strobe output enabled        |

| BUSYE0 | Busy signal detection enable/disable                                       |  |  |  |  |  |
|--------|----------------------------------------------------------------------------|--|--|--|--|--|
| 0      | y signal detection disabled (input via BUSY0 pin is ignored)               |  |  |  |  |  |
| 1      | Busy signal detection enabled and transfer wait by busy signal is executed |  |  |  |  |  |

| BUSYLV0 <sup>Note 4</sup> | Busy signal active level setting |
|---------------------------|----------------------------------|
| 0                         | Low level                        |
| 1                         | High level                       |

#### Notes 1. Bits 0 and 1 are read-only.

- 2. STBE0 is valid only in master mode. In slave mode, 1-byte transfer ends after eight transfer clocks regardless of the STBE0 set value.
- 3. When STBE0 is set to 1, two transfer clocks are consumed between byte transfers regardless of the setting of automatic data transfer interval specification register 0 (ADTI0). That is, 10 transfer clocks are used for 1-byte transfer even if ADTI0 = 00H is set.
- 4. In bit error detection by busy input, the active level specified by BUSYLV0 is detected.

#### Caution Be sure to set bits 6 and 7 to 0.

| ERRE0 <sup>Note</sup> | Bit error detection enable/disable |  |  |  |  |
|-----------------------|------------------------------------|--|--|--|--|
| 0                     | Error detection disabled           |  |  |  |  |
| 1                     | Error detection enabled            |  |  |  |  |

| ERRF0 | Bit error detection flag                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | <ul> <li>Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0</li> <li>At reset input</li> <li>When transfer is started by setting bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) to 1 or writing to SIOA0.</li> </ul> |
| 1     | Bit error detected (when ERRE0 = 1, the level specified by BUSYLV0 during the data bit transfer period is detected via BUSY0 pin input).                                                                                                             |
| TSEO  | Transfer status detection flog                                                                                                                                                                                                                       |

| TSF0 | Transfer status detection flag                                                               |  |  |  |  |  |
|------|----------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0    | Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0                |  |  |  |  |  |
|      | At reset input                                                                               |  |  |  |  |  |
|      | At the end of the specified transfer                                                         |  |  |  |  |  |
|      | When transfer is stopped by setting bit 1 (ATSTP0) of serial trigger register 0 (CSIT0) to 1 |  |  |  |  |  |
| 1    | From the transfer start to the end of the specified transfer                                 |  |  |  |  |  |

**Note** The ERRE0 setting is valid even when BUSYE0 = 0.

Caution When TSF0 is 1, rewriting serial operation mode specification register 0 (CSIMA0), serial status register 0 (CSIS0), divisor selection register 0 (BRGCA0), automatic data transfer address point specification register 0 (ADTP0), automatic data transfer interval specification register 0 (ADTI0), and serial I/O shift register 0 (SIOA0) are prohibited. However, these registers can be read and re-written to the same value. In addition, the buffer RAM can be rewritten during transfer.

## (c) Divisor selection register 0 (BRGCA0)

This is an 8-bit register used to control the serial transfer speed (divisor of CSIA input clock). This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting BRGCA0 is prohibited.

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|--------|---|---|---|---|---|---|---------|---------|
| BRGCA0 | 0 | 0 | 0 | 0 | 0 | 0 | BRGCA01 | BRGCA00 |

| BRGCA01 | BRGCA00 | CSIA0 input clock (fw) division ratio selection |
|---------|---------|-------------------------------------------------|
| 0       | 0       | fw/6 (1.67 MHz)                                 |
| 0       | 1       | fw/2 <sup>3</sup> (1.25 MHz)                    |
| 1       | 0       | fw/2 <sup>4</sup> (625 kHz)                     |
| 1       | 1       | fw/2 <sup>5</sup> (312.5 kHz)                   |

**Remark** Figures in parentheses apply to operation with fw = 10 MHz, fw = fx (X1 input clock oscillation frequency)

#### The relationship between register settings and pins is shown below.

| CSIAE0 | MASTER0 | PM143               | P143                | PM144               | P144                | PM142               | P142                | Serial I/O<br>Shift Register 0<br>Operation | Serial Clock<br>Counter<br>Operation Control | SIA0/P143<br>Pin Function         | SOA0/P144<br>Pin Function | SCKA0/P142<br>Pin Function |
|--------|---------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------------------------------|----------------------------------------------|-----------------------------------|---------------------------|----------------------------|
| 0      | ×       | × <sup>Note 1</sup> | Operation<br>stopped                        | Clear                                        | P143<br>(CMOS I/O)                | P144<br>(CMOS I/O)        | P142<br>(CMOS I/O)         |
| 1      | 0       | 1 <sup>Note 2</sup> | × <sup>Note 2</sup> | 0                   | 0                   | 1                   | ×                   | Operation<br>enabled                        | Count operation                              | SIA0 <sup>Note 2</sup><br>(Input) | SOA0<br>(CMOS output)     | SCKA0<br>(Input)           |
|        | 1       |                     |                     |                     |                     | 0                   | 1                   |                                             |                                              |                                   |                           | SCKA0<br>(CMOS output)     |

**Notes** 1. Can be used freely as port function.

2. Can be used as P143 (CMOS I/O) when only transmission is performed (clear bit 2 (RXEA0) of CSIMA0 to 0).

| Remark | ×:       | Don't care                                                       |
|--------|----------|------------------------------------------------------------------|
|        | CSIAE0:  | Bit 7 of serial operation mode specification register 0 (CSIMA0) |
|        | MASTER0: | Bit 4 of CSIMA0                                                  |
|        | PM××:    | Port mode register                                               |
|        | P××:     | Port output latch                                                |

### (3) 1-byte transmission/reception communication operation

### (a) 1-byte transmission/reception

When bit 7 (CSIAE0) and bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) = 1, 0, respectively, if transfer data is written to serial I/O shift register 0 (SIOA0), the data is output via the SOA0 pin in synchronization with the serial clock falling edge, and then input via the SIA0 pin in synchronization with serial clock falling edge, and stored in the SIOA0 register in synchronization with the rising edge 1 clock later.

Data transmission and data reception can be performed simultaneously.

If only reception is to be performed, transfer can only be started by writing a dummy value to the SIOA0 register.

When transfer of 1 byte is complete, an interrupt request signal (INTACSI) is generated.

In 1-byte transmission/reception, the setting of bit 5 (ATM0) of CSIMA0 is invalid.

Be sure to read data after confirming that bit 0 (TSF0) of serial status register 0 (CSIS0) = 0.



Figure 17-9. 3-Wire Serial I/O Mode Timing

Caution The SOA0 pin becomes low level by an SIOA0 write.

## (b) Data format

SOA0

DI0

DI1

DI2

In the data format, data is changed in synchronization with the SCKA0 falling edge as shown below. The data length is fixed to 8 bits and the data transfer direction can be switched by the specification of bit 1 (DIR0) of serial operation mode specification register 0 (CSIMA0).

## Figure 17-10. Format of Transmit/Receive Data



DI3

DI4

DI5

DI6

DI7

### (c) Switching MSB/LSB as start bit

Figure 17-11 shows the configuration of serial I/O shift register 0 (SIOA0) and the internal bus. As shown in the figure, MSB/LSB can be read/written in reverse form.

Switching MSB/LSB as the start bit can be specified using bit 1 (DIR0) of serial operation mode specification register 0 (CSIMA0).





Start bit switching is realized by switching the bit order for data written to SIOA0. The SIOA0 shift order remains unchanged.

Thus, switching between MSB-first and LSB-first must be performed before writing data to the shift register.

#### (d) Transfer start

Serial transfer is started by setting transfer data to serial I/O shift register 0 (SIOA0) when the following two conditions are satisfied.

- Serial interface CSIA0 operation control bit (CSIAE0) = 1
- Internal serial clock is stopped or SCKA0 is high level after 8-bit serial transfer.

#### Caution If CSIAE0 is set to 1 after data is written to SIOA0, transfer does not start.

Upon termination of 8-bit transfer, serial transfer automatically stops and the interrupt request flag (ACSIIF) is set.

#### 17.4.3 3-wire serial I/O mode with automatic transmit/receive function

Up to 32 bytes of data can be transmitted/received without using software in the mode in which bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) is set to 1. After transfer is started, only data of the set number of bytes stored in RAM in advance can be transmitted, and only data of the set number of bytes can be received and stored in RAM.

In addition, to transmit/receive data continuously, handshake signals (STB0 and BUSY0) generated by hardware are supported. Therefore, connection to peripheral LSIs such as OSD (On Screen Display) LSIs and LCD controller/drivers can be easily realized.

## (1) Register setting

Serial interface CSIA0 is controlled by the following six registers.

- Serial operation mode specification register 0 (CSIMA0)
- Serial status register 0 (CSIS0)
- Serial trigger register 0 (CSIT0)
- Divisor selection register 0 (BRGCA0)
- Automatic data transfer address point specification register 0 (ADTP0)
- Automatic data transfer interval specification register 0 (ADTI0)

#### (a) Serial operation mode specification register 0 (CSIMA0)

This is an 8-bit register used to control the serial transfer operation. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

Address: FF90H After reset: 00H R/W

| Symbol | 7      | 6    | 5    | 4       | 3     | 2     | 1    | 0 |
|--------|--------|------|------|---------|-------|-------|------|---|
| CSIMA0 | CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | Control of CSIA0 operation enable/disable                     |
|--------|---------------------------------------------------------------|
| 0      | CSIA0 operation disabled (SOA0: Low level, SCKA0: High level) |
| 1      | CSIA0 operation enabled                                       |

| ATE0 | Control of automatic transfer operation enable/disable |
|------|--------------------------------------------------------|
| 0    | 1-byte transfer mode                                   |
| 1    | Automatic transfer mode                                |

| ATM0 | Automatic transfer mode specification                                                                 |
|------|-------------------------------------------------------------------------------------------------------|
| 0    | Single transfer mode (stops at the address specified by the ADTP0 register)                           |
| 1    | Repeat transfer mode (after transfer is complete, clear the ADTC0 register to 00H to resume transfer) |

| MASTER0 | CSIA0 master/slave mode specification           |
|---------|-------------------------------------------------|
| 0       | Slave mode (synchronous with SCKA0 input clock) |
| 1       | Master mode (synchronous with internal clock)   |

| TXEA0 | Control of transmit operation enable/disable  |
|-------|-----------------------------------------------|
| 0     | Transmit operation disabled (SOA0: Low level) |
| 1     | Transmit operation enabled                    |

| RXEA0 | Control of receive operation enable/disable |
|-------|---------------------------------------------|
| 0     | Receive operation disabled                  |
| 1     | Receive operation enabled                   |

| DIR0 | First bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

Cautions 1. When CSIAE0 = 0, the buffer RAM cannot be accessed.

- 2. When CSIAE0 is changed from 1 to 0, all the registers of the CSIA0 unit are initialized asynchronously. To set CSIAE0 = 1 again, be sure to re-set the registers of the CSIA0 unit.
- 3. When CSIAE0 is re-set to 1 after CSIAE0 is changed from 1 to 0, it is not guaranteed that the value of the buffer RAM will be retained.

### (b) Serial status register 0 (CSIS0)

This is an 8-bit register used to select the input clock and to control the transfer operation of CSIA0. This register can be set by a 1-bit or 8-bit memory manipulation instruction.

RESET input sets this register to 00H. However, rewriting CSIS0 is prohibited when bit 0 (TSF0) is 1.

## Address: FF91H After reset: 00H R/WNote 1

| Symbol | 7 | 6 | 5     | 4      | 3       | 2     | 1     | 0    |
|--------|---|---|-------|--------|---------|-------|-------|------|
| CSIS0  | 0 | 0 | STBE0 | BUSYE0 | BUSYLV0 | ERRE0 | ERRF0 | TSF0 |

| STBE0 <sup>Notes 2, 3</sup> | Strobe output enable/disable |
|-----------------------------|------------------------------|
| 0                           | Strobe output disabled       |
| 1                           | Strobe output enabled        |

| BUSYE0 | Busy signal detection enable/disable                                       |
|--------|----------------------------------------------------------------------------|
| 0      | Busy signal detection disabled (input via BUSY0 pin is ignored)            |
| 1      | Busy signal detection enabled and transfer wait by busy signal is executed |

| BUSYLV0 <sup>Note 4</sup> | Busy signal active level setting |
|---------------------------|----------------------------------|
| 0                         | Low level                        |
| 1                         | High level                       |

### Notes 1. Bits 0 and 1 are read-only.

- 2. STBE0 is valid only in master mode. In slave mode, 1-byte transfer ends after eight transfer clocks regardless of the STBE0 set value.
- 3. When STBE0 is set to 1, two transfer clocks are consumed between byte transfers regardless of the setting of automatic data transfer interval specification register 0 (ADTI0). That is, 10 transfer clocks are used for 1-byte transfer even if ADTI0 = 00H is set.
- 4. In bit error detection by busy input, the active level specified by BUSYLV0 is detected.

### Caution Be sure to set bits 6 and 7 to 0.

| ERRE0 <sup>Note</sup> | Bit error detection enable/disable |
|-----------------------|------------------------------------|
| 0                     | Error detection disabled           |
| 1                     | Error detection enabled            |

| ERRF0 | Bit error detection flag                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | <ul> <li>Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0</li> <li>At reset input</li> <li>When transfer is started by setting bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) to 1 or writing to SIOA0.</li> </ul> |
| 1     | Bit error detected (when ERRE0 = 1, the level specified by BUSYLV0 during the data bit transfer period is detected via BUSY0 pin input).                                                                                                             |
| TSEO  | Transfer status detection flog                                                                                                                                                                                                                       |

| TSF0 | Transfer status detection flag                                                               |
|------|----------------------------------------------------------------------------------------------|
| 0    | • Bit 7 (CSIAE0) of serial operation mode specification register 0 (CSIMA0) = 0              |
|      | At reset input                                                                               |
|      | At the end of the specified transfer                                                         |
|      | When transfer is stopped by setting bit 1 (ATSTP0) of serial trigger register 0 (CSIT0) to 1 |
| 1    | From the transfer start to the end of the specified transfer                                 |

**Note** The ERRE0 setting is valid even when BUSYE0 = 0.

Caution When TSF0 is 1, rewriting serial operation mode specification register 0 (CSIMA0), serial status register 0 (CSIS0), divisor selection register 0 (BRGCA0), automatic data transfer address point specification register 0 (ADTP0), automatic data transfer interval specification register 0 (ADTI0), and serial I/O shift register 0 (SIOA0) are prohibited. However, these registers can be read and re-written to the same value. In addition, the buffer RAM can be rewritten during transfer.

### (c) Serial trigger register 0 (CSIT0)

This is an 8-bit register used to control execution/stop of automatic data transfer. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H. However, manipulate only when bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) is 1 (manipulation prohibited when ATE0 = 0).

#### Address: FF92H After reset: 00H R/W



- Cautions 1. Even if ATSTP0 or ATSTA0 is set to 1, automatic transfer cannot be started/stopped until 1byte transfer is complete.
  - 2. ATSTP0 and ATSTA0 retain 1 until immediately before the interrupt signal INTACSI is generated, and then change to 0 automatically.
  - 3. After automatic data transfer is stopped, the data address when the transfer stopped is stored in automatic data transfer address count register 0 (ADTC0). However, since no function to restart automatic data transfer is incorporated, when transfer is stopped by setting ATSTP0 = 1, start automatic data transfer by ATSTA0 after re-setting the registers.

#### (d) Divisor selection register 0 (BRGCA0)

This is an 8-bit register used to control the serial transfer speed (divisor of CSIA input clock). This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting BRGCA0 is prohibited.

| Symbol | 7       | 6       | 5                          | 4          | 3               | 2                | 1        | 0       |
|--------|---------|---------|----------------------------|------------|-----------------|------------------|----------|---------|
| BRGCA0 | 0       | 0       | 0                          | 0          | 0               | 0                | BRGCA01  | BRGCA00 |
|        |         |         | _                          |            |                 |                  |          |         |
|        | BRGCA01 | BRGCA00 |                            | CSIA0 i    | nput clock (fw) | division ratio s | election |         |
|        | 0       | 0       | fw/6 (1.67 MH              | z)         |                 |                  |          |         |
|        | 0       | 1       | fw/2 <sup>3</sup> (1.25 MH | Hz)        |                 |                  |          |         |
|        | 1       | 0       | fw/2 <sup>4</sup> (625 kHz | <u>z</u> ) |                 |                  |          |         |
|        | 1       | 1       | fw/2⁵ (312.5 kl            | Hz)        |                 |                  |          |         |

Address: FF93H After reset: 03H R/W

**Remark** Figures in parentheses apply to operation with fw = 10 MHz, fw = fx (X1 input clock oscillation frequency)

#### (e) Automatic data transfer address point specification register 0 (ADTP0)

This is an 8-bit register used to specify the buffer RAM address that ends transfer during automatic data transfer (bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) = 1).

This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting ADTP0 is prohibited.

In the 78K0/KF1 Series, 00H to 1FH can be specified because 32 bytes of buffer RAM are incorporated.

**Example** When ADTP0 is set to 07H

8 bytes of 00H to 07H are transferred.

In repeat transfer mode (bit 5 (ATM0) of CSIMA0 = 1), transfer is performed repeatedly up to the address value set in ADTP0.

**Example** When 07H is transferred to ADTP0 (repeat transfer mode) Transfer is repeated as 00H to 07H, 00H to 07H, ....

Address: FF94H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |
|--------|---|---|---|--------|--------|--------|--------|--------|
| ADTP0  | 0 | 0 | 0 | ADTP04 | ADTP03 | ADTP02 | ADTP01 | ADTP00 |

## Caution Be sure to set bits 7 to 5 to 0.

The relationship between buffer RAM address values and ADTP0 setting values is shown below.

| Buffer RAM Address Value | ADTP0 Setting Value | Buffer RAM Address Value | ADTP0 Setting Value |
|--------------------------|---------------------|--------------------------|---------------------|
| FA00H                    | 00H                 | FA10H                    | 10H                 |
| FA01H                    | 01H                 | FA11H                    | 11H                 |
| FA02H                    | 02H                 | FA12H                    | 12H                 |
| FA03H                    | 03H                 | FA13H                    | 13H                 |
| FA04H                    | 04H                 | FA14H                    | 14H                 |
| FA05H                    | 05H                 | FA15H                    | 15H                 |
| FA06H                    | 06H                 | FA16H                    | 16H                 |
| FA07H                    | 07H                 | FA17H                    | 17H                 |
| FA08H                    | 08H                 | FA18H                    | 18H                 |
| FA09H                    | 09H                 | FA19H                    | 19H                 |
| FA0AH                    | 0AH                 | FA1AH                    | 1AH                 |
| FA0BH                    | 0BH                 | FA1BH                    | 1BH                 |
| FA0CH                    | 0CH                 | FA1CH                    | 1CH                 |
| FA0DH                    | 0DH                 | FA1DH                    | 1DH                 |
| FA0EH                    | 0EH                 | FA1EH                    | 1EH                 |
| FA0FH                    | 0FH                 | FA1FH                    | 1FH                 |

### (f) Automatic data transfer interval specification register 0 (ADTI0)

This is an 8-bit register used to specify the interval period between 1-byte transfers during automatic data transfer (bit 6 (ATE0) of serial operation mode specification register 0 (CSIMA0) = 1).

Set this register when in master mode (bit 4 (MASTER0) of CSIMA0 = 1) (setting is unnecessary in slave mode). Setting in 1-byte transfer mode (bit 6 (ATE0) of CSIMA0 = 0) is also valid. When the interval time specified by ADTI0 after the end of 1-byte transfer has elapsed, an interrupt request signal (INTACSI) is output. The number of clocks for the interval can be set to between 0 an 63 clocks.

The specified interval time is the transfer clock (specified by divisor selection register 0 (BRGCA0)) multiplied by an integer value.

Example When ADTI0 = 03H



This register can be set by an 8-bit memory manipulation instruction. However, when bit 0 (TSF0) of serial status register 0 (CSIS0) is 1, rewriting ADTI0 is prohibited.

#### Address: FF95H After reset: 00H R/W

| Symbol | 7 | 6 | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|---|---|--------|--------|--------|--------|--------|--------|
| ADTI0  | 0 | 0 | ADTI05 | ADTI04 | ADTI03 | ADTI02 | ADTI01 | ADTI00 |

- Caution Because the setting of bit 5 (STBE0) and bit 4 (BUSYE0) of serial status register 0 (CSIS0) takes priority over the ADTI0 setting, the interval time based on the setting of STBE0 and BUSYE0 is generated even when ADTI0 is set to 00H.
  - Example <1> When STBE = 1, BUSYE = 0: Interval time of two transfer clocks is generated
    - <2> When STBE = 0, BUSYE = 1: Interval time of one transfer clock is generated
    - <3> When STBE = 1, BUSYE = 1: Interval time of two transfer clocks is generated

Therefore, setting STBE0 and BUSYE0 to 0 is required to perform no-wait transfer.

#### (3) Automatic transmit/receive data setting

#### (a) Transmit data setting

- <1> Write transmit data from the least significant address FA00H of buffer RAM (up to FA1FH at maximum). The transmit data should be in the order from lower address to higher address.
- <2> Set the automatic data transfer address point specification register 0 (ADTP0) to the value obtained by subtracting 1 from the number of transmit data bytes.

#### (b) Automatic transmission/reception mode setting

- <1> Set CSIAE0 and ATE0 of serial operating mode specification register 0 (CSIMA0) to 1.
- <2> Set RXEA0 and TXEA0 of CSIMA0 to 1.
- <3> Set a data transfer interval in automatic data transfer interval specification register 0 (ADTI0).
- <4> Set bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) to 1.

The following operations are automatically carried out when (a) and (b) are carried out.

- After the buffer RAM data indicated by automatic data transfer address count register 0 (ADTC0) is transferred to SIOA0, transmission is carried out (start of automatic transmission/reception).
- The received data is written to the buffer RAM address indicated by ADTC0.
- ADTC0 is incremented and the next data transmission/reception is carried out. Data transmission/reception continues until the ADTC0 incremental output matches the set value of automatic data transfer address point specification register 0 (ADTP0) (end of automatic transmission/reception). However, if bit 5 (ATM0) of CSIMA0 is set to 1 (repeat mode), ADTC0 is cleared after a match between ADTP0 and ADTC0, and then repeated transmission/reception is started.
- When automatic transmission/reception is terminated, TSF0 is cleared to 0.

#### (4) Automatic transmission/reception communication operation

#### (a) Automatic transmission/reception mode

Automatic transmission/reception can be performed using buffer RAM.

The data stored in the buffer RAM is output from the SOA0 pin via the SIOA0 register in synchronization with the serial clock falling edge by performing (a) and (b) in (3) Automatic transmit/receive data setting.

The data is then input from the SIA0 pin via the SIOA0 register in synchronization with the serial clock falling edge and the receive data is stored in the buffer RAM in synchronization with the rising edge 1 clock later.

Data transfer ends if bit 0 (TSF0) of serial status register 0 (CSIS0) is set to 1 when any of the following conditions is met.

- Reset by setting bit 7 (CSIAE0) of the CSIMA0 register to 0
- Transfer of 1 byte is complete by setting bit 1 (ATSTP0) of the CSIT0 register to 1
- Transfer of 1 byte is complete when bit 1 (ERRF0) of the CSIS0 register becomes 1 while bit 2 (ERRE0) = 1
- Transfer of the range specified by the ADTP0 register is complete

At this time, an interrupt request signal (INTACSI) is generated except when the CSIAE0 bit = 0.

If a transfer is terminated in the middle, transfer starting from the remaining data is not possible. Read automatic data transfer address count register 0 (ADTC0) to confirm how much of the data has already been transferred, set the transfer data again, and then re-execute transfer.

In addition, when busy control and strobe control are not performed, the BUSY0/BUZ/INTP7/P141 and STB0/P145 pins can be used as ordinary I/O port pins.

Figure 17-12 shows the operation timing in automatic transmission/reception mode and Figure 17-13 shows the operation flowchart. Figure 17-14 shows the operation of internal buffer RAM when 6 bytes of data are transmitted/received.





- Cautions 1. Because, in the automatic transmission/reception mode, the automatic transmit/receive function writes/reads data to/from the internal buffer RAM after 1byte transmission/reception, an interval is inserted until the next transmission/reception. As the buffer RAM write/read is performed at the same time as CPU processing, the interval is dependent upon the value of automatic data transfer interval specification register 0 (ADTI0) and the set values of bits 5 and 4 (STBE0, BUSYE0) of serial status register 0 (CSIS0) (see (6) Automatic transmit/receive interval time).
  - 2. When TSF0 is cleared, the SOA0 pin becomes low level.

Remark ACSIIF: Interrupt request flag TSF0: Bit 0 of serial status register 0 (CSIS0)



Figure 17-13. Automatic Transmission/Reception Mode Flowchart

| ADTP0:  | Automatic data transfer address point specification register 0 |
|---------|----------------------------------------------------------------|
| ADTI0:  | Automatic data transfer interval specify register 0            |
| ATSTA0: | Bit 0 of serial trigger register 0 (CSIT0)                     |
| SIOA0:  | Serial I/O shift register 0                                    |

- ADTC0: Automatic data transfer address count register 0
- TSF0: Bit 0 of serial status register 0 (CSIS0)

In 6-byte transmission/reception (ATM0 = 0, RXEA0 = 1, TXEA0 = 1) in automatic transmission/reception mode, internal buffer RAM operates as follows.

#### (i) Before transmission/reception (see Figure 17-14 (a).)

When bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) is set to 1, transmit data 1 (T1) is transferred from the internal buffer RAM to SIOA0. When transmission of the first byte is completed, receive data 1 (R1) is transferred from SIOA0 to the buffer RAM, and automatic data transfer address count register 0 (ADTC0) is incremented. Then transmit data 2 (T2) is transferred from the internal buffer RAM to SIOA0.

#### (ii) 4th byte transmission/reception point (see Figure 17-14 (b).)

Transmission/reception of the third byte is completed, and transmit data 4 (T4) is transferred from the internal buffer RAM to SIOA0. When transmission of the fourth byte is completed, the receive data 4 (R4) is transferred from SIOA0 to the internal buffer RAM, and ADTC0 is incremented.

## (iii) Completion of transmission/reception (see Figure 17-14 (c).)

When transmission of the sixth byte is completed, receive data 6 (R6) is transferred from SIOA0 to the internal buffer RAM, and the interrupt request flag (ACSIIF) is set (INTACSI generation).

## Figure 17-14. Internal Buffer RAM Operation in 6-Byte Transmission/Reception (in Automatic Transmission/Reception Mode) (1/2)



#### (a) Before transmission/reception





(b) 4th byte transmission/reception



| FA1FH |                     |   |   |        |
|-------|---------------------|---|---|--------|
|       |                     |   |   |        |
| FA05H | Receive data 6 (R6) |   |   | SIOA0  |
|       | Receive data 5 (R5) | Г |   |        |
|       | Receive data 4 (R4) | L | 5 | ADTP0  |
|       | Receive data 3 (R3) | Г | 5 | ADTC0  |
|       | Receive data 2 (R2) | L |   |        |
| FA00H | Receive data 1 (R1) |   | 1 | ACSIIF |

### (b) Automatic transmission mode

In this mode, the specified number of 8-bit unit data are transmitted.

Serial transfer is started when bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) is set to 1 while bit 7 (CSIAE0), bit 6 (ATE0), and bit 3 (TXEA0) of serial operating mode specification register 0 (CSIMA0) are set to 1.

When the final byte has been transmitted, an interrupt request flag (ACSIIF) is set. However, judge the termination of automatic transmission and reception, not by ACSIIF but by bit 0 (TSF0) of serial status register 0 (CSIS0).

If a receive operation, busy control and strobe control are not executed, the BUSY0/BUZ/INTP7/P141 and STB0/P145 pins can be used as normal I/O port pins.

Figure 17-15 shows the automatic transmission mode operation timing, and Figure 17-16 shows the operation flowchart. Figure 17-17 shows the operation of the internal buffer RAM when 6 bytes of data are transmitted or received.





- Cautions 1. Because, in the automatic transmission mode, the automatic transmit/receive function reads data from the internal buffer RAM after 1-byte transmission, an interval is inserted until the next transmission. As the buffer RAM read is performed at the same time as CPU processing, the interval is dependent upon the value of automatic data transfer interval specification register 0 (ADTI0) and the set values of bits 5 and 4 (STBE0, BUSYE0) of serial status register 0 (CSIS0) (see (6) Automatic transmit/receive interval time).
  - 2. When TSF0 is cleared, the SOA0 pin becomes low level.

Remark ACSIIF: Interrupt request flag TSF0: Bit 0 of serial status register 0 (CSIS0)





| ADTP0:  | Automatic data transfer address point specification register 0 |
|---------|----------------------------------------------------------------|
| ADTI0:  | Automatic data transfer interval specification register 0      |
| ATSTA0: | Bit 0 of serial trigger register 0 (CSIT0)                     |
| SIOA0:  | Serial I/O shift register 0                                    |
| ADTC0:  | Automatic data transfer address count register 0               |
| TSF0:   | Bit 0 of serial status register 0 (CSIS0)                      |

In 6-byte transmission (ATM0 = 0, RXEA0 = 0, TXEA0 = 1, ATE0 = 1) in automatic transmission mode, internal buffer RAM operates as follows.

### (i) Before transmission (see Figure 17-17 (a).)

When bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) is set to 1, transmit data 1 (T1) is transferred from the internal buffer RAM to SIOA0. When transmission of the first byte is completed, automatic data transfer address count register 0 (ADTC0) is incremented. Then transmit data 2 (T2) is transferred from the internal buffer RAM to SIOA0.

### (ii) 4th byte transmission point (see Figure 17-17 (b).)

Transmission of the third byte is completed, and transmit data 4 (T4) is transferred from the internal buffer RAM to SIOA0. When transmission of the fourth byte is completed, ADTC0 is incremented.

### (iii) Completion of transmission (see Figure 17-17 (c).)

When transmission of the sixth byte is completed, the interrupt request flag (ACSIIF) is set (INTACSI generation).

# Figure 17-17. Internal Buffer RAM Operation in 6-Byte Transmission (in Automatic Transmission Mode) (1/2)



#### (a) Before transmission

# Figure 17-17. Internal Buffer RAM Operation in 6-Byte Transmission (in Automatic Transmission Mode) (2/2)



(b) 4th byte transmission point



| FA1FH |                      |   |        |
|-------|----------------------|---|--------|
|       | T                    |   |        |
| FA05H | Transmit data 6 (T6) |   | SIOA0  |
|       | Transmit data 5 (T5) |   | l      |
|       | Transmit data 4 (T4) | 5 | ADTP0  |
|       | Transmit data 3 (T3) | 5 | ADTC0  |
|       | Transmit data 2 (T2) |   |        |
| FA00H | Transmit data 1 (T1) | 1 | ACSIIF |

### (c) Repeat transmission mode

In this mode, data stored in the internal buffer RAM is transmitted repeatedly.

Serial transfer is started when bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) is set to 1 while bit 7 (CSIAE0), bit 6 (ATE0), bit 5 (ATM0), and bit 3 (TXEA0) of serial operating mode specification register 0 (CSIMA0) are set to 1.

Unlike the basic transmission mode, after the final byte (data in address FA1FH) has been transmitted, the interrupt request flag (ACSIIF) is not set, the automatic data transfer address count register 0 (ADTC0) is reset to 0, and the internal buffer RAM contents are transmitted again.

When a reception operation, busy control and strobe control are not performed, the BUSY0/BUZ/INTP7/P141 and STB0/P145 pins can be used as ordinary I/O port pins.

The repeat transmission mode operation timing is shown in Figure 17-18, and the operation flowchart in Figure 17-19. Figure 17-20 shows the operation of the internal buffer RAM when 6 bytes of data are transmitted in the repeat transmission mode.





Caution Because, in the repeat transmission mode, a read is performed on the buffer RAM after the transmission of one byte, the interval is included in the period up to the next transmission. As the buffer RAM read is performed at the same time as CPU processing, the interval is dependent upon automatic data transfer interval specification register 0 (ADTI0) and the set values of bits 5 and 4 (STBE0, BUSYE0) of serial status register 0 (CSIS0) (see (6) Automatic transmit/receive interval time).





| ADTP0:  | Automatic data transfer address point specification register 0 |
|---------|----------------------------------------------------------------|
| ADTI0:  | Automatic data transfer interval specification register 0      |
| ATSTA0: | Bit 0 of serial trigger register 0 (CSIT0)                     |
| SIOA0:  | Serial I/O shift register 0                                    |
| ADTC0:  | Automatic data transfer address count register 0               |

In 6-byte transmission (ATM0 = 1, RXEA0 = 0, TXEA0 = 1, ATE0 = 1) in repeat transmission mode, internal buffer RAM operates as follows.

### (i) Before transmission (see Figure 17-20 (a).)

When bit 0 (ATSTA0) of serial trigger register 0 (CSIT0) is set to 1, transmit data 1 (T1) is transferred from the internal buffer RAM to SIOA0. When transmission of the first byte is completed, automatic data transfer address count register 0 (ADTC0) is incremented. Then transmit data 2 (T2) is transferred from the internal buffer RAM to SIOA0.

### (ii) Upon completion of transmission of 6 bytes (see Figure 17-20 (b).)

When transmission of the sixth byte is completed, the interrupt request flag (ACSIIF) is not set. ADTC0 is reset to 0.

### (iii) 7th byte transmission point (see Figure 17-20 (c).)

Transmit data 1 (T1) is transferred from the internal buffer RAM to SIOA0 again. When transmission of the first byte is completed, ADTC0 is incremented. Then transmit data 2 (T2) is transferred from the internal buffer RAM to SIOA0.

# Figure 17-20. Internal Buffer RAM Operation in 6-Byte Transmission (in Repeat Transmission Mode) (1/2)



### (a) Before transmission

# Figure 17-20. Internal Buffer RAM Operation in 6-Byte Transmission (in Repeat Transmission Mode) (2/2)



# (b) Upon completion of transmission of 6 bytes





# (d) Data format

In the data format, data is changed in synchronization with the SCKA0 falling edge as shown below. The data length is fixed to 8 bits and the data transfer direction can be switched by the specification of bit 1 (DIR0) of serial operation mode specification register 0 (CSIMA0).







### (e) Automatic transmission/reception suspension and restart

Automatic transmission/reception can be temporarily suspended by setting bit 1 (ATSTP0) of serial trigger register 0 (CSIT0) to 1.

During 8-bit data transfer, the transmission/reception is not suspended. It is suspended upon completion of 8-bit data transfer.

When suspended, bit 0 (TSF0) of serial status register 0 (CSIS0) is set to 0 after transfer of the 8th bit, and all the port pins that function alternately as (P141/BUZ/BUSY0/INTP7, P142/SCKA0, P143/SIA0, P144/SOA0, and P145/STB0) are set to the port mode.

To restart automatic transmission/reception, set bit 0 (ATSTA0) of CSIT0 to 1. The remaining data can be transmitted in this way.

- Cautions 1. If the HALT instruction is executed during automatic transmission/reception, transfer is suspended and the HALT mode is set if during 8-bit data transfer. When the HALT mode is cleared, automatic transmission/reception is restarted from the suspended point.
  - 2. When suspending automatic transmission/reception, do not change the operating mode to 3-wire serial I/O mode while TSF0 = 1.





ATSTP0: Bit 1 of serial trigger register 0 (CSIT0) ATSTA0: Bit 0 of CSIT0

### (5) Synchronization control

Busy control and strobe control are functions used to synchronize transmission/reception between the master device and a slave device.

By using these functions, a shift in bits being transmitted or received can be detected.

### (a) Busy control option

Busy control is a function to keep the serial transmission/reception by the master device waiting while the busy signal output by a slave device to the master is active.

When using this busy control option, the following conditions must be satisfied.

- Bit 6 (ATE0) of serial operating mode specification register 0 (CSIMA0) is set to 1.
- Bit 4 (BUSYE0) of serial status register 0 (CSIS0) is set to 1.

Figure 17-23 shows the system configuration of the master device and slave device when the busy control option is used.





The master device inputs the busy signal output by the slave device to the BUSY0/BUZ/INTP7/P141 pin. The master device samples the input busy signal in synchronization with the falling of the serial clock. Even if the busy signal becomes active while 8-bit data is being transmitted or received, transmission/reception by the master is not kept waiting. If the busy signal is active at the rising edge of the serial clock one clock after completion of transmission/reception of the 8-bit data, the busy input becomes valid. After that, the master transmission/reception is kept waiting while the busy signal is active.

The active level of the busy signal is set by bit 3 (BUSYLV0) of CSIS0.

BUSYLV0 = 1: Active-high BUSYLV0 = 0: Active-low

When using the busy control option, select the internal clock as the serial clock. Control with the busy signal cannot be implemented with the external clock.

Figure 17-24 shows the operation timing when the busy control option is used.

Caution Busy control cannot be used simultaneously with the interval time control function of automatic data transfer interval specification register 0 (ADTI0). If used, busy control is invalid.



### Figure 17-24. Operation Timing When Busy Control Option Is Used (When BUSYLV0 = 1)

### Caution If the TSF0 is cleared, the SOA0 pin goes low.

# Remark ACSIIF: Interrupt request flag

TSF0: Bit 0 of serial status register 0 (CSIS0)

When the busy signal becomes inactive, waiting is released. If the sampled busy signal is inactive, transmission/reception of the next 8-bit data is started at the falling edge of the next serial clock.

Because the busy signal is asynchronous with the serial clock, it takes up to 1 clock until the busy signal is sampled, even if made inactive by the slave. It takes 0.5 clock until data transfer is started after the busy signal was sampled.

To accurately release waiting, the slave must keep the busy signal inactive at least for the duration of 1.5 clock.

Figure 17-25 shows the timing of the busy signal and releasing the waiting. This figure shows an example in which the busy signal is active as soon as transmission/reception has been started.





### (b) Busy & strobe control option

Strobe control is a function used to synchronize data transmission/reception between the master and slave devices. The master device outputs the strobe signal from the STB0/P145 pin when 8-bit transmission/reception has been completed. By this signal, the slave device can determine the timing of the end of data transmission. Therefore, synchronization is established even if a bit shift occurs because noise is superimposed on the serial clock, and transmission of the next byte is not affected by the bit shift.

To use the strobe control option, the following conditions must be satisfied:

- Bit 6 (ATE0) of the serial operating mode specification register 0 (CSIMA0) is set to 1.
- Bit 5 (STBE0) of serial status register 0 (CSIS0) is set to 1.

Usually, the busy control and strobe control options are simultaneously used as handshake signals. In this case, the strobe signal is output from the STB0/P145 pin, the BUSY0/BUZ/INTP7/P141 pin can be sampled to keep transmission/reception waiting while the busy signal is input.

A high level lasting for one transfer clock is output from the STB0/P145 pin in synchronization with the falling edge of the ninth serial clock as the strobe signal. The busy signal is detected at the rising edge of the serial clock two clocks after 8-bit data transmission/reception completion.

When the strobe control option is not used, the P145/STB0 pin can be used as a normal I/O port pin.

Figure 17-26 shows the operation timing when the busy & strobe control options are used.

When the strobe control option is used, the interrupt request flag (ACSIIF) that is set on completion of transmission/reception is set after the strobe signal is output.



| SCKA0  |                                                      |
|--------|------------------------------------------------------|
| SOA0   | XD7XD6XD5XD4XD3XD2XD1XD0 XD7XD6XD5XD4XD3XD2XD1XD0    |
| SIA0   |                                                      |
| STB0   |                                                      |
| BUSY0  |                                                      |
| ACSIIF |                                                      |
|        | Busy input released                                  |
| TSF0   | · · · · · · · · · · · · · · · · · · ·                |
|        | Caution When TSF0 is cleared, the SOA0 pin goes low. |

Remark ACSIIF: Interrupt request flag

TSF0: Bit 0 of serial status register 0 (CSIS0)

### (c) Bit shift detection by busy signal

During automatic transmission/reception, a bit shift of the serial clock of the slave device may occur because noise is superimposed on the serial clock signal output by the master device. Unless the strobe control option is used at this time, the bit shift affects transmission of the next byte. In this case, the master can detect the bit shift by checking the busy signal during transmission by using the busy control option.

A bit shift is detected by using the busy signal as follows:

The slave outputs the busy signal after the rising of the eighth serial clock during data transmission/reception (to not keep transmission/reception waiting by the busy signal at this time, make the busy signal inactive within 2 clocks).

The master samples the busy signal in synchronization with the falling edge of the serial clock if bit 2 (ERRE0) of serial status register 0 (CSIS0) is set to 1. If a bit shift does not occur, all the eight serial clocks that have been sampled are inactive. If the sampled serial clocks are active, it is assumed that a bit shift has occurred, error processing is executed (by setting bit 1 (ERRF0) of serial status register 0 (CSIS0) to 1, and transfer is suspended and an interrupt request signal (INTACSI) is output).

Although transfer is suspended after completion of 1-byte data transfer, slave signal output, wait due to the busy signal, and wait due to the interval time specified by ADTI0 are not executed.

If ERRE0 = 0, ERRF0 cannot become 1 even if a bit shift occurs.

Figure 17-27 shows the operation timing of the bit shift detection function by the busy signal.

**Remark** The bit error function is valid both in the master mode and slave mode. The setting of ERRE0 is valid even when BUSYE0 = 0.



# Figure 17-27. Operation Timing of Bit Shift Detection Function by Busy Signal (When BUSYLV0 = 0)

ERRF0: Bit 1 of serial status register 0 (CSIS0)

### (6) Automatic transmit/receive interval time

When using the automatic transmit/receive function, the read/write operations from/to the internal buffer RAM are performed after transmitting/receiving one byte. Therefore, an interval is inserted before the next transmit/receive operation.

Since the read/write operations from/to the buffer RAM are performed in parallel with the CPU processing when using the automatic transmit/receive function by the internal clock, the interval depends on the value which is set in the automatic data transfer interval specification register 0 (ADTI0) and bits 5 and 4 (STBE0, BUSYE0) of the serial status register 0 (CSIS0).

When ADTI0 is set to 00H, an interval time based on the to STBE0 and BUSYE0 settings is generated.

For example, when ADTI0 = 00H and STBE0 = BUSYE0 = 1, an interval time of two clocks is generated. If an interval time of two clocks or more is set by ADTI0, the interval time set by ADTI0 is generated regardless of the STBE0 and BUSYE0 settings.

**Example** <1> When STBE0 = 1, BUSYE0 = 0: Interval time of two transfer clocks is generated <2> When STBE0 = 0, BUSYE0 = 1: Interval time of one transfer clock is generated <3> When STBE0 = 1, BUSYE0 = 1: Interval time of two transfer clocks is generated







# CHAPTER 18 MULTIPLIER/DIVIDER

## 18.1 Functions of Multiplier/Divider

The multiplier/divider has the following functions.

- 16 bits  $\times$  16 bits = 32 bits (multiplication)
- 32 bits ÷ 16 bits = 32 bits, 16-bit remainder (division)

# 18.2 Configuration of Multiplier/Divider

The multiplier/divider consists of the following hardware.

# Table 18-1. Configuration of Multiplier/Divider

| Item             | Configuration                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers        | Remainder data register 0 (SDR0)<br>Multiplication/division data registers A0 (MDA0H, MDA0L)<br>Multiplication/division data registers B0 (MDB0) |
| Control register | Multiplier/divider control register 0 (DMUC0)                                                                                                    |

Figure 18-1 shows the block diagram of the multiplier/divider.

Figure 18-1. Block Diagram of Multiplier/Divider



CHAPTER 18 MULTIPLIER/DIVIDER

### (1) Remainder data register 0 (SDR0)

SDR0 is a 16-bit register that stores a remainder. This register stores 0 in the multiplication mode and the remainder of an operation result in the division mode.

This register can be read by an 8-bit or 16-bit memory manipulation instruction.

RESET input sets this register to 0000H.

### Figure 18-2. Format of Remainder Data Register 0 (SDR0)



# Cautions 1. The value read from SDR0 during operation processing (while bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is 1) is not guaranteed.

2. SDR0 is reset when the operation is started (when DMUE is set to 1).

### (2) Multiplication/division data register A0 (MDA0H, MDA0L)

MDA0 is a register that stores 16-bit multiplier A in the multiplication mode, and a 32-bit dividend in the division mode (higher 16 bits: MDA0H, lower 16 bits: MDA0L, MDA0H+MDA0L: MDA0). The functions of MDA0 when an operation is executed are shown in the table below.

| DMUSEL0 <sup>Note</sup> | Operation Mode      | Setting                                           | Operation Result                   |
|-------------------------|---------------------|---------------------------------------------------|------------------------------------|
| 0                       | Division mode       | Dividend                                          | Division result (quotient)         |
| 1                       | Multiplication mode | Higher 10 bits: 0, Lower 16<br>bits: Multiplier A | Multiplication result<br>(product) |

The register configuration differs between when multiplication is executed and when division is executed, as follows.

• Register configuration during multiplication

<Multiplier A> <Multiplier B> <Product>
MDA0 (bits 15 to 0)  $\times$  MDB0 (bits 15 to 0) = MDA0 (bits 31 to 0)

• Register configuration during division

| <dividend></dividend> | <divisor></divisor>  | <quotient></quotient>   | <remainder></remainder> |
|-----------------------|----------------------|-------------------------|-------------------------|
| MDA0 (bits 31 to 0) + | - MDB0 (bits 15 to 0 | ) = MDA0 (bits 31 to 0) | SDR0 (bits 15 to 0)     |

MDA0 fetches the calculation result as soon as the clock is input, when bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is set to 1.

MDA0H and MDA0L can be set by an 8-bit or 16-bit memory instruction.

RESET input sets this register to 0000H.



### Figure 18-3. Format of Multiplication/Division Data Register A0 (MDA0H, MDA0L)

- Cautions 1. MDA0H is reset to 0 when an operation is started in the multiplication mode (when multiplier/divider control register 0 (DMUC0) is set to 81H).
  - 2. Do not change the value of MDA0 during operation processing (while bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is 1). Even in this case, the operation is executed, but the result is undefined.
  - 3. The value read from MDA0 during operation processing (while DMUE is 1) is not guaranteed.

### (3) Multiplication/division data register B0 (MDB0)

MDB0 is a register that stores a 16-bit multiplier B in the multiplication mode and a 16-bit divisor in the division mode.

This register can be set by an 8-bit or 16-bit memory manipulation instruction.

RESET input sets this register to 0000H.

### Figure 18-4. Format of Multiplication/Division Data Register B0 (MDB0)

| Address: | FF66H       | , FF67ŀ    | H Afte     | er reset   | : 0000H    | H R/V      | V          |            |            |            |            |            |            |            |            |               |
|----------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|---------------|
| Symbol   | ymbol FF67H |            |            |            |            |            |            |            | FF66H      |            |            |            |            |            |            |               |
|          |             |            |            |            |            |            |            |            |            |            |            |            |            |            |            | $\overline{}$ |
| MDB0     | MDB<br>015  | MDB<br>014 | MDB<br>013 | MDB<br>012 | MDB<br>011 | MDB<br>010 | MDB<br>009 | MDB<br>008 | MDB<br>007 | MDB<br>006 | MDB<br>005 | MDB<br>004 | MDB<br>003 | MDB<br>002 | MDB<br>001 | MDB<br>000    |
|          | 015         | 014        | 013        | 012        | 011        | 010        | 009        | 000        | 007        | 000        | 005        | 004        | 003        | 002        | 001        | 000           |

- Cautions 1. Do not change the value of MDB0 during operation processing (while bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is 1). Even in this case, the operation is executed, but the result is undefined.
  - 2. Do not set MDB0 to 0000H in the division mode. If set, undefined operation results are stored in MDA0 and SDR0.

## 18.3 Register Controlling Multiplier/Divider

The multiplier/divider is controlled by multiplier/divider control register 0 (DMUC0).

### (1) Multiplier/divider control register 0 (DMUC0)

DMUC0 is an 8-bit register that controls the operation of the multiplier/divider. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

### Figure 18-5. Format of Multiplier/Divider Control Register 0 (DMUC0)

| Address: FF68H After reset: 00H R/W |                      |                |                  |                |                  |                   |    |         |  |
|-------------------------------------|----------------------|----------------|------------------|----------------|------------------|-------------------|----|---------|--|
| Symbol                              | 7                    | 6              | 5                | 4              | 3                | 2                 | 1  | 0       |  |
| DMUC0                               | DMUE                 | 0              | 0                | 0              | 0                | 0                 | 0  | DMUSEL0 |  |
|                                     |                      |                |                  |                |                  |                   |    |         |  |
|                                     | DMUE <sup>Note</sup> |                |                  | Ор             | eration start/st | ор                |    |         |  |
|                                     | 0                    | Stops operati  | tops operation   |                |                  |                   |    |         |  |
|                                     | 1                    | Starts operati | Starts operation |                |                  |                   |    |         |  |
|                                     |                      |                |                  |                |                  |                   |    |         |  |
|                                     | DMUSEL0              |                | Op               | eration mode ( | multiplication/c | livision) selecti | on |         |  |
|                                     | 0                    | Division mode  | e                |                |                  |                   |    |         |  |
|                                     | 1                    | Multiplication | mode             |                |                  |                   |    |         |  |

- **Note** When DMUE is set to 1, the operation is started. DMUE is automatically cleared to 0 after the operation is complete.
- Cautions 1. If DMUE is cleared to 0 during operation processing (when DMUE is 1), the operation result is not guaranteed. If the operation is completed while the clearing instruction is being executed, the operation result is guaranteed, provided that the interrupt flag is set.
  - 2. Do not change the value of DMUSEL0 during operation processing (while DMUE is 1). If it is changed, undefined operation results are stored in multiplication/division data register A0 (MDA0) and remainder data register 0 (SDR0).
  - 3. If DMUE is cleared to 0 during operation processing (while DMUE is 1), the operation processing is stopped. To execute the operation again, set multiplication/division data register A0 (MDA0), multiplication/division data register B0 (MDB0), and multiplier/divider control register 0 (DMUC0), and start the operation (by clearing DMUE to 0).

## 18.4 Operations of Multiplier/Divider

### 18.4.1 Multiplication operation

## (1) Multiplication operation

- Initial setting
  - 1. Set operation data to multiplication/division data register A0L (MDA0L) and multiplication/division data register B0 (MDB0).
  - 2. Set bits 0 (DMUSEL0) and 7 (DMUE) of multiplier/divider control register 0 (DMUC0) to 1. The internal clock will start (operation will start).
- During operation
  - 3. The operation will be completed when 16 internal clocks have been issued after the start of the operation (intermediate data is stored in the MDA0L and MDA0H registers during operation, and therefore the read values of these registers are not guaranteed).
- End of operation
  - 4. After the operation, an interrupt request signal (INTDMU) is generated.
  - 5. The operation result data is stored in the MDA0L and MDA0H registers.
  - 6. DMUE is cleared to 0 (end of operation).
- Next operation
  - 7. To execute multiplication next, start from the initial setting in 18.4.1 Multiplication operation (1).
- 8. To execute division next, start from the initial setting in 18.4.2 Division operation (1).

Figure 18-6. Timing Chart of Multiplication Operation (00DAH × 0093H)



CHAPTER 18 MULTIPLIER/DIVIDER

### (2) Multiplication operation $\rightarrow$ multiplication operation

<End of first operation>

- 1. After the operation, an interrupt request signal (INTDMU) is generated.
- 2. The operation result data is stored in multiplication/division data register A0 (MDA0L and MDA0H).
- 3. Bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is cleared to 0 (end of operation).
- <Starting second operation>
- Initial setting
  - 4. Set operation data to multiplication/division data register A0L (MDA0L) and multiplication/division data register B0 (MDB0).
  - 5. Set bits 0 (DMUSEL0) and 7 (DMUE) of DMUC0 to 1. The internal clock will start (operation will start).

• During operation

6. The operation will be completed when 16 internal clocks have been issued after the start of the operation (intermediate data is stored in the MDA0L and MDA0H registers during operation, and therefore the read values of these registers are not guaranteed).



Figure 18-7. Timing Chart When Multiplication Is Executed Successively (00DAH × 0093H → FFFFH × FFFFH)

CHAPTER 18 MULTIPLIER/DIVIDER

As an example, the calculation of "4 bits  $\times$  4 bits (0111B  $\times$  0101B)" is shown below.





- 1. If the least significant bit of the multiplicand register whose most significant bit is zero-extended is 1, the multiplier with the most significant bit zero-extended is added to the higher 5 bits of the multiplicand register.
- 2. If the least significant bit of the multiplicand register whose most significant bit is zero-extended is 0, zero is added to the higher 5 bits of the multiplicand register.
- 3. After addition, the lower 4 bits of the multiplicand register are shifted 1 bit to the right, and the product with the most significant bit of the addition result zero-extended is stored in the higher 5 bits.

## 18.4.2 Division operation

## (1) Division operation

• Initial setting

- 1. Set operation data to multiplication/division data register A0 (MDA0L and MDA0H) and multiplication/division data register B0 (MDB0).
- 2. Set bits 0 (DMUSEL0) and 7 (DMUE) of multiplier/divider control register 0 (DMUC0) to 0 and 1, respectively. The internal clock will start (operation will start).
- During operation
- The operation will be completed when 32 internal clocks have been issued after the start of the operation (intermediate data is stored in the MDA0L and MDA0H registers and remainder data register 0 (SDR0) during operation, and therefore the read values of these registers are not guaranteed).
- End of operation
- 4. After the operation, an interrupt request signal (INTDMU) is generated.
- 5. The result data is stored in the MDA0L, MDA0H, and SDR0 registers.
- 6. DMUE is cleared to 0 (end of operation).
- Next operation
- 7. To execute multiplication next, start from the initial setting in 18.4.1 Multiplication operation (1).
- 8. To execute division next, start from the initial setting in 18.4.2 Division operation (1).



\_<u></u>, \_

Figure 18-9. Timing Chart of Division Operation (DCBA2586H + 0018H)

## (2) Division operation $\rightarrow$ division operation

<End of first operation>

- 1. After the operation, an interrupt request signal (INTDMU) is generated.
- 2. The result data is stored in multiplication/division data register A0 (MDA0L and MDA0H) and remainder data register 0 (SDR0).
- 3. Bit 7 (DMUE) of multiplier/divider control register 0 (DMUC0) is cleared to 0 (end of operation).

<Starting second operation>

- Initial setting
- 4. Set operation data to the MDA0L, MDA0H, and MDB0 registers.
- 5. Set bits 0 (DMUSEL0) and 7 (DMUE) of multiplier/divider control register 0 (DMUC0) to 0 and 1, respectively. The internal clock will start (operation will start).
- During operation
- 6. The operation will be completed when 32 internal clocks have been issued after the start of the operation (intermediate data is stored in the MDA0L, MDA0H, and SDR0 registers during operation, and therefore the read values of these registers are not guaranteed).



CHAPTER 18 MULTIPLIER/DIVIDER

As an example, the calculation of "4 bits  $\div$  2 bits (1001B  $\div$  10B)" is shown below.





- 1. The inverted value of the higher 3 bits of the dividend register whose most significant bit is extended by "00" is added to the divisor whose most significant bit is zero-extended.
- 2. After addition, the dividend register is shifted 1 bit to the left and "0" is stored in the least significant bit if the most significant bit is 0.
- 3. If the most significant bit is 1 after addition, the dividend register is shifted 1 bit to the left, and the inverted addition result, except the most significant bit, is stored in the higher 2 bits of the dividend register. 1 is stored in the least significant bit.
- 4. The higher 2 bits of the dividend register indicate the remainder, while the lower 4 bits indicate the quotient.
- 5. After addition, the lower 4 bits of the dividend register are shifted 1 bit to the right, and the addition result whose most significant bit is zero-extended is stored in the higher 5 bits.

## **CHAPTER 19 INTERRUPT FUNCTIONS**

## **19.1 Interrupt Function Types**

The following two types of interrupt functions are used.

### (1) Maskable interrupts

These interrupts undergo mask control. Maskable interrupts can be divided into a high interrupt priority group and a low interrupt priority group by setting the priority specification flag registers (PR0L, PR0H, PR1L, PR1H). Multiple interrupt servicing can be applied to low-priority interrupts when high-priority interrupts are generated. If two or more interrupts with the same priority are generated simultaneously, each interrupt is serviced according to its predetermined priority (see **Table 19-1**).

A standby release signal is generated.

Nine external interrupt requests and 20 (17 in the  $\mu$ PD780143 and 780144) internal interrupt requests are provided as maskable interrupts.

### (2) Software interrupt

This is a vectored interrupt generated by executing the BRK instruction. It is acknowledged even when interrupts are disabled. The software interrupt does not undergo interrupt priority control.

### **19.2 Interrupt Sources and Configuration**

A total of 30 (27 in the  $\mu$ PD780143 and 780144) interrupt sources exist for maskable and software interrupts (see **Table 19-1**).

| Interrupt     | Default                    |                     | Interrupt Source                                                                                                                                | Internal/ | Vector           | Basic                                   |
|---------------|----------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------|-----------------------------------------|
| Туре          | Priority <sup>Note 1</sup> | Name                | Trigger                                                                                                                                         | External  | Table<br>Address | Configuration<br>Type <sup>Note 2</sup> |
| Maskable 0 II |                            | INTLVI              | Low-voltage detection                                                                                                                           | Internal  | 0004H            | (A)                                     |
|               | 1                          | INTP0               | Pin input edge detection                                                                                                                        | External  | 0006H            | (B)                                     |
|               | 2                          | INTP1               |                                                                                                                                                 |           | 0008H            |                                         |
|               | 3                          | INTP2               |                                                                                                                                                 |           | 000AH            |                                         |
|               | 4                          | INTP3               |                                                                                                                                                 |           | 000CH            |                                         |
|               | 5                          | INTP4               |                                                                                                                                                 |           | 000EH            |                                         |
|               | 6                          | INTP5               |                                                                                                                                                 |           | 0010H            |                                         |
|               | 7                          | INTSRE6             | UART6 reception error generation                                                                                                                | Internal  | 0012H            | (A)                                     |
|               | 8                          | INTSR6              | End of UART6 reception                                                                                                                          |           | 0014H            |                                         |
|               | 9                          | INTST6              | End of UART6 transmission                                                                                                                       |           | 0016H            |                                         |
|               | 10                         | INTCSI10/<br>INTST0 | End of CSI10 transfer/end of UART0 transmission                                                                                                 |           | 0018H            |                                         |
|               | 11                         | INTTMH1             | Match between TMH1 and CRH1<br>(when compare register is specified)                                                                             |           | 001AH            |                                         |
|               | 12                         | INTTMHO             | Match between TMH0 and CRH0<br>(when compare register is specified)                                                                             |           | 001CH            |                                         |
|               | 13                         | INTTM50             | Match between TM50 and CR50<br>(when compare register is specified)                                                                             | 1         | 001EH            |                                         |
|               | 14                         | INTTM000            | Match between TM00 and CR000<br>(when compare register is specified),<br>TI010 pin valid edge detection<br>(when capture register is specified) |           | 0020H            |                                         |
|               | 15                         | INTTM010            | Match between TM00 and CR010<br>(when compare register is specified),<br>TI000 pin valid edge detection<br>(when capture register is specified) |           | 0022H            |                                         |
|               | 16 INTAD                   |                     | End of A/D conversion                                                                                                                           | ]         | 0024H            |                                         |
|               | 17                         | INTSR0              | End of UART0 reception or reception error generation                                                                                            |           | 0026H            |                                         |
|               | 18                         | INTWTI              | Watch timer reference time interval signal                                                                                                      | ]         | 0028H            |                                         |
|               | 19                         | INTTM51             | Match between TM51 and CR51<br>(when compare register is specified)                                                                             |           | 002AH            |                                         |

## Table 19-1. Interrupt Source List (1/2)

- **Notes 1.** The default priority is the priority applicable when two or more maskable interrupts are generated simultaneously. 0 is the highest priority, and 28 is the lowest.
  - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 19-1.

| Interrupt | Default<br>Priority <sup>Note 1</sup> | Interrupt Source           |                                                                                                                                                 | Internal/ | Vector           | Basic                                   |
|-----------|---------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------|-----------------------------------------|
| Туре      |                                       | Name                       | Trigger                                                                                                                                         | External  | Table<br>Address | Configuration<br>Type <sup>Note 2</sup> |
| Maskable  | 20                                    | INTKR                      | Key interrupt detection                                                                                                                         | External  | 002CH            | (C)                                     |
|           | 21                                    | INTWT                      | Watch timer overflow                                                                                                                            | Internal  | 002EH            | (A)                                     |
|           | 22                                    | INTP6                      | Pin input edge detection                                                                                                                        | External  | 0030H            | (B)                                     |
|           | 23                                    | INTP7                      |                                                                                                                                                 |           | 0032H            |                                         |
|           | 24                                    | INTDMU                     | End of multiply/divide operation                                                                                                                | Internal  | 0034H (A)        |                                         |
|           | 25                                    | INTCSI11 <sup>Note 3</sup> | End of CSI11 transfer                                                                                                                           |           | 0036H            |                                         |
|           | 26                                    | INTTM001 <sup>Note 3</sup> | Match between TM01 and CR001 (when<br>compare register is specified), TI011 pin valid<br>edge detection (when capture register is<br>specified) |           | 0038H            |                                         |
|           | 27                                    | INTTM011 <sup>Note 3</sup> | Match between TM01 and CR011 (when<br>compare register is specified), Tl001 pin valid<br>edge detection (when capture register is<br>specified) |           | 003AH            |                                         |
|           | 28                                    | INTACSI                    | End of CSIA0 transfer                                                                                                                           |           | 003CH            |                                         |
| Software  | -                                     | BRK                        | BRK instruction execution                                                                                                                       | -         | 003EH            | (D)                                     |
| Reset     | _                                     | RESET                      | Reset input                                                                                                                                     | -         | 0000Н            | _                                       |
|           |                                       | POC                        | Power-on reset                                                                                                                                  |           |                  |                                         |
|           |                                       | LVI                        | Low-voltage detection                                                                                                                           |           |                  |                                         |
|           |                                       | Clock monitor              | X1 oscillation stop detection                                                                                                                   |           |                  |                                         |
|           |                                       | WDT                        | WDT overflow                                                                                                                                    |           |                  |                                         |

| Table 19-1. | Interrupt | Source | List ( | 2/21 |
|-------------|-----------|--------|--------|------|
|             | micriapi  | Cource | LISU   | ~~)  |

- **Notes 1.** The default priority is the priority applicable when two or more maskable interrupts are generated simultaneously. 0 is the highest priority, and 28 is the lowest.
  - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 19-1.
  - 3. The interrupt sources INTCSI11, INTTM001, and INTTM011 are available only in the  $\mu$ PD780146, 780148, and 78F0148.

## Figure 19-1. Basic Configuration of Interrupt Function (1/2)

# (A) Internal maskable interrupt



## (B) External maskable interrupt (INTP0 to INTP7)



- IF: Interrupt request flag
- IE: Interrupt enable flag
- ISP: In-service priority flag
- MK: Interrupt mask flag
- PR: Priority specification flag

### Figure 19-1. Basic Configuration of Interrupt Function (2/2)

## (C) External maskable interrupt (INTKR)



### (D) Software interrupt



- IF: Interrupt request flag
- IE: Interrupt enable flag
- ISP: In-service priority flag
- MK: Interrupt mask flag
- PR: Priority specification flag
- KRM: Key return mode register

## **19.3 Registers Controlling Interrupt Functions**

The following 6 types of registers are used to control the interrupt functions.

- Interrupt request flag register (IF0L, IF0H, IF1L, IF1H)
- Interrupt mask flag register (MK0L, MK0H, MK1L, MK1H)
- Priority specification flag register (PR0L, PR0H, PR1L, PR1H)
- External interrupt rising edge enable register (EGP)
- External interrupt falling edge enable register (EGN)
- Program status word (PSW)

Table 19-2 shows a list of interrupt request flags, interrupt mask flags, and priority specification flags corresponding to interrupt request sources.

| Interrupt                  | Interrupt Request Flag    |          | Interrupt                 | Mask Flag | Priority Specification Flag |          |
|----------------------------|---------------------------|----------|---------------------------|-----------|-----------------------------|----------|
| Request                    |                           | Register |                           | Register  |                             | Register |
| INTLVI                     | LVIIF                     | IFOL     | LVIMK                     | MKOL      | LVIPR                       | PROL     |
| INTP0                      | PIF0                      |          | РМК0                      |           | PPR0                        |          |
| INTP1                      | PIF1                      |          | PMK1                      |           | PPR1                        |          |
| INTP2                      | PIF2                      |          | PMK2                      |           | PPR2                        |          |
| INTP3                      | PIF3                      |          | РМК3                      |           | PPR3                        |          |
| INTP4                      | PIF4                      |          | PMK4                      |           | PPR4                        |          |
| INTP5                      | PIF5                      |          | PMK5                      |           | PPR5                        |          |
| INTSRE6                    | SREIF6                    |          | SREMK6                    |           | SREPR6                      |          |
| INTSR6                     | SRIF6                     | IF0H     | SRMK6                     | МКОН      | SRPR6                       | PR0H     |
| INTST6                     | STIF6                     |          | STMK6                     | 1         | STPR6                       |          |
| INTCSI10                   | DUALIF0 <sup>Note 1</sup> |          | DUALMK0 <sup>Note 1</sup> | ]         | DUALPR0 <sup>Note 1</sup>   | 1        |
| INTST0                     |                           |          |                           |           |                             |          |
| INTTMH1                    | TMIFH1                    |          | TMMKH1                    |           | TMPRH1                      | -        |
| INTTMH0                    | TMIFH0                    |          | ТММКН0                    |           | TMPRH0                      |          |
| INTTM50                    | TMIF50                    |          | TMMK50                    |           | TMPR50                      |          |
| INTTM000                   | TMIF000                   |          | ТММК000                   |           | TMPR000                     |          |
| INTTM010                   | TMIF010                   |          | TMMK010                   |           | TMPR010                     |          |
| INTAD                      | ADIF                      | IF1L     | ADMK                      | MK1L      | ADPR                        | PR1L     |
| INTSR0                     | SRIF0                     |          | SRMK0                     |           | SRPR0                       |          |
| INTWTI                     | WTIIF                     |          | WTIMK                     |           | WTIPR                       |          |
| INTTM51                    | TMIF51                    |          | TMMK51                    |           | TMPR51                      |          |
| INTKR                      | KRIF                      |          | KRMK                      |           | KRPR                        |          |
| INTWR                      | WTIF                      |          | WTMK                      |           | WTPR                        | -        |
| INTP6                      | PIF6                      |          | PMK6                      |           | PPR6                        |          |
| INTP7                      | PIF7                      |          | PMK7                      | ]         | PPR7                        |          |
| INTSR0                     | SRIF0                     |          | SRMK0                     | ]         | SRPR0                       |          |
| INTDMU                     | DMUIF                     | IF1H     | DMUMK                     | MK1H      | DMUPR                       | PR1H     |
| INTCSI11 <sup>Note 2</sup> | CSIIF11 <sup>Note 2</sup> |          | CSIMK11 <sup>Note 2</sup> | ]         | CSIPR11 <sup>Note 2</sup>   |          |
| INTTM001 <sup>Note 2</sup> | TMIF001 <sup>Note 2</sup> |          | TMMK001 <sup>Note 2</sup> | ]         | TMPR001 <sup>Note 2</sup>   |          |
| INTTM011 <sup>Note 2</sup> | TMIF011 <sup>Note 2</sup> |          | TMMK011 <sup>Note 2</sup> | ]         | TMPR011 <sup>Note 2</sup>   |          |
| INTACSI                    | ACSIIF                    | 7        | ACSIMK                    | 1         | ACSIPR                      | 7        |

# Table 19-2. Flags Corresponding to Interrupt Request Sources

Notes 1. If either of the two types of interrupt sources is generated, these flags are set (1).

**2.** *μ*PD780146, 780148, and 78F0148 only.

## (1) Interrupt request flag registers (IF0L, IF0H, IF1L, IF1H)

The interrupt request flags are set to 1 when the corresponding interrupt request is generated or an instruction is executed. They are cleared to 0 when an instruction is executed upon acknowledgment of an interrupt request or upon RESET input.

IF0L, IF0H, IF1L, and IF1H are set by a 1-bit or 8-bit memory manipulation instruction. When IF0L and IF0H, and IF1L and IF1H are combined to form 16-bit registers IF0 and IF1, they are set by a 16-bit memory manipulation instruction.

RESET input clears these registers to 00H.

## Figure 19-2. Format of Interrupt Request Flag Registers (IF0L, IF0H, IF1L, IF1H)

| Address: FFI | FE0H After reset: 00H R/W |                        |                                                          |        |                           |                          |                           |       |
|--------------|---------------------------|------------------------|----------------------------------------------------------|--------|---------------------------|--------------------------|---------------------------|-------|
| Symbol       | 7                         | 6                      | 5                                                        | 4      | 3                         | 2                        | 1                         | 0     |
| IFOL         | SREIF6                    | PIF5                   | PIF4                                                     | PIF3   | PIF2                      | PIF1                     | PIF0                      | LVIIF |
|              |                           |                        |                                                          |        |                           |                          |                           |       |
| Address: FFI | E1H After r               | eset: 00H I            | R/W                                                      |        |                           |                          |                           |       |
| Symbol       | 7                         | 6                      | 5                                                        | 4      | 3                         | 2                        | 1                         | 0     |
| IF0H         | TMIF010                   | TMIF000                | TMIF50                                                   | TMIFH0 | TMIFH1                    | DUALIF0                  | STIF6                     | SRIF6 |
|              |                           |                        |                                                          |        |                           |                          |                           |       |
| Address: FFI | E2H After r               | eset: 00H I            | R/W                                                      |        |                           |                          |                           |       |
| Symbol       | 7                         | 6                      | 5                                                        | 4      | 3                         | 2                        | 1                         | 0     |
| IF1L         | PIF7                      | PIF6                   | WTIF                                                     | KRIF   | TMIF51                    | WTIIF                    | SRIF0                     | ADIF  |
|              |                           |                        |                                                          |        |                           |                          |                           |       |
| Address: FFI | E3H After r               | eset: 00H I            | R/W                                                      |        |                           |                          |                           |       |
| Symbol       | 7                         | 6                      | 5                                                        | 4      | 3                         | 2                        | 1                         | 0     |
| IF1H         | 0 <sup>Note 1</sup>       | 0 <sup>Note 1</sup>    | 0 <sup>Note 1</sup>                                      | ACSIIF | TMIF011 <sup>Note 2</sup> | TMIF001 <sup>Note2</sup> | CSIIF11 <sup>Note 2</sup> | DMUIF |
|              |                           |                        |                                                          |        |                           |                          |                           |       |
|              | XXIFX                     | Interrupt request flag |                                                          |        |                           |                          |                           |       |
|              | 0                         | No interrupt           | No interrupt request signal is generated                 |        |                           |                          |                           |       |
|              | 1                         | Interrupt req          | Interrupt request is generated, interrupt request status |        |                           |                          |                           |       |

- **2.**  $\mu$ PD780146, 780148, and 78F0148 only. Be sure to set these bits to 0 in the  $\mu$ PD780143 and 780144.
- Cautions 1. When operating a timer, serial interface, or A/D converter after standby release, operate it once after clearing the interrupt request flag. An interrupt request flag may be set by noise.
  - 2. When an interrupt is acknowledged, the interrupt request flag is automatically cleared and then the interrupt routine is entered.

Notes 1. Be sure to set bits 5 to 7 of IF1H to 0.

## (2) Interrupt mask flag registers (MK0L, MK0H, MK1L, MK1H)

\*

 $\star$ 

The interrupt mask flags are used to enable/disable the corresponding maskable interrupt servicing.

MK0L, MK0H, MK1L, and MK1H are set by a 1-bit or 8-bit memory manipulation instruction. When MK0L and MK0H, and MK1L and MK1H are combined to form 16-bit registers MK0 and MK1, they are set by a 16-bit memory manipulation instruction.

RESET input sets MK0L, MK0H, and MK1L to FFH and MK1H to DFH.

#### Figure 19-3. Format of Interrupt Mask Flag Registers (MK0L, MK0H, MK1L, MK1H)

| Address: FF | E4H After r         | eset: FFH                   | R/W                         |        |                           |                          |                           |       |
|-------------|---------------------|-----------------------------|-----------------------------|--------|---------------------------|--------------------------|---------------------------|-------|
| Symbol      | 7                   | 6                           | 5                           | 4      | 3                         | 2                        | 1                         | 0     |
| MK0L        | SREMK6              | PMK5                        | PMK4                        | PMK3   | PMK2                      | PMK1                     | PMK0                      | LVIMK |
|             |                     |                             |                             |        |                           |                          |                           |       |
| Address: FF | E5H After r         | eset: FFH I                 | R/W                         |        |                           |                          |                           |       |
| Symbol      | 7                   | 6                           | 5                           | 4      | 3                         | 2                        | 1                         | 0     |
| МКОН        | TMMK010             | TMMK000                     | TMMK50                      | TMMKH0 | TMMKH1                    | DUALMK0                  | STMK6                     | SRMK6 |
|             |                     |                             |                             |        |                           |                          |                           |       |
| Address: FF | E6H After r         | eset: FFH I                 | R/W                         |        |                           |                          |                           |       |
| Symbol      | 7                   | 6                           | 5                           | 4      | 3                         | 2                        | 1                         | 0     |
| MK1L        | PMK7                | PMK6                        | WTMK                        | KRMK   | TMMK51                    | WTIMK                    | SRMK0                     | ADMK  |
|             |                     |                             |                             |        |                           |                          |                           |       |
| Address: FF | E7H After r         | eset: DFH                   | R/W                         |        |                           |                          |                           |       |
| Symbol      | 7                   | 6                           | 5                           | 4      | 3                         | 2                        | 1                         | 0     |
| MK1H        | 1 <sup>Note 1</sup> | 1 <sup>Note 1</sup>         | 0 <sup>Note 1</sup>         | ACSIMK | TMMK011 <sup>Note 2</sup> | TMMK001 <sup>Note2</sup> | CSIMK11 <sup>Note 2</sup> | DMUMK |
|             |                     |                             |                             |        |                           |                          |                           |       |
|             | XXMKX               | Interrupt servicing control |                             |        |                           |                          |                           |       |
|             | 0                   | Interrupt ser               | Interrupt servicing enabled |        |                           |                          |                           |       |
|             | 1                   | Interrupt ser               | vicing disable              | d      |                           |                          |                           |       |

Notes 1. Be sure to set bits 6 and 7 of MK1H to 1 and bit 5 to 0.

**2.**  $\mu$ PD780146, 780148, and 78F0148 only. Be sure to set these bits to 1 in the  $\mu$ PD780143 and 780144.

## (3) Priority specification flag registers (PR0L, PR0H, PR1L, PR1H)

The priority specification flag registers are used to set the corresponding maskable interrupt priority order. PR0L, PR0H, PR1L, and PR1H are set by a 1-bit or 8-bit memory manipulation instruction. If PR0L and PR0H, and PR1L and PR1H are combined to form 16-bit registers PR0 and PR1, they are set by a 16-bit memory manipulation instruction.

RESET input sets these registers to FFH.

#### Figure 19-4. Format of Priority Specification Flag Registers (PR0L, PR0H, PR1L, PR1H)

| Address: FFI | E8H After r         | eset: FFH I         | R/W                 |        |                           |                          |                           |       |
|--------------|---------------------|---------------------|---------------------|--------|---------------------------|--------------------------|---------------------------|-------|
| Symbol       | 7                   | 6                   | 5                   | 4      | 3                         | 2                        | 1                         | 0     |
| PR0L         | SREPR6              | PPR5                | PPR4                | PPR3   | PPR2                      | PPR1                     | PPR0                      | LVIPR |
|              |                     |                     |                     |        |                           |                          |                           |       |
| Address: FFI | E9H After r         | eset: FFH I         | R/W                 |        |                           |                          |                           |       |
| Symbol       | 7                   | 6                   | 5                   | 4      | 3                         | 2                        | 1                         | 0     |
| PR0H         | TMPR010             | TMPR000             | TMPR50              | TMPRH0 | TMPRH1                    | DUALPRO                  | STPR6                     | SRPR6 |
|              |                     |                     |                     |        |                           |                          |                           |       |
| Address: FFI | EAH After r         | reset: FFH          | R/W                 |        |                           |                          |                           |       |
| Symbol       | 7                   | 6                   | 5                   | 4      | 3                         | 2                        | 1                         | 0     |
| PR1L         | PPR7                | PPR6                | WTPR                | KRPR   | TMPR51                    | WTIPR                    | SRPR0                     | ADPR  |
|              |                     |                     |                     |        |                           |                          |                           |       |
| Address: FFI | EBH After r         | reset: FFH          | R/W                 |        |                           |                          |                           |       |
| Symbol       | 7                   | 6                   | 5                   | 4      | 3                         | 2                        | 1                         | 0     |
| PR1H         | 1 <sup>Note 1</sup> | 1 <sup>Note 1</sup> | 1 <sup>Note 1</sup> | ACSIPR | TMPR011 <sup>Note 2</sup> | TMPR001 <sup>Note2</sup> | CSIPR11 <sup>Note 2</sup> | DMUPR |
|              |                     |                     |                     |        |                           |                          |                           |       |
|              | XXPRX               |                     |                     | Pric   | ority level selec         | ction                    |                           |       |
|              | 0                   | High priority       | High priority level |        |                           |                          |                           |       |

Notes 1. Be sure to set bits 5 to 7 of PR1H to 1.

Low priority level

1

**2.**  $\mu$ PD780146, 780148, and 78F0148 only. Be sure to set these bits to 1 in the  $\mu$ PD780143 and 780144.

(4) External interrupt rising edge enable register (EGP), external interrupt falling edge enable register (EGN) These registers specify the valid edge for INTP0 to INTP7. EGP and EGN are set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears these registers to 00H.

# Figure 19-5. Format of External Interrupt Rising Edge Enable Register (EGP) and External Interrupt Falling Edge Enable Register (EGN)

| Address: FF | 48H After re | eset: 00H | R/W  |      |      |      |      |      |
|-------------|--------------|-----------|------|------|------|------|------|------|
| Symbol      | 7            | 6         | 5    | 4    | 3    | 2    | 1    | 0    |
| EGP         | EGP7         | EPG6      | EGP5 | EGP4 | EGP3 | EGP2 | EGP1 | EGP0 |
|             |              |           |      |      |      |      |      |      |
| Address: FF | 49H After re | eset: 00H | R/W  |      |      |      |      |      |
| Symbol      | 7            | 6         | 5    | 4    | 3    | 2    | 1    | 0    |
| EGN         | EGN7         | EGN6      | EGN5 | EGN4 | EGN3 | EGN2 | EGN1 | EGN0 |
|             |              |           |      |      |      |      |      |      |

| EGPn | EGNn | INTPn pin valid edge selection ( $n = 0$ to 7) |
|------|------|------------------------------------------------|
| 0    | 0    | Interrupt disabled                             |
| 0    | 1    | Falling edge                                   |
| 1    | 0    | Rising edge                                    |
| 1    | 1    | Both rising and falling edges                  |

Table 19-3 shows the ports corresponding to EGPn and EGNn.

| Table 19-3. | Ports Corresponding to EGPn and EGNn |
|-------------|--------------------------------------|
|-------------|--------------------------------------|

| Detection Enable Register |      | Edge Detection Port | Interrupt Request Signal |
|---------------------------|------|---------------------|--------------------------|
| EGP0                      | EGN0 | P120                | INTP0                    |
| EGP1                      | EGN1 | P30                 | INTP1                    |
| EGP2                      | EGN2 | P31                 | INTP2                    |
| EGP3                      | EGN3 | P32                 | INTP3                    |
| EGP4                      | EGN4 | P33                 | INTP4                    |
| EGP5                      | EGN5 | P16                 | INTP5                    |
| EGP6                      | EGN6 | P140                | INTP6                    |
| EGP7                      | EGN7 | P141                | INTP7                    |

## (5) Program status word (PSW)

The program status word is a register used to hold the instruction execution result and the current status for an interrupt request. The IE flag that sets maskable interrupt enable/disable and the ISP flag that controls multiple interrupt servicing are mapped to the PSW.

Besides 8-bit read/write, this register can carry out operations using bit manipulation instructions and dedicated instructions (EI and DI). When a vectored interrupt request is acknowledged, if the BRK instruction is executed, the contents of the PSW are automatically saved into a stack and the IE flag is reset to 0. If a maskable interrupt request is acknowledged, the contents of the priority specification flag of the acknowledged interrupt are transferred to the ISP flag. The PSW contents are also saved into the stack with the PUSH PSW instruction. They are restored from the stack with the RETI, RETB, and POP PSW instructions.

RESET input sets PSW to 02H.



#### Figure 19-6. Format of Program Status Word

#### **19.4 Interrupt Servicing Operations**

#### 19.4.1 Maskable interrupt request acknowledgement

A maskable interrupt request becomes acknowledgeable when the interrupt request flag is set to 1 and the mask (MK) flag corresponding to that interrupt request is cleared to 0. A vectored interrupt request is acknowledged if interrupts are in the interrupt enabled state (when the IE flag is set to 1). However, a low-priority interrupt request is not acknowledged during servicing of a higher priority interrupt request (when the ISP flag is reset to 0).

The times from generation of a maskable interrupt request until interrupt servicing is performed are listed in Table 19-4 below.

For the interrupt request acknowledgement timing, see Figures 19-8 and 19-9.

Table 19-4. Time from Generation of Maskable Interrupt Request Until Servicing

|                      | Minimum Time | Maximum Time <sup>Note</sup> |
|----------------------|--------------|------------------------------|
| When $\times$ PR = 0 | 7 clocks     | 32 clocks                    |
| When ××PR = 1        | 8 clocks     | 33 clocks                    |

Note If an interrupt request is generated just before a divide instruction, the wait time becomes longer.

Remark 1 clock: 1/fcpu (fcpu: CPU clock)

If two or more maskable interrupt requests are generated simultaneously, the request with a higher priority level specified in the priority specification flag is acknowledged first. If two or more interrupt requests have the same priority level, the request with the highest default priority is acknowledged first.

An interrupt request that is held pending is acknowledged when it becomes acknowledgeable.

Figure 19-7 shows the interrupt request acknowledgement algorithm.

If a maskable interrupt request is acknowledged, the contents are saved into the stacks in the order of PSW, then PC, the IE flag is reset (0), and the contents of the priority specification flag corresponding to the acknowledged interrupt are transferred to the ISP flag. The vector table data determined for each interrupt request is loaded into the PC and branched.

Restoring from an interrupt is possible by using the RETI instruction.



Figure 19-7. Interrupt Request Acknowledgement Processing Algorithm

××IF: Interrupt request flag

××MK: Interrupt mask flag

××PR: Priority specification flag

IE: Flag that controls acknowledgement of maskable interrupt request (1 = Enable, 0 = Disable)

ISP: Flag that indicates the priority level of the interrupt currently being serviced (0 = high-priority interrupt servicing, 1 = No interrupt request acknowledged, or low-priority interrupt servicing)

Yes

Vectored interrupt servicing

Interrupt request held pending



## Figure 19-8. Interrupt Request Acknowledgement Timing (Minimum Time)







Remark 1 clock: 1/fcpu (fcpu: CPU clock)

#### 19.4.2 Software interrupt request acknowledgement

A software interrupt request is acknowledged by BRK instruction execution. Software interrupts cannot be disabled.

If a software interrupt request is acknowledged, the contents are saved into the stacks in the order of the program status word (PSW), then program counter (PC), the IE flag is reset (0), and the contents of the vector table (003EH, 003FH) are loaded into the PC and branched.

Restoring from a software interrupt is possible by using the RETB instruction.

#### Caution Do not use the RETI instruction for restoring from the software interrupt.

#### 19.4.3 Multiple interrupt servicing

Multiple interrupt servicing occurs when another interrupt request is acknowledged during execution of an interrupt. Multiple interrupt servicing does not occur unless the interrupt request acknowledgement enabled state is selected (IE = 1). Also, when an interrupt request is acknowledged, interrupt request acknowledgement becomes disabled (IE = 0). Therefore, to enable multiple interrupt servicing, it is necessary to set (1) the IE flag with the EI instruction during interrupt servicing to enable interrupt acknowledgement.

Moreover, even if interrupts are enabled, multiple interrupt servicing may not be enabled, this being subject to interrupt priority control. Two types of priority control are available: default priority control and programmable priority control. Programmable priority control is used for multiple interrupt servicing.

In the interrupt enabled state, if an interrupt request with a priority equal to or higher than that of the interrupt currently being serviced is generated, it is acknowledged for multiple interrupt servicing. If an interrupt with a priority lower than that of the interrupt currently being serviced is generated during interrupt servicing, it is not acknowledged for multiple interrupt servicing. Interrupt requests that are not enabled because interrupts are in the interrupt disabled state or because they have a lower priority are held pending. When servicing of the current interrupt ends, the pending interrupt request is acknowledged following execution of one main processing instruction execution.

Table 19-5 shows interrupt requests enabled for multiple interrupt servicing and Figure 19-10 shows multiple interrupt servicing examples.

| Multiple Interrupt Request |         | Maskable Interrupt Request |        |        |        |  |
|----------------------------|---------|----------------------------|--------|--------|--------|--|
|                            |         | PR                         | = 0    | PR     | = 1    |  |
| Interrupt Being Serviced   |         | IE = 1                     | IE = 0 | IE = 1 | IE = 0 |  |
| Maskable interrupt         | ISP = 0 | 0                          | ×      | ×      | ×      |  |
|                            | ISP = 1 | 0                          | ×      | 0      | ×      |  |
| Software interrupt         |         | 0                          | ×      | 0      | ×      |  |

Table 19-5. Interrupt Request Enabled for Multiple Interrupt Servicing During Interrupt Servicing

Remarks 1. O: Multiple interrupt servicing enabled

- 2. X: Multiple interrupt servicing disabled
- 3. ISP and IE are flags contained in the PSW.
  - ISP = 0: An interrupt with higher priority is being serviced.
  - ISP = 1: No interrupt request has been acknowledged, or an interrupt with a lower priority is being serviced.
  - IE = 0: Interrupt request acknowledgement is disabled.
  - IE = 1: Interrupt request acknowledgement is enabled.
- 4. PR is a flag contained in PR0L, PR0H, PR1L, and PR1H.
  - PR = 0: Higher priority level
  - PR = 1: Lower priority level

#### Figure 19-10. Examples of Multiple Interrupt Servicing (1/2)



#### Example 1. Multiple interrupt servicing occurs twice

During servicing of interrupt INTxx, two interrupt requests, INTyy and INTzz, are acknowledged, and multiple interrupt servicing takes place. Before each interrupt request is acknowledged, the EI instruction must always be issued to enable interrupt request acknowledgement.





Interrupt request INTyy issued during servicing of interrupt INTxx is not acknowledged because its priority is lower than that of INTxx, and multiple interrupt servicing does not take place. The INTyy interrupt request is held pending, and is acknowledged following execution of one main processing instruction.

- PR = 0: Higher priority level
- PR = 1: Lower priority level
- IE = 0: Interrupt request acknowledgement disabled



#### Figure 19-10. Examples of Multiple Interrupt Servicing (2/2)

## Example 3. Multiple interrupt servicing does not occur because interrupts are not enabled

Interrupts are not enabled during servicing of interrupt INTxx (EI instruction is not issued), therefore, interrupt request INTyy is not acknowledged and multiple interrupt servicing does not take place. The INTyy interrupt request is held pending, and is acknowledged following execution of one main processing instruction.

- PR = 0: Higher priority level
- IE = 0: Interrupt request acknowledgement disabled

#### 19.4.4 Interrupt request hold

There are instructions where, even if an interrupt request is issued for them while another instruction is being executed, request acknowledgement is held pending until the end of execution of the next instruction. These instructions (interrupt request hold instructions) are listed below.

- MOV PSW, #byte
- MOV A, PSW
- MOV PSW, A
- MOV1 PSW. bit, CY
- MOV1 CY, PSW. bit
- AND1 CY, PSW. bit
- OR1 CY, PSW. bit
- XOR1 CY, PSW. bit
- SET1 PSW. bit
- CLR1 PSW. bit
- RETB
- RETI
- PUSH PSW
- POP PSW
- BT PSW. bit, \$addr16
- BF PSW. bit, \$addr16
- BTCLR PSW. bit, \$addr16
- El
- DI
- Manipulation instructions for the IF0L, IF0H, IF1L, IF1H, MK0L, MK0H, MK1L, MK1H, PR0L, PR0H, PR1L, and PR1H registers
- Caution The BRK instruction is not one of the above-listed interrupt request hold instructions. However, the software interrupt activated by executing the BRK instruction causes the IE flag to be cleared to 0. Therefore, even if a maskable interrupt request is generated during execution of the BRK instruction, the interrupt request is not acknowledged.

Figure 19-11 shows the timing at which interrupt requests are held pending.

#### Figure 19-11. Interrupt Request Hold



Remarks 1. Instruction N: Interrupt request hold instruction

- 2. Instruction M: Instruction other than interrupt request hold instruction
- 3. The XXPR (priority level) values do not affect the operation of XXIF (interrupt request).

# **CHAPTER 20 KEY INTERRUPT FUNCTION**

## 20.1 Functions of Key Interrupt

A key interrupt (INTKR) can be generated by setting the key return mode register (KRM) and inputting a falling edge to the key interrupt input pins (KR0 to KR7).

| Flag | Description                         |
|------|-------------------------------------|
| KRM0 | Controls KR0 signal in 1-bit units. |
| KRM1 | Controls KR1 signal in 1-bit units. |
| KRM2 | Controls KR2 signal in 1-bit units. |
| KRM3 | Controls KR3 signal in 1-bit units. |
| KRM4 | Controls KR4 signal in 1-bit units. |
| KRM5 | Controls KR5 signal in 1-bit units. |
| KRM6 | Controls KR6 signal in 1-bit units. |
| KRM7 | Controls KR7 signal in 1-bit units. |

# Table 20-1. Assignment of Key Interrupt Detection Pins

#### 20.2 Configuration of Key Interrupt

The key interrupt consists of the following hardware.

## Table 20-2. Configuration of Key Interrupt

| Item             | Configuration                  |
|------------------|--------------------------------|
| Control register | Key return mode register (KRM) |

Figure 20-1. Block Diagram of Key Interrupt



## 20.3 Register Controlling Key Interrupt

## (1) Key return mode register (KRM)

This register controls the KRM0 to KRM7 bits using the KR0 to KR7 signals, respectively. This register is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

#### Figure 20-2. Format of Key Return Mode Register (KRM)

Address: FF6EH After reset: 00H R/W



| KRMn                           | Key interrupt mode control           |  |  |  |  |
|--------------------------------|--------------------------------------|--|--|--|--|
| 0                              | Does not detect key interrupt signal |  |  |  |  |
| 1 Detects key interrupt signal |                                      |  |  |  |  |

- Cautions 1. If any of the KRM0 to KRM7 bits used is set to 1, set bits 0 to 7 (PU70 to PU77) of the corresponding pull-up resistor register 7 (PU7) to 1.
  - 2. If KRM is changed, the interrupt request flag may be set. Therefore, disable interrupts and then change the KRM register. Clear the interrupt request flag and enable interrupts.
  - 3. The bits not used in the key interrupt mode can be used as normal ports.

## **CHAPTER 21 STANDBY FUNCTION**

## 21.1 Standby Function and Configuration

#### 21.1.1 Standby function

#### Table 21-1. Relationship Between HALT Mode, STOP Mode, and Clock

|                               | X1 Input Clock        | Ring-OSC Clock        | Subsystem Clock       | CPU Clock         |  |
|-------------------------------|-----------------------|-----------------------|-----------------------|-------------------|--|
| HALT mode                     | Oscillation continues | Oscillation continues | Oscillation continues | Operation stopped |  |
| STOP mode Oscillation stopped |                       | Oscillation continues | Oscillation continues | Operation stopped |  |

The standby function is designed to reduce the power consumption of the system. The following two modes are available.

#### (1) HALT mode

HALT instruction execution sets the HALT mode. In the HALT mode, the CPU operation clock is stopped, but the system clock oscillator continues oscillating. In this mode, current consumption is not decreased as much as in the STOP mode, but the HALT mode is effective for restarting operation immediately upon interrupt request generation and carrying out intermittent operations.

## (2) STOP mode

STOP instruction execution sets the STOP mode. In the STOP mode, the X1 input clock oscillator stops, stopping the whole system, thereby considerably reducing the CPU power consumption.

Because this mode can be cleared by an interrupt request, it enables intermittent operations to be carried out. However, because a wait time is required to secure the oscillation stabilization time after the STOP mode is released, select the HALT mode if it is necessary to start processing immediately upon interrupt request generation.

In either of these two modes, all the contents of registers, flags and data memory just before the standby mode is set are held. The I/O port output latches and output buffer statuses are also held.

- Cautions 1. STOP mode can be used only when operating on the X1 input clock or Ring-OSC clock. HALT mode can be used when operating on the X1 input clock, Ring-OSC clock, or subsystem clock. However, when the STOP instruction is executed during Ring-OSC clock operation, the X1 oscillator stops, but Ring-OSC oscillator does not stop.
  - 2. When shifting to the STOP mode, be sure to stop the peripheral hardware operation before executing STOP instruction.
  - 3. The following sequence is recommended for power consumption reduction of the A/D converter when the standby function is used: First clear bit 7 (ADCS) of the A/D converter mode register (ADM) to 0 to stop the A/D conversion operation, and then execute the HALT or STOP instruction.
  - Ring-OSC clock oscillation cannot be stopped in the STOP mode. However, when the Ring-OSC clock is used as the CPU clock, the CPU operation is stopped for 17/fR (s) after STOP mode is released.



Figure 21-1. Operation Timing When STOP Mode Is Released

## 21.1.2 Registers controlling standby function

1

1

The standby function is controlled by the following two registers.

- Oscillation stabilization time counter status register (OSTC)
- Oscillation stabilization time select register (OSTS)

## (1) Oscillation stabilization time counter status register (OSTC)

This is the status register of the X1 input clock oscillation stabilization time counter. If the Ring-OSC clock is used as the CPU clock, the X1 input clock oscillation stabilization time can be checked.

★ OSTC can be read by a 1-bit or 8-bit memory manipulation instruction.

1

1

**\star RESET** input, STOP instruction, MSTOP = 1, and MCC = 1 clear OSTC to 00H.

#### Figure 21-2. Format of Oscillation Stabilization Time Counter Status Register (OSTC)

| Address: FFA3H After reset: 00H R |        |        |        |        |        |                                          |                                          |             |
|-----------------------------------|--------|--------|--------|--------|--------|------------------------------------------|------------------------------------------|-------------|
| Symbol                            | 7      | 6      | 5      | 4      | 3      | 2                                        | 1                                        | 0           |
| OSTC                              | 0      | 0      | 0      | MOST11 | MOST13 | MOST14                                   | MOST15                                   | MOST16      |
|                                   |        |        |        |        |        |                                          |                                          |             |
|                                   | MOST11 | MOST13 | MOST14 | MOST15 | MOST16 | Oscillation                              | stabilization t                          | time status |
|                                   | 1      | 0      | 0      | 0      | 0      | 211/fx min. (2                           | 2 <sup>11</sup> /fx min. (204.8 μs min.) |             |
|                                   | 1      | 1      | 0      | 0      | 0      | 2 <sup>13</sup> /fx min. (819.2 μs min.) |                                          |             |
|                                   | 1      | 1      | 1      | 0      | 0      | 2 <sup>14</sup> /fx min. (1.64 ms min.)  |                                          |             |

1

1

# Caution After the above time has elapsed, the bits are set to 1 in order from MOST11 and remain 1.

0

1

2<sup>15</sup>/fx min. (3.27 ms min.)

2<sup>16</sup>/fx min. (6.55 ms min.)

**Remarks 1.** Values in parentheses are for operation with fx = 10 MHz.

2. fx: X1 input clock oscillation frequency

1

1

#### (2) Oscillation stabilization time select register (OSTS)

This register is used to select the X1 oscillation stabilization wait time when STOP mode is released. The wait time set by OSTS is valid only after STOP mode is released when the X1 input clock is selected as the CPU clock. After STOP mode is released when the Ring-OSC clock is selected, check the oscillation stabilization time using OSTC.

OSTS can be set by an 8-bit memory manipulation instruction.

RESET input sets OSTS to 05H.

## Figure 21-3. Format of Oscillation Stabilization Time Select Register (OSTS)

| Address: FFA | 4H After r | eset: 05H | R/W |   |   |       |       |       |
|--------------|------------|-----------|-----|---|---|-------|-------|-------|
| Symbol       | 7          | 6         | 5   | 4 | 3 | 2     | 1     | 0     |
| OSTS         | 0          | 0         | 0   | 0 | 0 | OSTS2 | OSTS1 | OSTS0 |
|              |            |           |     |   |   |       |       |       |

| OSTS2 | OSTS1          | OSTS0 | Oscillation stabilization time selection |  |  |
|-------|----------------|-------|------------------------------------------|--|--|
| 0     | 0              | 1     | 2 <sup>11</sup> /fx (204.8 μs)           |  |  |
| 0     | 1              | 0     | 2 <sup>13</sup> /fx (819.2 μs)           |  |  |
| 0     | 1              | 1     | 2 <sup>14</sup> /fx (1.64 ms)            |  |  |
| 1     | 0              | 0     | 2 <sup>15</sup> /fx (3.27 ms)            |  |  |
| 1     | 0              | 1     | 2 <sup>16</sup> /fx (6.55 ms)            |  |  |
| 0     | ther than abov | ve    | Setting prohibited                       |  |  |

Cautions 1. If the STOP mode is entered and then released while the Ring-OSC clock is being used as the CPU clock, set the oscillation stabilization time as follows.

Desired OSTC oscillation stabilization time < Oscillation stabilization time set by OSTS</li>

The X1 oscillation stabilization time counter counts only during the oscillation stabilization time set by OSTS. Therefore, note that only the statuses during the oscillation stabilization time set by OSTS are set to OSTC after STOP mode has been released.

2. The wait time when STOP mode is released does not include the time after STOP mode release until clock oscillation starts ("a" below) regardless of whether STOP mode is released by **RESET** input or interrupt generation.



- **Remarks 1.** Values in parentheses are for operation with fx = 10 MHz.
  - **2.** fx: X1 input clock oscillation frequency

# 21.2 Standby Function Operation

# 21.2.1 HALT mode

# (1) HALT mode

The HALT mode is set by executing the HALT instruction. HALT mode can be set regardless of whether the CPU clock before the setting was the X1 input clock, Ring-OSC clock, or subsystem clock. The operating statuses in the HALT mode are shown below.

|                   | HALT Mode Setting                            | When HAL                        | T Instruction Is                                                                                |                                 |                                                                      | -                                                                                                           |                                        | s Executed Wh<br>ling-OSC Clocl |                                        |
|-------------------|----------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------------|----------------------------------------|
|                   |                                              |                                 | When Ring-OSC         When Ring-OSC           Oscillation Continues         Oscillation Stopped |                                 |                                                                      | When X1 Input Clock         When X1 Input Clock           Oscillation Continues         Oscillation Stopped |                                        |                                 | •                                      |
| Item              |                                              | When<br>Subsystem<br>Clock Used | When<br>Subsystem<br>Clock Not<br>Used                                                          | When<br>Subsystem<br>Clock Used | When<br>Subsystem<br>Clock Not<br>Used                               | When<br>Subsystem<br>Clock Used                                                                             | When<br>Subsystem<br>Clock Not<br>Used | When<br>Subsystem<br>Clock Used | When<br>Subsystem<br>Clock Not<br>Used |
| System cloc       | :k                                           | The X1 oscilla<br>CPU is stopp  | -                                                                                               | coscillator, and                | d subsystem cl                                                       | ock oscillator a                                                                                            | are able to osci                       | llate. Clock su                 | pply to the                            |
| CPU               |                                              | Operation sto                   | pped                                                                                            |                                 |                                                                      |                                                                                                             |                                        |                                 |                                        |
| Port (latch)      |                                              | Status before                   | HALT mode w                                                                                     | vas set is retair               | ned                                                                  |                                                                                                             |                                        |                                 |                                        |
| 16-bit timer/     | event counter 00                             | Operable                        |                                                                                                 |                                 |                                                                      | Operation sto                                                                                               | pped                                   |                                 |                                        |
| 16-bit timer/     | event counter 01 <sup>Note 2</sup>           | Operable                        |                                                                                                 |                                 |                                                                      | Operation sto                                                                                               | opped                                  |                                 |                                        |
| 8-bit timer/e     | vent counter 50                              | Operable                        |                                                                                                 |                                 |                                                                      | Operable only                                                                                               | y when TI50 is                         | selected as th                  | e count clock                          |
| 8-bit timer/e     | vent counter 51                              | Operable                        |                                                                                                 |                                 |                                                                      | Operable only when TI51 is selected as the count clock                                                      |                                        |                                 |                                        |
| 8-bit timer H     | 10                                           | Operable                        |                                                                                                 |                                 |                                                                      | Operable only when TO50 is selected as the count clock during 8-bit timer/event counter 50 operation        |                                        |                                 |                                        |
| 8-bit timer H     | 11                                           | Operable                        |                                                                                                 |                                 | Operable only when $f_{\text{P}}/2^7$ is selected as the count clock |                                                                                                             |                                        |                                 |                                        |
| Watch time        | r                                            | Operable                        | Operable <sup>Note 3</sup>                                                                      | Operable                        | Operable <sup>Note 3</sup>                                           | Operable <sup>Note 4</sup>                                                                                  | Not operable                           | Operable <sup>Note 4</sup>      | Not operable                           |
| Watchdog<br>timer | Ring-OSC cannot be stopped <sup>Note 5</sup> | Operable                        |                                                                                                 | -                               | -                                                                    | Operable                                                                                                    |                                        |                                 |                                        |
|                   | Ring-OSC can be stopped <sup>Note 5</sup>    | Operation sto                   | pped                                                                                            |                                 |                                                                      |                                                                                                             |                                        |                                 |                                        |
| A/D convert       | er                                           | Operable                        |                                                                                                 |                                 |                                                                      | Not operable                                                                                                |                                        |                                 |                                        |
| Serial            | UART0                                        | Operable                        | Operable                                                                                        |                                 |                                                                      | Operable only when TO50 is selected as the serial                                                           |                                        |                                 |                                        |
| interface         | UART6                                        | Operable                        |                                                                                                 |                                 |                                                                      | clock during TM50 operation                                                                                 |                                        |                                 |                                        |
|                   | CSI10                                        | Operable                        | Operable                                                                                        |                                 |                                                                      | Operable only when external SCK10 is selected as the serial clock                                           |                                        |                                 |                                        |
|                   | CSI11 <sup>Note 2</sup>                      |                                 |                                                                                                 |                                 |                                                                      | Operable only when external SCK11 is selected as the serial clock                                           |                                        |                                 | ected as the                           |
|                   | CSIA0                                        | Operable                        |                                                                                                 |                                 |                                                                      | Operation sto                                                                                               | pped                                   |                                 |                                        |
| Clock monit       | or                                           | Operable                        |                                                                                                 | Operation sto                   | opped                                                                | Operable                                                                                                    |                                        | Operation sto                   | pped                                   |
| Multiplier/div    | vider                                        | Operable                        |                                                                                                 |                                 |                                                                      | Operation sto                                                                                               | opped                                  |                                 |                                        |
| Power-on-c        | lear function <sup>Note 6</sup>              | Operable                        |                                                                                                 |                                 |                                                                      |                                                                                                             |                                        |                                 |                                        |
| Low-voltage       | e detection function                         | Operable                        |                                                                                                 |                                 |                                                                      |                                                                                                             |                                        |                                 |                                        |
| External inte     | errupt                                       | Operable                        |                                                                                                 |                                 |                                                                      |                                                                                                             |                                        |                                 |                                        |

| Table 21-2. | Operating | Statuses in | HALT | Mode | (1/2) |
|-------------|-----------|-------------|------|------|-------|
|             | oporating | otataooo m  |      | mouo | ···-/ |

Notes 1. When "Stopped by software" is selected for Ring-OSC by a mask option and Ring-OSC is stopped by software (for mask options, see CHAPTER 27 MASK OPTIONS).

- **2.** μPD780146, 780148, and 78F0148 only.
- 3. Operable when the X1 input clock is selected.
- 4. Operable when the subsystem clock is selected.
- 5. "Ring-OSC cannot be stopped" or "Ring-OSC can be stopped by software" can be selected by a mask option.
- 6. When "POC used" is selected by a mask option.

\*

|                   | HALT Mode Setting                               | When HAL                                       | T Instruction Is Executed Wh                                               | ile CPU Is Operating on Subs                                         | ystem Clock                                            |  |  |  |
|-------------------|-------------------------------------------------|------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------|--|--|--|
|                   |                                                 | When X1 Input Clock                            | Oscillation Continues                                                      | When X1 Input Cloc                                                   | k Oscillation Stopped                                  |  |  |  |
| Item              |                                                 | When Ring-OSC<br>Oscillation Continues         | When Ring-OSC<br>Oscillation Stopped <sup>Note 1</sup>                     | When Ring-OSC<br>Oscillation Continues                               | When Ring-OSC<br>Oscillation Stopped <sup>Note 1</sup> |  |  |  |
| System cloc       | k                                               | The X1 oscillator, Ring-OS0<br>CPU is stopped. | C oscillator, and subsystem of                                             | lock oscillator are able to osci                                     | illate. Clock supply to the                            |  |  |  |
| CPU               |                                                 | Operation stopped                              |                                                                            |                                                                      |                                                        |  |  |  |
| Port (latch)      |                                                 | Status before HALT mode v                      | was set is retained                                                        |                                                                      |                                                        |  |  |  |
| 16-bit timer/     | event counter 00                                | Operable                                       |                                                                            | Operation stopped                                                    |                                                        |  |  |  |
| 16-bit timer/     | event counter 01 Note 2                         | Operable                                       |                                                                            | Operation stopped                                                    |                                                        |  |  |  |
| 8-bit timer/e     | event counter 50                                | Operable                                       |                                                                            | Operable only when TI50 is                                           | selected as the count clock                            |  |  |  |
| 8-bit timer/e     | event counter 51                                | Operable                                       |                                                                            | Operable only when TI51 is                                           | selected as the count clock                            |  |  |  |
| 8-bit timer H0    |                                                 | Operable                                       |                                                                            | Operable only when TO50 i<br>clock during 8-bit timer/even           |                                                        |  |  |  |
| 8-bit timer H     | 11                                              | Operable                                       | Operable only when the<br>X1 input clock is selected<br>as the count clock | Operable only when $f_{\text{F}}/2^7$ is selected as the count clock | Operation stopped                                      |  |  |  |
| Watch time        |                                                 | Operable                                       |                                                                            | Operable only when subsystem clock is selected                       |                                                        |  |  |  |
| Watchdog<br>timer | Ring-OSC cannot<br>be stopped <sup>Note 3</sup> | Operable                                       | _                                                                          | Operable                                                             | _                                                      |  |  |  |
|                   | Ring-OSC can be stopped <sup>Note 3</sup>       | Operation stopped                              |                                                                            |                                                                      |                                                        |  |  |  |
| A/D convert       | er                                              | Operable                                       |                                                                            | Not operable                                                         |                                                        |  |  |  |
| Serial            | UART0                                           | Operable                                       |                                                                            | Operable only when TO50 is selected as the serial                    |                                                        |  |  |  |
| interface         | UART6                                           | Operable                                       |                                                                            | clock during TM50 operatio                                           | ck during TM50 operation                               |  |  |  |
|                   | CSI10                                           | Operable                                       |                                                                            | Operable only when external clock is selected as the serial clock    |                                                        |  |  |  |
|                   | CSI11 <sup>Note 2</sup> Operable                |                                                |                                                                            | Operable only when externation serial clock                          | al clock is selected as the                            |  |  |  |
|                   | CSIA0 Operable                                  |                                                |                                                                            | Operation stopped                                                    |                                                        |  |  |  |
| Clock monitor     |                                                 | Operable                                       | Operation stopped                                                          | <u> </u>                                                             |                                                        |  |  |  |
| Multiplier/div    | vider                                           | Operable                                       |                                                                            | Operation stopped                                                    |                                                        |  |  |  |
| Power-on-c        | lear function <sup>Note 4</sup>                 | Operable                                       |                                                                            | -                                                                    |                                                        |  |  |  |
| Low-voltage       | e detection function                            | Operable                                       |                                                                            |                                                                      |                                                        |  |  |  |
| External inte     | errupt                                          | Operable                                       | Operable                                                                   |                                                                      |                                                        |  |  |  |

# Table 21-2. Operating Statuses in HALT Mode (2/2)

**Notes 1.** When "Stopped by software" is selected for Ring-OSC by a mask option and Ring-OSC is stopped by software (for mask options, see **CHAPTER 27 MASK OPTIONS**).

**2.** *μ*PD780146, 780148, and 78F0148 only.

\*

- **3.** "Ring-OSC cannot be stopped" or "Ring-OSC can be stopped by software" can be selected by a mask option.
- 4. When "POC used" is selected by a mask option.

## (2) HALT mode release

The HALT mode can be released by the following two sources.

#### (a) Release by unmasked interrupt request

When an unmasked interrupt request is generated, the HALT mode is released. If interrupt acknowledgement is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgement is disabled, the next address instruction is executed.





- **Remarks 1.** The broken lines indicate the case when the interrupt request which has released the standby mode is acknowledged.
  - 2. The wait time is as follows:
    - When vectored interrupt servicing is carried out: 8 or 9 clocks
    - When vectored interrupt servicing is not carried out: 2 or 3 clocks

# (b) Release by RESET input

When the RESET signal is input, HALT mode is released, and then, as in the case with a normal reset operation, the program is executed after branching to the reset vector address.

## Figure 21-5. HALT Mode Release by RESET Input

#### (1) When X1 input clock is used as CPU clock







Remarks 1. fx: X1 input clock oscillation frequency

2. fr: Ring-OSC clock oscillation frequency

| Table 21-3. | Operation | After HALT | Mode | Release |
|-------------|-----------|------------|------|---------|
|-------------|-----------|------------|------|---------|

| Release Source                | MK××    | PR××         | IE | ISP | Operation                          |
|-------------------------------|---------|--------------|----|-----|------------------------------------|
| Maskable interrupt<br>request | 0       | 0            | 0  | ×   | Next address instruction execution |
|                               | 0       | 0            | 1  | ×   | Interrupt servicing execution      |
|                               | 0 1 0 1 | Next address |    |     |                                    |
|                               | 0       | 1            | ×  | 0   | instruction execution              |
|                               | 0       | 1            | 1  | 1   | Interrupt servicing execution      |
|                               | 1       | ×            | ×  | ×   | HALT mode held                     |
| RESET input                   | -       | -            | ×  | ×   | Reset processing                   |

×: Don't care

## 21.2.2 STOP mode

## (1) STOP mode setting and operating statuses

The STOP mode is set by executing the STOP instruction, and it can be set only when the CPU clock before the setting was the X1 input clock or Ring-OSC clock.

Caution Because the interrupt request signal is used to clear the standby mode, if there is an interrupt source with the interrupt request flag set and the interrupt mask flag reset, the standby mode is immediately cleared if set. Thus, the STOP mode is reset to the HALT mode immediately after execution of the STOP instruction and the system returns to the operating mode as soon as the wait time set using the oscillation stabilization time select register (OSTS) has elapsed.

The operating statuses in the STOP mode are shown below.

|                    | STOP Mode Settin                               | When STOP Instru                                                              | uction Is Executed W                                                                                              | hile CPU Is Operating        | g on X1 Input Clock              | When STOP Instr              | uction Is Executed                           |  |  |
|--------------------|------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------|----------------------------------|------------------------------|----------------------------------------------|--|--|
|                    |                                                | •                                                                             | When Ring-OSC Oscillation         When Ring-OSC Oscillation           Continues         Stopped <sup>Note 1</sup> |                              |                                  |                              | While CPU Is Operating on Ring-<br>OSC Clock |  |  |
| Item               |                                                | When Subsystem<br>Clock Used                                                  | When Subsystem<br>Clock Not Used                                                                                  | When Subsystem<br>Clock Used | When Subsystem<br>Clock Not Used | When Subsystem<br>Clock Used | When Subsystem<br>Clock Not Used             |  |  |
| System cloc        | k                                              | Only X1 oscillator                                                            | oscillation is stoppe                                                                                             | ed. Clock supply to          | the CPU is stopped               | l.                           |                                              |  |  |
| CPU                |                                                | Operation stopped                                                             | b                                                                                                                 |                              |                                  |                              |                                              |  |  |
| Port (latch)       |                                                | Status before STC                                                             | OP mode was set is                                                                                                | retained                     |                                  |                              |                                              |  |  |
| 16-bit timer/      | event counter 00                               | Operation stopped                                                             | b                                                                                                                 |                              |                                  |                              |                                              |  |  |
| 16-bit timer/      | event counter 01 <sup>№t</sup>                 | <sup>2</sup> Operation stopped                                                | b                                                                                                                 |                              |                                  |                              |                                              |  |  |
| 8-bit timer/e      | vent counter 50                                | Operable only wh                                                              | en TI50 is selected                                                                                               | as the count clock           |                                  |                              |                                              |  |  |
| 8-bit timer/e      | vent counter 51                                | Operable only wh                                                              | en TI51 is selected                                                                                               | as the count clock           |                                  |                              |                                              |  |  |
| 8-bit timer H      | 0                                              | Operable only whe                                                             | en TO50 is selected                                                                                               | as the count clock           | during 8-bit timer/e             | vent counter 50 ope          | eration                                      |  |  |
| 8-bit timer H      | 1                                              | Operable <sup>Note 3</sup>                                                    | Operable <sup>Note 3</sup> Operation stopped                                                                      |                              | Operable <sup>Note 3</sup>       |                              |                                              |  |  |
| Watch timer        |                                                | Operable <sup>Note 4</sup>                                                    | Operation stopped                                                                                                 | Operable <sup>Note 4</sup>   | Operation stopped                | Operable <sup>Note 4</sup>   | Operation stopped                            |  |  |
| Watchdog<br>timer  | Ring-OSC canno<br>be stopped <sup>Note 5</sup> | Operable                                                                      | Operable – Operable                                                                                               |                              |                                  |                              |                                              |  |  |
|                    | Ring-OSC can be<br>stopped <sup>№te 5</sup>    | Operation stopped                                                             | Operation stopped                                                                                                 |                              |                                  |                              |                                              |  |  |
| A/D converte       | er                                             | Operation stopped                                                             | Operation stopped                                                                                                 |                              |                                  |                              |                                              |  |  |
| Serial interfa     | ace UART0                                      | Operable only when TO50 is selected as the serial clock during TM50 operation |                                                                                                                   |                              |                                  |                              |                                              |  |  |
|                    | UART6                                          |                                                                               |                                                                                                                   |                              |                                  |                              |                                              |  |  |
|                    | CSI10                                          | Operable only when external SCK10 is selected as the serial clock             |                                                                                                                   |                              |                                  |                              |                                              |  |  |
|                    | CSI11 <sup>Note 2</sup>                        | Operable only wh                                                              | Operable only when external SCK11 is selected as the serial clock                                                 |                              |                                  |                              |                                              |  |  |
|                    | CSIA0                                          | Operation stopped                                                             |                                                                                                                   |                              |                                  |                              |                                              |  |  |
| Clock monite       | or                                             | Operation stopped                                                             | Operation stopped                                                                                                 |                              |                                  |                              |                                              |  |  |
| Multiplier/divider |                                                | Operation stopped                                                             | Operation stopped                                                                                                 |                              |                                  |                              |                                              |  |  |
| Power-on-cl        | ear function <sup>Note 6</sup>                 | Operable                                                                      |                                                                                                                   |                              |                                  |                              |                                              |  |  |
| Low-voltage        | detection function                             | Operable                                                                      |                                                                                                                   |                              |                                  |                              |                                              |  |  |
| External inte      | errupt                                         | Operable                                                                      | Operable                                                                                                          |                              |                                  |                              |                                              |  |  |

 Table 21-4. Operating Statuses in STOP Mode

Notes 1. When "Stopped by software" is selected for Ring-OSC by a mask option and Ring-OSC is stopped by software (for mask options, see CHAPTER 27 MASK OPTIONS).

- **2.** *μ*PD780146, 780148, and 78F0148 only.
- **3.** Operation continues only when  $f_{\rm R}/2^7$  is selected as the count clock.
- 4. Operable when the subsystem clock is selected.
- 5. "Ring-OSC cannot be stopped" or "Ring-OSC can be stopped by software" can be selected by a mask option.
- 6. When "POC used" is selected by a mask option.

#### (2) STOP mode release

The STOP mode can be released by the following two sources.

#### (a) Release by unmasked interrupt request

When an unmasked interrupt request is generated, the STOP mode is released. After the oscillation stabilization time has elapsed, if interrupt acknowledgement is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgement is disabled, the next address instruction is executed.

#### Figure 21-6. STOP Mode Release by Interrupt Request Generation



(1) When X1 input clock is used as CPU clock

**Remark** The broken lines indicate the case when the interrupt request that has released the standby mode is acknowledged.

# (b) Release by RESET input

When the RESET signal is input, STOP mode is released and a reset operation is performed after the oscillation stabilization time has elapsed.

## Figure 21-7. STOP Mode Release by RESET Input

#### (1) When X1 input clock is used as CPU clock



(2) When Ring-OSC clock is used as CPU clock



| Table 21-5. | <b>Operation After STOP Mode Release</b> |
|-------------|------------------------------------------|
|-------------|------------------------------------------|

| Release Source                | MK×× | PR×× | IE | ISP | Operation                          |
|-------------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt<br>request | 0    | 0    | 0  | ×   | Next address instruction execution |
|                               | 0    | 0    | 1  | ×   | Interrupt servicing execution      |
|                               | 0    | 1    | 0  | 1   | Next address                       |
|                               | 0    | 1    | ×  | 0   | instruction execution              |
|                               | 0    | 1    | 1  | 1   | Interrupt servicing execution      |
|                               | 1    | ×    | ×  | ×   | STOP mode held                     |
| RESET input                   | _    | _    | ×  | ×   | Reset processing                   |

×: Don't care

## **CHAPTER 22 RESET FUNCTION**

The following five operations are available to generate a reset signal.

- (1) External reset input via RESET pin
- (2) Internal reset by watchdog timer program loop detection
- (3) Internal reset by clock monitor X1 clock oscillation stop detection
- (4) Internal reset by comparison of supply voltage and detection voltage of power-on-clear (POC) circuit
- (5) Internal reset by comparison of supply voltage and detection voltage of low-power-supply detector (LVI)

External and internal resets have no functional differences. In both cases, program execution starts at the address at 0000H and 0001H when the reset signal is input.

A reset is applied when a low level is input to the RESET pin, the watchdog timer overflows, X1 clock oscillation stop is detected by the clock monitor, or by POC and LVI circuit voltage detection, and each item of hardware is set to the status shown in Table 22-1. Each pin is high impedance during reset input or during the oscillation stabilization time just after reset release, except for P130, which is low-level output.

When a high level is input to the RESET pin, the reset is released and program execution starts using the Ring-OSC clock after the CPU clock operation has stopped for  $17/f_R$  (s). A reset generated by the watchdog timer and clock monitor sources is automatically released after the reset, and program execution starts using the Ring-OSC clock after the CPU clock operation has stopped for  $17/f_R$  (s) (see **Figures 22-2** to **22-4**). Reset by POC and LVI circuit power supply detection is automatically released when  $V_{DD} > V_{POC}$  or  $V_{DD} > V_{LVI}$  after the reset, and program execution starts using the Ring-OSC clock after the CPU clock operation has stopped for  $17/f_R$  (s) (see **CHAPTER 24 POWER-ON-CLEAR CIRCUIT** and **CHAPTER 25 LOW-VOLTAGE DETECTOR**).

Cautions 1. For an external reset, input a low level for 10  $\mu$ s or more to the RESET pin.

- 2. During reset input, the X1 input clock and Ring-OSC clock stop oscillating.
- 3. When the STOP mode is released by a reset, the STOP mode contents are held during reset input. However, the port pins become high-impedance, except for P130, which is set to low-level output.



## Figure 22-1. Block Diagram of Reset Function

# Caution An LVI circuit internal reset does not reset the LVI circuit.

Remarks 1. LVIM: Low-voltage detection register

2. LVIS: Low-voltage detection level selection register



Caution A watchdog timer internal reset resets the watchdog timer.



Figure 22-4. Timing of Reset in STOP Mode by RESET Input



Remark For the reset timing of the power-on-clear circuit and low-voltage detector, see CHAPTER 24 POWER-ON-CLEAR CIRCUIT and CHAPTER 25 LOW-VOLTAGE DETECTOR.

|                                                       | Hardware                                                                  | Status After Reset          |
|-------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------|
| Program counter (PC)                                  | The contents of the<br>reset vector table<br>(0000H, 0001H) are<br>set.   |                             |
| Stack pointer (SP)                                    |                                                                           | Undefined                   |
| Program status word                                   | (PSW)                                                                     | 02H                         |
| RAM                                                   | Data memory                                                               | Undefined <sup>Note 2</sup> |
|                                                       | General-purpose registers                                                 | Undefined <sup>Note 2</sup> |
| Ports (P0 to P7, P12 t                                | o P14) (output latches)                                                   | 00H                         |
| Port mode registers (F                                | PM0, PM1, PM3 to PM7, PM12, PM14)                                         | FFH                         |
| Pull-up resistor option                               | registers (PU0, PU1, PU3 to PU7, PU12, PU14)                              | 00H                         |
| Input switch control re                               | igister (ISC)                                                             | 00H                         |
| Internal memory size                                  | switching register (IMS)                                                  | CFH                         |
| Internal expansion RA                                 | M size switching register (IXS)                                           | 0CH                         |
| Memory expansion m                                    | ode register (MEM)                                                        | 00H                         |
| Memory expansion wa                                   | ait setting register (MM)                                                 | 10H                         |
| Processor clock contr                                 | ol register (PCC)                                                         | 00H                         |
| Ring-OSC mode regis                                   | ster (RCM)                                                                | 00H                         |
| Main clock mode register (MCM)                        |                                                                           | 00H                         |
| Main OSC control register (MOC)                       |                                                                           | 00H                         |
| Oscillation stabilization time select register (OSTS) |                                                                           | 05H                         |
| Oscillation stabilizatio                              | n time counter status register (OSTC)                                     | 00H                         |
| 16-bit timer/event                                    | Timer counters 00, 01 (TM00, TM01)                                        | 0000H                       |
| counters 00, 01 <sup>Note 3</sup>                     | Capture/compare registers 000, 010, 001, 011 (CR000, CR010, CR001, CR011) | 0000H                       |
|                                                       | Mode control registers 00, 01 (TMC00, TMC01)                              | 00H                         |
|                                                       | Prescaler mode registers 00, 01 (PRM00, PRM01)                            | 00H                         |
|                                                       | Capture/compare control registers 00, 01 (CRC00, CRC01)                   | 00H                         |
|                                                       | Timer output control registers 00, 01 (TOC00, TOC01)                      | 00H                         |
| 8-bit timer/event                                     | Timer counters 50, 51 (TM50, TM51)                                        | 00H                         |
| counters 50, 51                                       | Compare registers 50, 51 (CR50, CR51)                                     | 00H                         |
|                                                       | Timer clock selection registers 50, 51 (TCL50, TCL51)                     | 00H                         |
|                                                       | Mode control registers 50, 51 (TMC50, TMC51)                              | 00H                         |
| 8-bit timers H0, H1                                   | Compare registers 00, 10, 01, 11 (CMP00, CMP10, CMP01, CMP11)             | 00H                         |
|                                                       | Mode registers (TMHMD0, TMHMD1)                                           | 00H                         |
|                                                       | Carrier control register 1 (TMCYC1) <sup>Note 4</sup>                     | 00H                         |
| Watch timer                                           | Operation mode register (WTM)                                             | 00H                         |
| Clock output/buzzer output controller                 | Clock output selection register (CKS)                                     | 00H                         |

#### Table 22-1. Hardware Statuses After Reset (1/3)

**Notes 1.** During reset input or oscillation stabilization time wait, only the PC contents among the hardware statuses become undefined. All other hardware statuses remain unchanged after reset.

2. When a reset is executed in the standby mode, the pre-reset status is held even after reset.

**3.** 16-bit timer/event counter 01 is available only for the  $\mu$ PD780146, 780148, and 78F0148.

4. 8-bit timer H1 only.

|                          | Hardware                                                                | Status After Reset |
|--------------------------|-------------------------------------------------------------------------|--------------------|
| Watchdog timer           | Mode register (WDTM)                                                    | 67H                |
|                          | Enable register (WDTE)                                                  | 9AH                |
| A/D converter            | Conversion result register (ADCR)                                       | Undefined          |
|                          | Mode register (ADM)                                                     | 00H                |
|                          | Analog input channel specification register (ADS)                       | 00H                |
|                          | Power-fail comparison mode register (PFM)                               | 00H                |
|                          | Power-fail comparison threshold register (PFT)                          | 00H                |
| Serial interface UART0   | Receive buffer register 0 (RXB0)                                        | FFH                |
|                          | Transmit shift register 0 (TXS0)                                        | FFH                |
|                          | Asynchronous serial interface operation mode register 0 (ASIM0)         | 01H                |
|                          | Baud rate generator control register 0 (BRGC0)                          | 1FH                |
| Serial interface UART6   | Receive buffer register 6 (RXB6)                                        | FFH                |
|                          | Transmit buffer register 6 (TXB6)                                       | FFH                |
|                          | Asynchronous serial interface operation mode register 6 (ASIM6)         | 01H                |
|                          | Asynchronous serial interface reception error status register 6 (ASIS6) | 00H                |
|                          | Asynchronous serial interface transmission status register 6 (ASIF6)    | 00H                |
|                          | Clock selection register 6 (CKSR6)                                      | 00H                |
|                          | Baud rate generator control register 6 (BRGC6)                          | FFH                |
|                          | Asynchronous serial interface control register 6 (ASICL6)               | 16H                |
| Serial interfaces CSI10, | Transmit buffer registers 10, 11 (SOTB10, SOTB11)                       | Undefined          |
| CSI11 <sup>Note</sup>    | Serial I/O shift registers 10, 11 (SIO10, SIO11)                        | Undefined          |
|                          | Serial operation mode registers 10, 11 (CSIM10, CSIM11)                 | 00H                |
|                          | Serial clock selection registers 10, 11 (CSIC10, CSIC11)                | 00H                |
| Serial interface CSIA0   | Shift register 0 (SIOA0)                                                | 00H                |
|                          | Operation mode specification register 0 (CSIMA0)                        | 00H                |
|                          | Status register 0 (CSIS0)                                               | 00H                |
|                          | Trigger register 0 (CSIT0)                                              | 00H                |
|                          | Divisor selection register 0 (BRGCA0)                                   | 03H                |
|                          | Automatic data transfer address point specification register 0 (ADTP0)  | 00H                |
|                          | Automatic data transfer interval specification register 0 (ADTI0)       | 00H                |
|                          | Automatic data transfer address count register 0 (ADTC0)                | 00H                |
| Multiplier/divider       | Remainder data register 0 (SDR0)                                        | 0000H              |
|                          | Multiplication/division data register A0 (MDA0H, MDA0L)                 | 0000H              |
|                          | Multiplication/division data register B0 (MDB0)                         | 0000H              |
|                          | Multiplier/divider control register 0 (DMUC0)                           | 00H                |
| Key interrupt            | Key return mode register (KRM)                                          | 00H                |
| Clock monitor            | Mode register (CLM)                                                     | 00H                |

| Table 22-1 | Hardware Statuses | After Reset (2/3) |
|------------|-------------------|-------------------|
|            | naruware Statuses |                   |

**Note** Serial interface CSI11 is available only for the  $\mu$ PD780146, 780148, and 78F0148.

|                      | Status After Reset                                                            |                     |
|----------------------|-------------------------------------------------------------------------------|---------------------|
| Reset function       | Reset control flag register (RESF)                                            | 00H <sup>Note</sup> |
| Low-voltage detector | Low-voltage detection register (LVIM)                                         | 00H <sup>Note</sup> |
|                      | Low-voltage detection level selection register (LVIS)                         | 00H <sup>Note</sup> |
| Interrupt            | Request flag registers 0L, 0H, 1L, 1H (IF0L, IF0H, IF1L, IF1H)                | 00H                 |
|                      | Mask flag registers 0L, 0H, 1L, 1H (MK0L, MK0H, MK1L, MK1H)                   | FFH                 |
|                      | Priority specification flag registers 0L, 0H, 1L, 1H (PR0L, PR0H, PR1L, PR1H) | FFH                 |
|                      | External interrupt rising edge enable register (EGP)                          | 00H                 |
|                      | External interrupt falling edge enable register (EGN)                         | 00H                 |

# Table 22-1. Hardware Statuses After Reset (3/3)

**Note** These values vary depending on the reset source.

| Reset Source<br>Register | RESET Input     | Reset by POC  | Reset by WDT  | Reset by CLM  | Reset by LVI |
|--------------------------|-----------------|---------------|---------------|---------------|--------------|
| RESF                     | See Table 22-2. |               |               |               |              |
| LVIM                     | Cleared (00H)   | Cleared (00H) | Cleared (00H) | Cleared (00H) | Held         |
| LVIS                     |                 |               |               |               |              |

## 22.1 Register for Confirming Reset Source

Many internal reset generation sources exist in the 78K0/KF1 Series. The reset control flag register (RESF) is used to store which source has generated the reset request.

RESF can be read by an 8-bit memory manipulation instruction.

RESET input, reset input by power-on-clear (POC) circuit, and reading RESF clear RESF to 00H.

#### Figure 22-5. Format of Reset Control Flag Register (RESF)



| WDTRF | Internal reset request by watchdog timer (WDT)               |  |
|-------|--------------------------------------------------------------|--|
| 0     | Internal reset request is not generated, or RESF is cleared. |  |
| 1     | Internal reset request is generated.                         |  |

| CLMRF | Internal reset request by clock monitor (CLM)                |
|-------|--------------------------------------------------------------|
| 0     | Internal reset request is not generated, or RESF is cleared. |
| 1     | Internal reset request is generated.                         |

| LVIRF | Internal reset request by low-voltage detector (LVI)         |
|-------|--------------------------------------------------------------|
| 0     | Internal reset request is not generated, or RESF is cleared. |
| 1     | Internal reset request is generated.                         |

Note The value after reset varies depending on the reset source.

#### Caution Do not read data by a 1-bit memory manipulation instruction.

The status of RESF when a reset request is generated is shown in Table 22-2.

| Reset Source | RESET input | Reset by POC | Reset by WDT | Reset by CLM | Reset by LVI |
|--------------|-------------|--------------|--------------|--------------|--------------|
| WDTRF        | Cleared (0) | Cleared (0)  | Set (1)      | Held         | Held         |
| CLMRF        |             |              | Held         | Set (1)      | Held         |
| LVIRF        |             |              | Held         | Held         | Set (1)      |

# **CHAPTER 23 CLOCK MONITOR**

# 23.1 Functions of Clock Monitor

The clock monitor samples the X1 input clock using the on-chip Ring-OSC, and generates an internal reset signal when the X1 input clock is stopped.

When a reset signal is generated by the clock monitor, bit 1 (CLMRF) of the reset control flag register (RESF) is set to 1. For details of RESF, refer to **CHAPTER 22 RESET FUNCTION**.

The clock monitor automatically stops under the following conditions.

- In STOP mode and during the oscillation stabilization time
- When the X1 input clock is stopped by software (MSTOP = 1 or MCC = 1)
- During the oscillation stabilization time after reset is released
- When the Ring-OSC clock is stopped

Remark MSTOP: Bit 7 of the main OSC control register (MOC)

## 23.2 Configuration of Clock Monitor

Clock monitor consists of the following hardware.

### Table 23-1. Configuration of Clock Monitor

| Item             | Configuration                     |  |
|------------------|-----------------------------------|--|
| Control register | Clock monitor mode register (CLM) |  |



Figure 23-1. Block Diagram of Clock Monitor

Clock monitor mode register (CLM)

## 23.3 Registers Controlling Clock Monitor

Clock monitor is controlled by the clock monitor mode register (CLM).

## (1) Clock monitor mode register (CLM)

This register sets the operation mode of the clock monitor. This register can be set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears this register to 00H.

#### Figure 23-2. Format of Clock Monitor Mode Register (CLM)

| Address: FFA9H |   | After reset: 00H | R/W |   |   |   |   |      |
|----------------|---|------------------|-----|---|---|---|---|------|
| Symbol         | 7 | 6                | 5   | 4 | 3 | 2 | 1 | 0    |
| CLM            | 0 | 0                | 0   | 0 | 0 | 0 | 0 | CLME |
|                |   |                  |     |   |   |   |   |      |

| CLME | Enables/disables clock monitor operation |  |  |  |
|------|------------------------------------------|--|--|--|
| 0    | Disables clock monitor operation         |  |  |  |
| 1    | Enables clock monitor operation          |  |  |  |

- Cautions 1. Once bit 0 (CLME) is set to 1, it cannot be cleared to 0 except by RESET input or the internal reset signal.
  - 2. If the reset signal is generated by the clock monitor, CLME is cleared to 0 and bit 1 (CLMRF) of the reset control flag register (RESF) is set to 1. CLMRF is read by software and then automatically cleared to 0. CLMRF is cleared under the following conditions.
    - RESET input
    - Internal reset signal generation by POC
    - After read by software

# 23.4 Operation of Clock Monitor

This section explains the functions of the clock monitor. The start and stop conditions are as follows.

<Start condition>

When bit 0 (CLME) of the clock monitor mode register (CLM) is set to operation enabled (1).

<Stop condition>

+

- In STOP mode and during the oscillation stabilization time
- During the oscillation stabilization time after reset is released
- When the X1 input clock is stopped by software (MSTOP = 1 or MCC = 1)
  - When the Ring-OSC clock is stopped

Remark MSTOP: Bit 7 of the main OSC control register (MOC)

# Table 23-2. Operation Status of Clock Monitor (When CLME = 1)

| CPU Operation Clock | Operation Mode | X1 Input Clock Status | Ring-OSC Clock Status   | Clock Monitor Status |  |
|---------------------|----------------|-----------------------|-------------------------|----------------------|--|
| X1 input clock      | STOP mode      | Stopped               | Oscillating             | Stopped              |  |
|                     |                |                       | Stopped <sup>Note</sup> |                      |  |
|                     | RESET input    |                       | Oscillating             |                      |  |
|                     |                |                       | Stopped <sup>Note</sup> |                      |  |
|                     | HALT mode      | Oscillating           | Oscillating             | Operating            |  |
|                     |                |                       | Stopped <sup>Note</sup> | Stopped              |  |
| Ring-OSC clock      | STOP mode      | Stopped               | Oscillating             | Stopped              |  |
|                     | RESET input    |                       |                         |                      |  |
|                     | HALT mode      | Oscillating           | ]                       | Operating            |  |
|                     |                | Stopped               | ]                       | Stopped              |  |

**Note** The Ring-OSC clock is stopped only when the "Ring-OSC can be stopped by software" is selected by a mask option. If "Ring-OSC cannot be stopped" is selected, the Ring-OSC clock cannot be stopped.

The clock monitor timing is as shown in Figure 23-3.

### Figure 23-3. Timing of Clock Monitor (1/3)

#### (1) When internal reset is executed by oscillation stop of X1 input clock

. ....

----

|                       | 4 clocks of Ring-OSC clock |  |  |  |   |   |  |
|-----------------------|----------------------------|--|--|--|---|---|--|
| X1 input clock        |                            |  |  |  | • |   |  |
| Ring-OSC clock        |                            |  |  |  |   | } |  |
| Internal reset signal |                            |  |  |  | X |   |  |
| CLME                  |                            |  |  |  |   |   |  |
| CLMRF <sup>Note</sup> |                            |  |  |  |   |   |  |

- **Note** CLMRF is read by software and then automatically cleared to 0. CLMRF is cleared under the following conditions.
  - RESET input
  - Internal reset signal generation by POC
  - After read by software

# (2) Clock monitor status after STOP mode is released

## (CLME = 1 is set when CPU clock operates on X1 input clock and before entering STOP mode)



When bit 0 (CLME) of the clock monitor mode register (CLM) is set to 1 before entering STOP mode, monitoring automatically starts at the end of the X1 input clock oscillation stabilization time. Monitoring is stopped in STOP mode and during the oscillation stabilization time.





When bit 0 (CLME) of the clock monitor mode register (CLM) is set to 1 before entering STOP mode, monitoring automatically starts at the end of the X1 input clock oscillation stabilization time. Monitoring is stopped in STOP mode and during the oscillation stabilization time.



(4) Clock monitor status after RESET input

RESET input clears bit 0 (CLME) of the clock monitor mode register (CLM) to 0 and stops the clock monitor operation. Even if CLME is set to 1 by software during the oscillation stabilization time of the X1 input clock, monitoring is not performed until the oscillation stabilization time of the X1 input clock ends. Monitoring is automatically started at the end of the oscillation stabilization time.

## Figure 23-3. Timing of Clock Monitor (3/3)



RESET input clears bit 0 (CLME) of the clock monitor mode register (CLM) to 0 and stops the clock monitor operation. When CLME is set to 1 by software at the end of the oscillation stabilization time of the X1 input clock, monitoring is started.

## CHAPTER 24 POWER-ON-CLEAR CIRCUIT

## 24.1 Functions of Power-on-Clear Circuit

The power-on-clear circuit (POC) has the following functions.

- Generates internal reset signal at power on.
- Compares supply voltage (VDD) and detection voltage (VPOC), and generates internal reset signal when VDD < VPOC.</li>
- The following can be selected by a mask option.
  - POC disabled
  - POC used (detection voltage:  $V_{POC} = 2.85 \text{ V} \pm 0.15 \text{ V}$ )
  - POC used (detection voltage:  $V_{POC} = 3.5 \text{ V} \pm 0.2 \text{ V}$ )
- Caution If an internal reset signal is generated in the POC circuit, the reset control flag register (RESF) is cleared to 00H.
- **Remark** This product incorporates multiple hardware functions that generate an internal reset signal. A flag that indicates the reset cause is located in the reset control flag register (RESF) for when an internal reset signal is generated by the watchdog timer (WDT), low-voltage-detection (LVI) circuit, or clock monitor. RESF is not cleared to 00H and the flag is set to 1 when an internal reset signal is generated by WDT, LVI, or the clock monitor.

For details of the RESF, refer to CHAPTER 22 RESET FUNCTION.

## 24.2 Configuration of Power-on-Clear Circuit

The block diagram of the power-on-clear circuit is shown in Figure 24-1.





## 24.3 Operation of Power-on-Clear Circuit

In the power-on-clear circuit, the supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>POC</sub>) are compared, and when  $V_{DD} < V_{POC}$ , an internal reset signal is generated.





## ★ 24.4 Cautions for Power-on-Clear Circuit

In a system where the supply voltage (VDD) fluctuates for a certain period in the vicinity of the POC detection voltage (VPOC), the system may be repeatedly reset and released from the reset status. In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking the following action.

#### <Action>

After releasing the reset signal, wait for the supply voltage fluctuation period of each system by means of a software counter that uses a timer, and then initialize the ports.

#### Figure 24-3. Example of Software Processing After Release of Reset (1/2)

• If supply voltage fluctuation is 50 ms or less in vicinity of POC detection voltage





2. A flowchart is shown on the next page.



Figure 24-3. Example of Software Processing After Release of Reset (2/2)

Checking reset cause

## CHAPTER 25 LOW-VOLTAGE DETECTOR

## 25.1 Functions of Low-Voltage Detector

The low-voltage detector (LVI) has following functions.

- Compares supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>LVI</sub>), and generates an internal interrupt signal or internal reset signal when V<sub>DD</sub> < V<sub>LVI</sub>.
- Detection levels (five levels) of supply voltage can be changed by software.
- Interrupt or reset function can be selected by software.
- Operable in STOP mode.

When the low-voltage detector is used to reset, bit 0 (LVIRF) of the reset control flag register (RESF) is set to 1 if reset occurs. For details of RESF, refer to **CHAPTER 22 RESET FUNCTION**.

## 25.2 Configuration of Low-Voltage Detector

The block diagram of the low-voltage detector is shown below.





## 25.3 Registers Controlling Low-Voltage Detector

The low-voltage detector is controlled by the following registers.

- Low-voltage detection register (LVIM)
- Low-voltage detection level selection register (LVIS)

## (1) Low-voltage detection register (LVIM)

This register sets low-voltage detection and the operation mode. This register can be set by a 1-bit or 8-bit memory manipulation instruction.

#### Figure 25-2. Format of Low-Voltage Detection Register (LVIM)

| Address: FFBEH After reset: 00H |       |   | I R/W |      |   |   |       |      |
|---------------------------------|-------|---|-------|------|---|---|-------|------|
| Symbol                          | 7     | 6 | 5     | 4    | 3 | 2 | 1     | 0    |
| LVIM                            | LVION | 0 | 0     | LVIE | 0 | 0 | LVIMD | LVIF |

| LVIONNotes 1, 2 | Enables low-voltage detection operation |  |  |  |  |
|-----------------|-----------------------------------------|--|--|--|--|
| 0               | Disables operation                      |  |  |  |  |
| 1               | Enables operation                       |  |  |  |  |

| LVIE <sup>Notes 1, 3, 4</sup> | Specifies reference voltage generator |  |  |  |  |
|-------------------------------|---------------------------------------|--|--|--|--|
| 0                             | Disables operation                    |  |  |  |  |
| 1                             | Enables operation                     |  |  |  |  |

| LVIMD <sup>Note 1</sup> | Low-voltage detection operation mode selection                                                |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0                       | Generates interrupt signal when supply voltage ( $V_{DD}$ ) < detection voltage ( $V_{LVI}$ ) |  |  |  |  |  |
| 1                       | Generates internal reset signal when supply voltage (V_DD) < detection voltage (V_LVI)        |  |  |  |  |  |

| LVIF <sup>Note 5</sup> | Low-voltage detection flag                                                                   |
|------------------------|----------------------------------------------------------------------------------------------|
| 0                      | Supply voltage ( $V_{DD}$ ) > detection voltage ( $V_{LVI}$ ), or when operation is disabled |
| 1                      | Supply voltage (V <sub>DD</sub> ) < detection voltage (V <sub>LVI</sub> )                    |

Notes 1. LVION, LVIE, and LVIMD are cleared to 0 at a reset other than an LVI reset. These are not cleared to 0 at an LVI reset.

- 2. When LVION is set to 1, operation of the comparator in the LVI circuit is started. Use software to instigate a wait of at least 0.2 ms from when LVION is set to 1 until the voltage is confirmed at LVIF.
- 3. When LVIE is set to 1, a reference voltage generator operation in the LVI circuit is started. Use software to instigate a wait of at least 2 ms from when LVIE is set to 1 until LVION is set to 1.
- 4. If "use POC" is selected by a mask option, leave LVIE as 0. A wait time (2 ms) until LVION is set to 1 is not necessary.
- 5. The value of LVIF is output as the interrupt request signal INTLVI when LVION = 1 and LVIMD = 0.

### Caution To stop LVI, follow either of the procedures below.

- When using 8-bit manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVION to 0 first and then clear LVIE to 0.

## (2) Low-voltage detection level selection register (LVIS)

\*

This register selects the low-voltage detection level. This register can be set by an 8-bit memory manipulation instruction.

| Address: | FFBFH Aft                         | er reset: 00⊢ | I R/W |                                       |         |       |       |       |  |
|----------|-----------------------------------|---------------|-------|---------------------------------------|---------|-------|-------|-------|--|
| Symbol   | 7                                 | 6             | 5     | 4                                     | 3       | 2     | 1     | 0     |  |
| LVIS     | 0                                 | 0             | 0     | 0                                     | 0       | LVIS2 | LVIS1 | LVIS0 |  |
|          |                                   |               |       |                                       |         |       |       |       |  |
|          | LVIS2 LVIS1 LVIS0 Detection level |               |       |                                       |         |       |       |       |  |
|          | 0                                 | 0             | 0     | VLVI0 (4.3 V                          | ±0.2 V) |       |       |       |  |
|          | 0                                 | 0             | 1     | VLVI1 (4.1 V                          | ±0.2 V) |       |       |       |  |
|          | 0                                 | 1             | 0     | VLVI2 (3.9 V                          | ±0.2 V) |       |       |       |  |
|          | 0                                 | 1             | 1     | VLVI3 (3.7 V                          | ±0.2 V) |       |       |       |  |
|          | 1                                 | 0             | 0     | VLVI4 (3.5 V ±0.2 V) <sup>Note</sup>  |         |       |       |       |  |
|          | 1                                 | 0             | 1     | VLVI5 (3.3 V ±0.15 V) <sup>Note</sup> |         |       |       |       |  |
|          | 1                                 | 1             | 0     | VLVI6 (3.1 V ±0.15 V) <sup>Note</sup> |         |       |       |       |  |
|          | 1                                 | 1             | 1     | Setting prohibited                    |         |       |       |       |  |

#### Figure 25-3. Format of Low-Voltage Detection Level Selection Register (LVIS)

**Note** When the detection voltage of the POC circuit is specified as  $V_{POC} = 3.5 \text{ V} \pm 0.2 \text{ V}$  by a mask option, do not select  $V_{LVI4}$  to  $V_{LVI6}$  as the LVI detection voltage. Even if  $V_{LVI4}$  to  $V_{LVI6}$  are selected, POC circuit has priority.

## 25.4 Operation of Low-Voltage Detector

The low-voltage detector can be used in the following two modes.

· Used as reset

Compares the supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>LVI</sub>), and generates an internal reset signal when  $V_{DD} < V_{LVI}$ .

· Used as interrupt

Compares the supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>LVI</sub>), and generates an interrupt signal (INTLVI) when  $V_{DD} < V_{LVI}$ .

The operation is set as follows.

- (1) When used as reset
  - When starting operation
  - <1> Mask the LVI interrupt (LVIMK = 1).
  - <2> Set the detection voltage using bits 2 to 0 (LVIS2 to LVIS0) of the low-voltage detection level selection register (LVIS).
  - <3> Set bit 4 (LVIE) of the low-voltage detection register (LVIM) to 1 (enables reference voltage generator operation).
  - <4> Use software to instigate a wait of at least 2 ms.
  - <5> Set bit 7 (LVION) of LVIM to 1 (enables LVI operation).
  - <6> Use software to instigate a wait of at least 0.2 ms.
  - <7> Confirm that "supply voltage (VDD) > detection voltage (VLVI)" at bit 0 (LVIF) of LVIM.
  - <8> Set bit 1 (LVIMD) of LVIM to 1 (generates internal reset signal when supply voltage (V<sub>DD</sub>) < detection voltage (V<sub>LVI</sub>)).
  - Cautions 1. <1> must always be executed. When LVIMK = 0, an interrupt may occur immediately after the processing in <5>.
    - 2. If "use POC" is selected by a mask option, procedures <3> and <4> are not required.
    - 3. If supply voltage (VDD) > detection voltage (VLVI) when LVIM is set to 1, an internal reset signal is not generated.
  - When stopping operation

Either of the following procedures must be executed.

- When using 8-bit memory manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVIMD to 0, LVION to 0, and LVIE to 0 in that order.



Figure 25-4. Timing of Low-Voltage Detector Internal Reset Signal Generation

- Note LVIRF is bit 0 of the reset control flag register (RESF). For details of RESF, refer to CHAPTER 22 RESET FUNCTION.
- **Remark** <1> to <8> in Figure 25-4 above correspond to <1> to <8> in the description of "when starting operation" in **25.4 (1) When used as reset**.

- (2) When used as interrupt
  - When starting operation
  - <1> Mask the LVI interrupt (LVIMK = 1).
  - <2> Set the detection voltage using bits 2 to 0 (LVIS2 to LVIS0) of the low-voltage detection level selection register (LVIS).
  - <3> Set bit 4 (LVIE) of the low-voltage detection register (LVIM) to 1 (enables reference voltage generator operation).
  - <4> Use software to instigate a wait of at least 2 ms.
  - <5> Set bit 7 (LVION) of LVIM to 1 (enables LVI operation).
  - <6> Use software to instigate a wait of at least 0.2 ms.
  - <7> Confirm that "supply voltage (VDD) > detection voltage (VLVI)" at bit 0 (LVIF) of LVIM.
  - <8> Clear the interrupt request flag of LVI (LVIIF) to 0.
  - <9> Release the interrupt mask flag of LVI (LVIMK).
  - <10> Execute the EI instruction (when vector interrupts are used).

### Caution If "use POC" is selected by a mask option, procedures <3> and <4> are not required.

• When stopping operation

Either of the following procedures must be executed.

- When using 8-bit memory manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVION to 0 first, and then clear LVIE to 0.



Figure 25-5. Timing of Low-Voltage Detector Interrupt Signal Generation

**Remark** <1> to <9> in Figure 25-5 above correspond to <1> to <9> in the description of "when starting operation" in **25.4 (2) When used as interrupt**.

## \* 25.5 Cautions for Low-Voltage Detector

In a system where the supply voltage ( $V_{DD}$ ) fluctuates for a certain period in the vicinity of the LVI detection voltage ( $V_{LVI}$ ), the operation is as follows depending on how the low-voltage detector is used.

#### (1) When used as reset

The system may be repeatedly reset and released from the reset status.

In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking action (1) below.

## (2) When used as interrupt

Interrupt requests may be frequently generated. Take action (2) below.

In this system, take the following actions.

#### <Action>

## (1) When used as reset

After releasing the reset signal, wait for the supply voltage fluctuation period of each system by means of a software counter that uses a timer, and then initialize the ports.



#### Figure 25-6. Example of Software Processing After Release of Reset (1/2)

• If supply voltage fluctuation is 50 ms or less in vicinity of LVI detection voltage

- Notes 1. If reset is generated again during this period, initialization processing is not started.
  - 2. A flowchart is shown on the next page.



Checking reset cause



## (2) When used as interrupt

Disable interrupts (DI) in the servicing routine of the LVI interrupt, and check to see if "supply voltage ( $V_{DD}$ ) > detection voltage ( $V_{LVI}$ )", by using bit 0 (LVIF) of the low-voltage detection register (LVIM). Then enable interrupts (EI).

In a system where the supply voltage fluctuation period is long in the vicinity of the LVI detection voltage, disable interrupts (DI), wait for the supply voltage fluctuation period, check that "supply voltage ( $V_{DD}$ ) > detection voltage ( $V_{LVI}$ )" with the LVIF flag, and then enable interrupts (EI).

#### Figure 25-7. Example of Software Processing of LVI Interrupt

• If supply voltage fluctuation is 50 ms or less in vicinity of LVI detection voltage



## CHAPTER 26 REGULATOR

## 26.1 Outline of Regulator

The 78K0/KF1 Series includes a circuit to realize low-voltage operation inside the device. To stabilize the regulator output voltage, connect the REGC pin to Vss via a 0.1  $\mu$ F capacitor.

- ★ The regulator of the 78K0/KF1 Series stops operating in the following cases.
  - During the reset period
  - In STOP mode
  - In HALT mode when the CPU is operating on the subsystem clock

Figure 26-1 shows the block diagram of the periphery of the regulator.



#### Figure 26-1. Block Diagram of Regulator Periphery

**Remark** To use the CPU at high speed ( $f_{XP} = 10 \text{ MHz}$ ,  $V_{DD} = 4.0$  to 5.5 V), connect the REGC pin directly to  $V_{DD}$  and use at the same potential as the  $V_{DD}$  pin.

## **CHAPTER 27 MASK OPTIONS**

Mask ROM versions are provided with the following mask options.

- 1. Power-on-clear (POC) circuit
  - POC cannot be used
  - POC used (detection voltage: VPOC = 2.85 V ±0.15 V)
  - POC used (detection voltage: VPOC = 3.5 V ±0.2 V)
- 2. Ring-OSC
  - Cannot be stopped
  - Can be stopped by software
- 3. Pull-up resistor of P60 to P63 pins
  - Pull-up resistor can be incorporated in 1-bit units (Pull-up resistors are not available for the flash memory versions.)

Flash memory versions that support the mask options of the mask ROM versions are as follows.

#### Table 27-1. Flash Memory Versions Supporting Mask Options of Mask ROM Versions

| Mask                                                             | Flash Memory Version       |              |  |
|------------------------------------------------------------------|----------------------------|--------------|--|
| POC Circuit                                                      | Ring-OSC                   |              |  |
| POC cannot be used                                               | Cannot be stopped          | μPD78F0148M1 |  |
|                                                                  | Can be stopped by software | μPD78F0148M2 |  |
| POC used (V <sub>POC</sub> = 2.85 V $\pm$ 0.15 V)                | Cannot be stopped          | μPD78F0148M3 |  |
|                                                                  | Can be stopped by software | μPD78F0148M4 |  |
| POC used (V <sub>POC</sub> = $3.5 \text{ V} \pm 0.2 \text{ V}$ ) | Cannot be stopped          | μPD78F0148M5 |  |
|                                                                  | Can be stopped by software | μPD78F0148M6 |  |

## CHAPTER 28 μPD78F0148

The  $\mu$ PD78F0148 is provided as the flash memory version of the 78K0/KF1 Series.

The  $\mu$ PD78F0148 replaces the internal mask ROM of the  $\mu$ PD780148 with flash memory to which a program can be written, erased, and overwritten while mounted on the board. Table 28-1 lists the differences between the  $\mu$ PD78F0148 and the mask ROM versions.

| Item                            | μPD78F0148                                                     | Mask ROM Versions                                                                    |  |
|---------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Internal ROM configuration      | Flash memory                                                   | Mask ROM                                                                             |  |
| Internal ROM capacity           | 60 KB <sup>Note</sup>                                          | μPD780143: 24 KB<br>μPD780144: 32 KB<br>μPD780146: 48 KB<br>μPD780148: 60 KB         |  |
| Internal expansion RAM capacity | 1024 bytes <sup>№te</sup>                                      | μPD780143: None<br>μPD780144: None<br>μPD780146: 1024 bytes<br>μPD780148: 1024 bytes |  |
| IC pin                          | None                                                           | Available                                                                            |  |
| VPP pin                         | Available                                                      | None                                                                                 |  |
| Electrical specifications       | Refer to CHAPTER 30 ELECTRICAL SPECIFICATIONS (TARGET VALUES). |                                                                                      |  |

## Table 28-1. Differences Between $\mu$ PD78F0148 and Mask ROM Versions

- **Note** The same capacity as the mask ROM versions can be specified by means of the internal memory size switching register (IMS) and the internal expansion RAM size switching register (IXS).
- Caution There are differences in noise immunity and noise radiation between the flash memory and mask ROM versions. When pre-producing an application set with the flash memory version and then mass-producing it with the mask ROM version, be sure to conduct sufficient evaluations for the commercial samples (not engineering samples) of the mask ROM versions.

#### 28.1 Internal Memory Size Switching Register

The  $\mu$ PD78F0148 allows users to select the internal memory capacity using the internal memory size switching register (IMS) so that the same memory map as that of the mask ROM versions with a different internal memory capacity can be achieved.

IMS is set by an 8-bit memory manipulation instruction.

RESET input sets IMS to CFH.

#### Caution Be sure to set the value of the relevant mask ROM version at initialization.

| Address: FFI | F0H After r                           | eset: CFH     | R/W      |              |                                 |              |                 |      |  |
|--------------|---------------------------------------|---------------|----------|--------------|---------------------------------|--------------|-----------------|------|--|
| Symbol       | 7                                     | 6             | 5        | 4            | 3                               | 2            | 1               | 0    |  |
| IMS          | RAM2                                  | RAM1          | RAM0     | 0            | ROM3                            | ROM2         | ROM1            | ROM0 |  |
|              |                                       |               |          |              |                                 |              |                 |      |  |
|              | RAM2 RAM1 RAM0                        |               |          |              | nternal high-sp                 | beed RAM cap | pacity selectio | n    |  |
|              | 1                                     | 1             | 0        | 1024 bytes   |                                 |              |                 |      |  |
|              | C                                     | ther than abo | ove      | Setting proh | hibited                         |              |                 |      |  |
|              | · · · · · · · · · · · · · · · · · · · |               |          |              |                                 |              |                 |      |  |
|              | ROM3                                  | ROM2          | ROM1     | ROM0         | Internal ROM capacity selection |              |                 |      |  |
|              | 0                                     | 1             | 1        | 0            | 24 KB                           |              |                 |      |  |
|              | 1                                     | 0             | 0        | 0            | 32 KB                           |              |                 |      |  |
|              | 1                                     | 1             | 0        | 0 48 KB      |                                 |              |                 |      |  |
|              | 1                                     | 1             | 1        | 1            | 60 KB                           |              |                 |      |  |
|              |                                       | Other th      | an above |              | Setting prohi                   | bited        |                 |      |  |

#### Figure 28-1. Format of Internal Memory Size Switching Register (IMS)

The IMS settings required to obtain the same memory map as mask ROM versions are shown in Table 28-2.

#### Table 28-2. Internal Memory Size Switching Register Settings

| Target Mask ROM Versions | IMS Setting |
|--------------------------|-------------|
| μPD780143                | C6H         |
| μPD780144                | C8H         |
| μPD780146                | ССН         |
| μPD780148                | CFH         |

Caution When using a mask ROM version, be sure to set the value indicated in Table 28-2 to IMS.

### 28.2 Internal Expansion RAM Size Switching Register

This register is used to set the internal expansion RAM capacity via software. This register is set by an 8-bit memory manipulation instruction. RESET input sets IXS to 0CH.

## Caution Be sure to set the value of the relevant mask ROM version at initialization.

#### Figure 28-2. Format of Internal Expansion RAM Size Switching Register (IXS)

Address: FFF4H After reset: 0CH R/W Symbol 3 2 0 7 6 5 4 1 IXS 0 0 0 IXRAM4 **IXRAM3** IXRAM2 IXRAM1 IXRAM0

| IXRAM4       | IXRAM3 | IXRAM2 | IXRAM1             | IXRAM0 | Internal expansion RAM capacity selection |
|--------------|--------|--------|--------------------|--------|-------------------------------------------|
| 0            | 1      | 1      | 0                  | 0      | 0 bytes                                   |
| 0            | 1      | 0      | 1                  | 0      | 1024 bytes                                |
| Other than a | lbove  |        | Setting prohibited |        |                                           |

The IXS settings required to obtain the same memory map as mask ROM versions are shown in Table 28-3.

#### Table 28-3. Internal Expansion RAM Size Switching Register Settings

| Target Mask ROM Versions | IXS Setting |  |  |
|--------------------------|-------------|--|--|
| μPD780143                | 0CH         |  |  |
| μPD780144                | 0CH         |  |  |
| μPD780146                | 0AH         |  |  |
| μPD780148                | 0AH         |  |  |

Caution When using a mask ROM version, be sure to set the value indicated in Table 28-3 to IXS.

### 28.3 Flash Memory Programming

On-board writing of flash memory (with device mounted on target system) is supported.

On-board writing is performed after connecting a dedicated flash programmer (Flashpro III (FL-PR3, PG-FP3)) to the host machine and target system.

Moreover, writing to flash memory can also be performed using a flash memory writing adapter connected to Flashpro III.

Remark FL-PR3 is a product of Naito Densei Machida Mfg. Co., Ltd.

#### 28.3.1 Selection of communication mode

Writing to flash memory is performed using Flashpro III and serial communication. Select the communication mode for writing from Table 28-4. For the selection of the communication mode, a format like the one shown in Figure 28-3 is used. The communication mode is selected according to the number of VPP pulses shown in Table 28-4.

| Communication Mode | Number of Channels | Pin Used <sup>Note</sup>                                   | Number of VPP Pulses |
|--------------------|--------------------|------------------------------------------------------------|----------------------|
| 3-wire serial I/O  | 1                  | SCK10/TxD0/P10<br>SI10/RxD0/P11<br>SO10/P12                | 0                    |
|                    |                    | SCK10/TxD0/P10<br>SI10/RxD0/P11<br>SO10/P12<br>HS/P15/TOH0 | 3                    |
| UART (UART0)       | 1                  | TxD0/SCK10/P10<br>RxD0/SI10/P11                            | 8                    |
|                    |                    | TxD0/SCK10/P10<br>RxD0/SI10/P11<br>HS/P15/TOH0             | 11                   |
| UART (UART6)       | 1                  | TxD6/P13<br>RxD6/P14                                       | 9                    |

## Table 28-4. Communication Mode List

**Note** After shifting to flash memory programming mode, all pins not used for flash memory programming are set to the same state as after reset. Therefore, since all ports become output high-impedance, pin processing, such as connecting to V<sub>DD</sub> or V<sub>SS</sub> via a resistor is required if the output high-impedance state is not acknowledged by external devices.

Caution Be sure to select the number of VPP pulses shown in Table 28-4 for the communication mode.

## Figure 28-3. Communication Mode Selection Format



## 28.3.2 Flash memory programming function

Flash memory writing is performed via command and data transmit/receive operations using the selected communication mode. The main functions are listed in Table 28-5.

| Table 28-5. | Main Functions of Flash Memory Programming |
|-------------|--------------------------------------------|
|-------------|--------------------------------------------|

| Function                      | Description                                                                                         |
|-------------------------------|-----------------------------------------------------------------------------------------------------|
| Reset                         | Used to detect write stop and transmission synchronization.                                         |
| Batch verify                  | Compares entire memory contents and input data.                                                     |
| Batch erase                   | Erases the entire memory contents.                                                                  |
| Batch blank check             | Checks the erase status of the entire memory.                                                       |
| High-speed write              | Performs writing to flash memory according to write start address and number of write data (bytes). |
| Continuous write              | Performs successive write operations using the data input with high-speed write operation.          |
| Status                        | Checks the current operation mode and operation end.                                                |
| Oscillation frequency setting | Inputs the resonator oscillation frequency information.                                             |
| Delete time setting           | Inputs the memory delete time.                                                                      |
| Baud rate setting             | Sets the communication rate when the UART method is used.                                           |
| Silicon signature read        | Outputs the device name, memory capacity, and device block information.                             |

## 28.3.3 Connecting Flashpro III

The connection between Flashpro III and the  $\mu$ PD78F0148 differs depending on the communication mode (3-wire serial I/O or UART). Figures 28-4 to 28-8 show the connection diagrams of each case.



Figure 28-4. Connection of Flashpro III in 3-Wire Serial I/O Mode







## Figure 28-6. Connection of Flashpro III in UART (UART0) Mode









## 28.3.4 Connection on adapter for flash memory writing

Examples of the recommended connection when using the adapter for flash memory writing are shown below.











Figure 28-11. Example of Wiring Adapter for Flash Memory Writing in UART (UART0) Mode

WRITER INTERFACE

• VDD (2.7 to 5.5V)







Figure 28-13. Example of Wiring Adapter for Flash Memory Writing in UART (UART6) Mode

## **CHAPTER 29 INSTRUCTION SET**

This chapter lists each instruction set of the 78K0/KF1 Series in table form. For details of each operation and operation code, refer to the separate document **78K/0 Series Instructions User's Manual (U12326E)**.

### 29.1 Conventions Used in Operation List

#### 29.1.1 Operand identifiers and specification methods

Operands are written in the "Operand" column of each instruction in accordance with the specification method of the instruction operand identifier (refer to the assembler specifications for details). When there are two or more methods, select one of them. Uppercase letters and the symbols #, !, \$ and [] are keywords and must be written as they are. Each symbol has the following meaning.

- #: Immediate data specification
- !: Absolute address specification
- \$: Relative address specification
- []: Indirect address specification

In the case of immediate data, describe an appropriate numeric value or a label. When using a label, be sure to write the #, !, \$, and [] symbols.

For operand register identifiers r and rp, either function names (X, A, C, etc.) or absolute names (names in parentheses in the table below, R0, R1, R2, etc.) can be used for specification.

| Identifier | Specification Method                                                                     |  |  |  |
|------------|------------------------------------------------------------------------------------------|--|--|--|
| r          | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7)                           |  |  |  |
| rp         | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                                                   |  |  |  |
| sfr        | Special function register symbol <sup>Note</sup>                                         |  |  |  |
| sfrp       | Special function register symbol (16-bit manipulatable register even addresses only)Note |  |  |  |
| saddr      | FE20H to FF1FH Immediate data or labels                                                  |  |  |  |
| saddrp     | FE20H to FF1FH Immediate data or labels (even address only)                              |  |  |  |
| addr16     | 0000H to FFFFH Immediate data or labels                                                  |  |  |  |
|            | (Only even addresses for 16-bit data transfer instructions)                              |  |  |  |
| addr11     | 0800H to 0FFFH Immediate data or labels                                                  |  |  |  |
| addr5      | 0040H to 007FH Immediate data or labels (even address only)                              |  |  |  |
| word       | 16-bit immediate data or label                                                           |  |  |  |
| byte       | 8-bit immediate data or label                                                            |  |  |  |
| bit        | 3-bit immediate data or label                                                            |  |  |  |
| RBn        | RB0 to RB3                                                                               |  |  |  |

#### Table 29-1. Operand Identifiers and Specification Methods

**Note** Addresses from FFD0H to FFDFH cannot be accessed with these operands.

Remark For special function register symbols, refer to Table 3-5 Special Function Register List.

#### 29.1.2 Description of operation column

- A: A register; 8-bit accumulator
- X: X register
- B: B register
- C: C register
- D: D register
- E: E register
- H: H register
- L: L register
- AX: AX register pair; 16-bit accumulator
- BC: BC register pair
- DE: DE register pair
- HL: HL register pair
- PC: Program counter
- SP: Stack pointer
- PSW: Program status word
- CY: Carry flag
- AC: Auxiliary carry flag
- Z: Zero flag
- RBS: Register bank select flag
- IE: Interrupt request enable flag
- NMIS: Non-maskable interrupt servicing flag
- (): Memory contents indicated by address or register contents in parentheses
- XH, XL: Higher 8 bits and lower 8 bits of 16-bit register
- A: Logical product (AND)
- √: Logical sum (OR)
- ∀: Exclusive logical sum (exclusive OR)
- ---: Inverted data
- addr16: 16-bit immediate data or label
- jdisp8: Signed 8-bit data (displacement value)

#### 29.1.3 Description of flag operation column

- (Blank): Not affected
- 0: Cleared to 0
- 1: Set to 1
- ×: Set/cleared according to the result
- R: Previously saved value is restored

## 29.2 Operation List

| Instruction<br>Group Mnemor | Magazza  | onic Operands  | Bytes | Clocks |            | Onesetien                       |   | Flag | g  |
|-----------------------------|----------|----------------|-------|--------|------------|---------------------------------|---|------|----|
|                             | Mnemonic |                |       | Note 1 | Note 2     | Operation                       | Z | AC   | CY |
| 8-bit data                  | MOV      | r, #byte       | 2     | 4      | _          | $r \leftarrow byte$             |   |      |    |
| transfer                    |          | saddr, #byte   | 3     | 6      | 7          | $(saddr) \leftarrow byte$       |   |      |    |
|                             |          | sfr, #byte     | 3     | -      | 7          | $sfr \leftarrow byte$           |   |      |    |
|                             |          | A, r           | 1     | 2      | _          | $A \leftarrow r$                |   |      |    |
|                             |          | r, A Note 3    | 1     | 2      | _          | $r \leftarrow A$                |   |      |    |
|                             |          | A, saddr       | 2     | 4      | 5          | $A \leftarrow (saddr)$          |   |      |    |
|                             |          | saddr, A       | 2     | 4      | 5          | $(saddr) \leftarrow A$          |   |      |    |
|                             |          | A, sfr         | 2     | -      | 5          | $A \leftarrow sfr$              |   |      |    |
|                             |          | sfr, A         | 2     | -      | 5          | sfr ← A                         |   |      |    |
|                             |          | A, !addr16     | 3     | 8      | 9 + n      | $A \leftarrow (addr16)$         |   |      |    |
|                             |          | !addr16, A     | 3     | 8      | 9 + m      | $(addr16) \leftarrow A$         |   |      |    |
|                             |          | PSW, #byte     | 3     | -      | 7          | $PSW \leftarrow byte$           | × | ×    | ×  |
|                             |          | A, PSW         | 2     | -      | 5          | $A \leftarrow PSW$              |   |      |    |
|                             |          | PSW, A         | 2     | -      | 5          | $PSW \leftarrow A$              | × | ×    | ×  |
|                             |          | A, [DE]        | 1     | 4      | 5 + n      | $A \leftarrow (DE)$             |   |      |    |
|                             |          | [DE], A        | 1     | 4      | 5 + m      | $(DE) \leftarrow A$             |   |      |    |
|                             |          | A, [HL]        | 1     | 4      | 5 + n      | $A \leftarrow (HL)$             |   |      |    |
|                             |          | [HL], A        | 1     | 4      | 5 + m      | $(HL) \leftarrow A$             |   |      |    |
|                             |          | A, [HL + byte] | 2     | 8      | 9 + n      | $A \gets (HL + byte)$           |   |      |    |
|                             |          | [HL + byte], A | 2     | 8      | 9 + m      | $(HL + byte) \leftarrow A$      |   |      |    |
|                             |          | A, [HL + B]    | 1     | 6      | 7 + n      | $A \gets (HL + B)$              |   |      |    |
|                             |          | [HL + B], A    | 1     | 6      | 7 + m      | $(HL + B) \leftarrow A$         |   |      |    |
|                             |          | A, [HL + C]    | 1     | 6      | 7 + n      | $A \gets (HL + C)$              |   |      |    |
|                             |          | [HL + C], A    | 1     | 6      | 7 + m      | $(HL + C) \leftarrow A$         |   |      |    |
|                             | хсн      | A, r           | 1     | 2      | -          | $A \leftrightarrow r$           |   |      |    |
|                             |          | A, saddr       | 2     | 4      | 6          | $A \leftrightarrow (saddr)$     |   |      |    |
|                             |          | A, sfr         | 2     | -      | 6          | $A \leftrightarrow (sfr)$       |   |      |    |
|                             |          | A, !addr16     | 3     | 8      | 10 + n + m | $A \leftrightarrow (addr16)$    |   |      |    |
|                             |          | A, [DE]        | 1     | 4      | 6 + n + m  | $A \leftrightarrow (DE)$        |   |      |    |
|                             |          | A, [HL]        | 1     | 4      | 6 + n + m  | $A \leftrightarrow (HL)$        |   |      |    |
|                             |          | A, [HL + byte] | 2     | 8      | 10 + n + m | $A \leftrightarrow (HL + byte)$ |   |      |    |
|                             |          | A, [HL + B]    | 2     | 8      | 10 + n + m | $A \leftrightarrow (HL + B)$    |   |      |    |
|                             |          | A, [HL + C]    | 2     | 8      | 10 + n + m | $A \leftrightarrow (HL + C)$    |   |      |    |

Notes 1. When the internal high-speed RAM area is accessed or for an instruction with no data access

2. When an area except the internal high-speed RAM area is accessed

- 3. Except "r = A"
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.
  - 4. m is the number of waits when the external memory expansion area is written.

| Instruction | Mnemonic    | Operands       | Bytes          |        | locks   | Operation                                    | Fla  | g  |
|-------------|-------------|----------------|----------------|--------|---------|----------------------------------------------|------|----|
| Group       | WITEITIONIC | Operatios      | Dytes          | Note 1 | Note 2  | Operation                                    | Z AC | CY |
| 16-bit data | MOVW        | rp, #word      | 3              | 6      | -       | $rp \leftarrow word$                         |      |    |
| transfer    |             | saddrp, #word  | 4              | 8      | 10      | $(saddrp) \leftarrow word$                   |      |    |
|             |             | sfrp, #word    | 4              | -      | 10      | $sfrp \leftarrow word$                       |      |    |
|             |             | AX, saddrp     | 2              | 6      | 8       | $AX \gets (saddrp)$                          |      |    |
|             |             | saddrp, AX     | 2              | 6      | 8       | $(saddrp) \leftarrow AX$                     |      |    |
|             |             | AX, sfrp       | 2              | -      | 8       | $AX \gets sfrp$                              |      |    |
|             |             | sfrp, AX       | 2              | -      | 8       | $sfrp \leftarrow AX$                         |      |    |
|             |             | AX, rp         | <sup>3</sup> 1 | 4      | _       | $AX \gets rp$                                |      |    |
|             |             | rp, AX         | <sup>3</sup> 1 | 4      | _       | $rp \leftarrow AX$                           |      |    |
|             |             | AX, !addr16    | 3              | 10     | 12 + 2n | $AX \leftarrow (addr16)$                     |      |    |
|             |             | !addr16, AX    | 3              | 10     | 12 + 2m | $(addr16) \leftarrow AX$                     |      |    |
|             | XCHW        | AX, rp         | <sup>3</sup> 1 | 4      | -       | $AX \leftrightarrow rp$                      |      |    |
| 8-bit       | ADD         | A, #byte       | 2              | 4      | -       | A, CY $\leftarrow$ A + byte                  | × ×  | ×  |
| operation   |             | saddr, #byte   | 3              | 6      | 8       | (saddr), CY $\leftarrow$ (saddr) + byte      | × ×  | ×  |
|             |             | A, r           | ₄ 2            | 4      | _       | A, CY $\leftarrow$ A + r                     | × ×  | ×  |
|             |             | r, A           | 2              | 4      | -       | $r, CY \leftarrow r + A$                     | × ×  | ×  |
|             |             | A, saddr       | 2              | 4      | 5       | A, CY $\leftarrow$ A + (saddr)               | × ×  | ×  |
|             |             | A, !addr16     | 3              | 8      | 9 + n   | A, CY $\leftarrow$ A + (addr16)              | × ×  | ×  |
|             |             | A, [HL]        | 1              | 4      | 5 + n   | A, CY $\leftarrow$ A + (HL)                  | × ×  | ×  |
|             |             | A, [HL + byte] | 2              | 8      | 9 + n   | A, CY $\leftarrow$ A + (HL + byte)           | × ×  | ×  |
|             |             | A, [HL + B]    | 2              | 8      | 9 + n   | $A, CY \gets A + (HL + B)$                   | × ×  | ×  |
|             |             | A, [HL + C]    | 2              | 8      | 9 + n   | $A,CY \gets A + (HL + C)$                    | × ×  | ×  |
|             | ADDC        | A, #byte       | 2              | 4      | -       | A, CY $\leftarrow$ A + byte + CY             | × ×  | ×  |
|             |             | saddr, #byte   | 3              | 6      | 8       | (saddr), CY $\leftarrow$ (saddr) + byte + CY | × ×  | ×  |
|             |             | A, r           | 4 2            | 4      | _       | $A, CY \gets A + r + CY$                     | × ×  | ×  |
|             |             | r, A           | 2              | 4      | _       | $r,CY \gets r + A + CY$                      | × ×  | ×  |
|             |             | A, saddr       | 2              | 4      | 5       | A, CY $\leftarrow$ A + (saddr) + CY          | × ×  | ×  |
|             |             | A, !addr16     | 3              | 8      | 9 + n   | A, CY $\leftarrow$ A + (addr16) + CY         | × ×  | ×  |
|             |             | A, [HL]        | 1              | 4      | 5 + n   | $A,CY \gets A + (HL) + CY$                   | × ×  | ×  |
|             |             | A, [HL + byte] | 2              | 8      | 9 + n   | A, CY $\leftarrow$ A + (HL + byte) + CY      | × ×  | ×  |
|             |             | A, [HL + B]    | 2              | 8      | 9 + n   | $A, CY \gets A + (HL + B) + CY$              | × ×  | ×  |
|             |             | A, [HL + C]    | 2              | 8      | 9 + n   | $A, CY \leftarrow A + (HL + C) + CY$         | × ×  | ×  |

- 2. When an area except the internal high-speed RAM area is accessed
- 3. Only when rp = BC, DE or HL
- 4. Except "r = A"
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.
  - 4. m is the number of waits when the external memory expansion area is written.

| Instruction |          |                | <b>.</b> | С      | locks  |                                              |   | Flag | g  |
|-------------|----------|----------------|----------|--------|--------|----------------------------------------------|---|------|----|
| Group       | Mnemonic | Operands       | Bytes    | Note 1 | Note 2 | Operation                                    | Z | AC   | CY |
| 8-bit       | SUB      | A, #byte       | 2        | 4      | _      | A, CY $\leftarrow$ A – byte                  | × | ×    | ×  |
| operation   |          | saddr, #byte   | 3        | 6      | 8      | (saddr), CY $\leftarrow$ (saddr) – byte      | × | ×    | ×  |
|             |          | A, r           | 2        | 4      | _      | A, $CY \leftarrow A - r$                     | × | ×    | ×  |
|             |          | r, A           | 2        | 4      | _      | $r, CY \leftarrow r - A$                     | × | ×    | ×  |
|             |          | A, saddr       | 2        | 4      | 5      | A, CY $\leftarrow$ A – (saddr)               | × | ×    | ×  |
|             |          | A, !addr16     | 3        | 8      | 9 + n  | A, CY $\leftarrow$ A – (addr16)              | × | ×    | ×  |
|             |          | A, [HL]        | 1        | 4      | 5 + n  | A, CY $\leftarrow$ A – (HL)                  | × | ×    | ×  |
|             |          | A, [HL + byte] | 2        | 8      | 9 + n  | A, CY $\leftarrow$ A – (HL + byte)           | × | ×    | ×  |
|             |          | A, [HL + B]    | 2        | 8      | 9 + n  | A, CY $\leftarrow$ A – (HL + B)              | × | ×    | ×  |
|             |          | A, [HL + C]    | 2        | 8      | 9 + n  | A, $CY \leftarrow A - (HL + C)$              | × | ×    | ×  |
|             | SUBC     | A, #byte       | 2        | 4      | -      | A, CY $\leftarrow$ A – byte – CY             | × | ×    | ×  |
|             |          | saddr, #byte   | 3        | 6      | 8      | (saddr), CY $\leftarrow$ (saddr) – byte – CY | × | ×    | ×  |
|             |          | A, r           | 2        | 4      | _      | A, $CY \leftarrow A - r - CY$                | × | Х    | ×  |
|             |          | r, A           | 2        | 4      | _      | $r,CY \gets r-A-CY$                          | × | Х    | ×  |
|             |          | A, saddr       | 2        | 4      | 5      | A, CY $\leftarrow$ A – (saddr) – CY          | × | ×    | ×  |
|             |          | A, !addr16     | 3        | 8      | 9 + n  | A, CY $\leftarrow$ A – (addr16) – CY         | × | ×    | ×  |
|             |          | A, [HL]        | 1        | 4      | 5 + n  | $A,CY \gets A - (HL) - CY$                   | × | ×    | ×  |
|             |          | A, [HL + byte] | 2        | 8      | 9 + n  | A, CY $\leftarrow$ A – (HL + byte) – CY      | × | ×    | ×  |
|             |          | A, [HL + B]    | 2        | 8      | 9 + n  | $A,CY \gets A - (HL + B) - CY$               | × | ×    | ×  |
|             |          | A, [HL + C]    | 2        | 8      | 9 + n  | $A,CY \gets A - (HL + C) - CY$               | × | ×    | ×  |
|             | AND      | A, #byte       | 2        | 4      | -      | $A \leftarrow A \land byte$                  | × |      |    |
|             |          | saddr, #byte   | 3        | 6      | 8      | $(saddr) \leftarrow (saddr) \land byte$      | × |      |    |
|             |          | A, r           | 2        | 4      | -      | $A \leftarrow A \wedge r$                    | × |      |    |
|             |          | r, A           | 2        | 4      | -      | $r \leftarrow r \wedge A$                    | × |      |    |
|             |          | A, saddr       | 2        | 4      | 5      | $A \leftarrow A \land (saddr)$               | × |      |    |
|             |          | A, !addr16     | 3        | 8      | 9 + n  | $A \leftarrow A \land (addr16)$              | × |      |    |
|             |          | A, [HL]        | 1        | 4      | 5 + n  | $A \leftarrow A \land (HL)$                  | × |      |    |
|             |          | A, [HL + byte] | 2        | 8      | 9 + n  | $A \leftarrow A \land (HL + byte)$           | × |      |    |
|             |          | A, [HL + B]    | 2        | 8      | 9 + n  | $A \leftarrow A \land (HL + B)$              | × |      |    |
|             |          | A, [HL + C]    | 2        | 8      | 9 + n  | $A \leftarrow A \land (HL + C)$              | × |      |    |

- 2. When an area except the internal high-speed RAM area is accessed
- 3. Except "r = A"
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.

| Instruction | Maamania | Onerende       | Dutas | С      | locks  | Oneration                              |   | Flag  |
|-------------|----------|----------------|-------|--------|--------|----------------------------------------|---|-------|
| Group       | Mnemonic | Operands       | Bytes | Note 1 | Note 2 | Operation                              | Ζ | AC CY |
| 8-bit       | OR       | A, #byte       | 2     | 4      | _      | $A \leftarrow A \lor byte$             | × |       |
| operation   |          | saddr, #byte   | 3     | 6      | 8      | $(saddr) \leftarrow (saddr) \lor byte$ | × |       |
|             |          | A, r           | 2     | 4      | -      | $A \leftarrow A \lor r$                | × |       |
|             |          | r, A           | 2     | 4      | -      | $r \leftarrow r \lor A$                | × |       |
|             |          | A, saddr       | 2     | 4      | 5      | $A \leftarrow A \lor (saddr)$          | × |       |
|             |          | A, !addr16     | 3     | 8      | 9 + n  | $A \leftarrow A \lor (addr16)$         | × |       |
|             |          | A, [HL]        | 1     | 4      | 5 + n  | $A \leftarrow A \lor (HL)$             | × |       |
|             |          | A, [HL + byte] | 2     | 8      | 9 + n  | $A \leftarrow A \lor (HL + byte)$      | × |       |
|             |          | A, [HL + B]    | 2     | 8      | 9 + n  | $A \leftarrow A \lor (HL + B)$         | × |       |
|             |          | A, [HL + C]    | 2     | 8      | 9 + n  | $A \leftarrow A \lor (HL + C)$         | × |       |
|             | XOR      | A, #byte       | 2     | 4      | -      | $A \leftarrow A \neq byte$             | × |       |
|             |          | saddr, #byte   | 3     | 6      | 8      | $(saddr) \leftarrow (saddr) \lor byte$ | × |       |
|             |          | A, r Note 3    | 2     | 4      | -      | $A \leftarrow A \forall r$             | × |       |
|             |          | r, A           | 2     | 4      | -      | $r \leftarrow r \forall A$             | × |       |
|             |          | A, saddr       | 2     | 4      | 5      | $A \leftarrow A \forall (saddr)$       | × |       |
|             |          | A, !addr16     | 3     | 8      | 9 + n  | $A \leftarrow A \forall$ (addr16)      | × |       |
|             |          | A, [HL]        | 1     | 4      | 5 + n  | $A \leftarrow A \nleftrightarrow (HL)$ | × |       |
|             |          | A, [HL + byte] | 2     | 8      | 9 + n  | $A \leftarrow A \lor (HL + byte)$      | × |       |
|             |          | A, [HL + B]    | 2     | 8      | 9 + n  | $A \leftarrow A \lor (HL + B)$         | × |       |
|             |          | A, [HL + C]    | 2     | 8      | 9 + n  | $A \leftarrow A \neq (HL + C)$         | × |       |
|             | СМР      | A, #byte       | 2     | 4      | -      | A – byte                               | × | × ×   |
|             |          | saddr, #byte   | 3     | 6      | 8      | (saddr) – byte                         | × | × ×   |
|             |          | A, r           | 2     | 4      | -      | A – r                                  | × | × ×   |
|             |          | r, A           | 2     | 4      | I      | r – A                                  | × | × ×   |
|             |          | A, saddr       | 2     | 4      | 5      | A – (saddr)                            | × | × ×   |
|             |          | A, !addr16     | 3     | 8      | 9 + n  | A – (addr16)                           | × | × ×   |
|             |          | A, [HL]        | 1     | 4      | 5 + n  | A – (HL)                               | × | × ×   |
|             |          | A, [HL + byte] | 2     | 8      | 9 + n  | A – (HL + byte)                        | × | × ×   |
|             |          | A, [HL + B]    | 2     | 8      | 9 + n  | A – (HL + B)                           | × | × ×   |
|             |          | A, [HL + C]    | 2     | 8      | 9 + n  | A – (HL + C)                           | × | × ×   |

2. When an area except the internal high-speed RAM area is accessed

- 3. Except "r = A"
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.

| Instruction |          | Original      | D. I. |        | locks      | Quanting                                                                                                           |   | Flag | g  |
|-------------|----------|---------------|-------|--------|------------|--------------------------------------------------------------------------------------------------------------------|---|------|----|
| Group       | Mnemonic | Operands      | Bytes | Note 1 | Note 2     | Operation                                                                                                          | Ζ | AC   | CY |
| 16-bit      | ADDW     | AX, #word     | 3     | 6      | -          | AX, CY $\leftarrow$ AX + word                                                                                      | × | ×    | ×  |
| operation   | SUBW     | AX, #word     | 3     | 6      | _          | AX, CY $\leftarrow$ AX – word                                                                                      | × | ×    | ×  |
|             | CMPW     | AX, #word     | 3     | 6      | -          | AX – word                                                                                                          | × | ×    | ×  |
| Multiply/   | MULU     | х             | 2     | 16     | -          | $AX \leftarrow A \times X$                                                                                         |   |      |    |
| divide      | DIVUW    | С             | 2     | 25     | -          | AX (Quotient), C (Remainder) $\leftarrow$ AX ÷ C                                                                   |   |      |    |
| Increment/  | INC      | r             | 1     | 2      | -          | r ← r + 1                                                                                                          | × | ×    |    |
| decrement   |          | saddr         | 2     | 4      | 6          | $(saddr) \leftarrow (saddr) + 1$                                                                                   | × | ×    |    |
|             | DEC      | r             | 1     | 2      | -          | r ← r – 1                                                                                                          | × | ×    |    |
|             |          | saddr         | 2     | 4      | 6          | $(saddr) \leftarrow (saddr) - 1$                                                                                   | × | ×    |    |
|             | INCW     | rp            | 1     | 4      | -          | $rp \leftarrow rp + 1$                                                                                             |   |      |    |
|             | DECW     | rp            | 1     | 4      | -          | $rp \leftarrow rp - 1$                                                                                             |   |      |    |
| Rotate      | ROR      | A, 1          | 1     | 2      | -          | (CY, A <sub>7</sub> $\leftarrow$ A <sub>0</sub> , A <sub>m-1</sub> $\leftarrow$ A <sub>m</sub> ) $\times$ 1 time   |   |      | ×  |
|             | ROL      | A, 1          | 1     | 2      | -          | (CY, A <sub>0</sub> $\leftarrow$ A <sub>7</sub> , A <sub>m + 1</sub> $\leftarrow$ A <sub>m</sub> ) $\times$ 1 time |   |      | ×  |
|             | RORC     | A, 1          | 1     | 2      | -          | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1 \text{ time}$                             |   |      | ×  |
|             | ROLC     | A, 1          | 1     | 2      | -          | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1 \text{ time}$                             |   |      | ×  |
|             | ROR4     | [HL]          | 2     | 10     | 12 + n + m | A3-0 ← (HL)3-0, (HL)7-4 ← A3-0,<br>(HL)3-0 ← (HL)7-4                                                               |   |      |    |
|             | ROL4     | [HL]          | 2     | 10     | 12 + n + m | $A_{3-0} \leftarrow (HL)_{7-4}, (HL)_{3-0} \leftarrow A_{3-0}, \\ (HL)_{7-4} \leftarrow (HL)_{3-0}$                |   |      |    |
| BCD         | ADJBA    |               | 2     | 4      | -          | Decimal Adjust Accumulator after Addition                                                                          | × | ×    | ×  |
| adjustment  | ADJBS    |               | 2     | 4      | -          | Decimal Adjust Accumulator after Subtract                                                                          | × | ×    | ×  |
| Bit         | MOV1     | CY, saddr.bit | 3     | 6      | 7          | $CY \leftarrow (saddr.bit)$                                                                                        |   |      | ×  |
| manipulate  |          | CY, sfr.bit   | 3     | -      | 7          | $CY \gets sfr.bit$                                                                                                 |   |      | ×  |
|             |          | CY, A.bit     | 2     | 4      | -          | $CY \leftarrow A.bit$                                                                                              |   |      | ×  |
|             |          | CY, PSW.bit   | 3     | -      | 7          | $CY \gets PSW.bit$                                                                                                 |   |      | ×  |
|             |          | CY, [HL].bit  | 2     | 6      | 7 + n      | $CY \gets (HL).bit$                                                                                                |   |      | ×  |
|             |          | saddr.bit, CY | 3     | 6      | 8          | $(saddr.bit) \gets CY$                                                                                             |   |      |    |
|             |          | sfr.bit, CY   | 3     | -      | 8          | $sfr.bit \leftarrow CY$                                                                                            |   |      |    |
|             |          | A.bit, CY     | 2     | 4      | -          | $A.bit \gets CY$                                                                                                   |   |      |    |
|             |          | PSW.bit, CY   | 3     | -      | 8          | $PSW.bit \gets CY$                                                                                                 | × | ×    |    |
|             |          | [HL].bit, CY  | 2     | 6      | 8 + n + m  | $(HL).bit \gets CY$                                                                                                |   | _    |    |

2. When an area except the internal high-speed RAM area is accessed

- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.
  - 4. m is the number of waits when the external memory expansion area is written.

| Instruction | Masaasia | Onevende      | Dutas | C      | locks     | Onevetien                            | Flag                       |
|-------------|----------|---------------|-------|--------|-----------|--------------------------------------|----------------------------|
| Group       | Mnemonic | Operands      | Bytes | Note 1 | Note 2    | Operation                            | Z AC CY                    |
| Bit         | AND1     | CY, saddr.bit | 3     | 6      | 7         | $CY \leftarrow CY \land (saddr.bit)$ | ×                          |
| manipulate  |          | CY, sfr.bit   | 3     | -      | 7         | $CY \leftarrow CY \land sfr.bit$     | ×                          |
|             |          | CY, A.bit     | 2     | 4      | -         | $CY \leftarrow CY \land A.bit$       | ×                          |
|             |          | CY, PSW.bit   | 3     | -      | 7         | $CY \leftarrow CY \land PSW.bit$     | ×                          |
|             |          | CY, [HL].bit  | 2     | 6      | 7 + n     | $CY \gets CY \land (HL).bit$         | ×                          |
|             | OR1      | CY, saddr.bit | 3     | 6      | 7         | $CY \gets CY \lor (saddr.bit)$       | ×                          |
|             |          | CY, sfr.bit   | 3     | -      | 7         | $CY \gets CY \lor sfr.bit$           | ×                          |
|             |          | CY, A.bit     | 2     | 4      | -         | $CY \leftarrow CY \lor A.bit$        | ×                          |
|             |          | CY, PSW.bit   | 3     | -      | 7         | $CY \leftarrow CY \lor PSW.bit$      | ×                          |
|             |          | CY, [HL].bit  | 2     | 6      | 7 + n     | $CY \gets CY \lor (HL).bit$          | ×                          |
|             | XOR1     | CY, saddr.bit | 3     | 6      | 7         | $CY \gets CY \lor (saddr.bit)$       | ×                          |
|             |          | CY, sfr.bit   | 3     | -      | 7         | $CY \gets CY \lor sfr.bit$           | ×                          |
|             |          | CY, A.bit     | 2     | 4      | -         | $CY \gets CY \lor A.bit$             | ×                          |
|             |          | CY, PSW.bit   | 3     | -      | 7         | $CY \leftarrow CY \neq PSW.bit$      | ×                          |
|             |          | CY, [HL].bit  | 2     | 6      | 7 + n     | $CY \gets CY \not\prec (HL).bit$     | ×                          |
|             | SET1     | saddr.bit     | 2     | 4      | 6         | $(saddr.bit) \leftarrow 1$           |                            |
|             |          | sfr.bit       | 3     | -      | 8         | sfr.bit $\leftarrow$ 1               |                            |
|             |          | A.bit         | 2     | 4      | -         | A.bit ← 1                            |                            |
|             |          | PSW.bit       | 2     | -      | 6         | $PSW.bit \gets 1$                    | $\times$ $\times$ $\times$ |
|             |          | [HL].bit      | 2     | 6      | 8 + n + m | (HL).bit $\leftarrow$ 1              |                            |
|             | CLR1     | saddr.bit     | 2     | 4      | 6         | $(saddr.bit) \leftarrow 0$           |                            |
|             |          | sfr.bit       | 3     | -      | 8         | sfr.bit $\leftarrow$ 0               |                            |
|             |          | A.bit         | 2     | 4      | -         | A.bit $\leftarrow 0$                 |                            |
|             |          | PSW.bit       | 2     | -      | 6         | $PSW.bit \gets 0$                    | $\times$ $\times$ $\times$ |
|             |          | [HL].bit      | 2     | 6      | 8 + n + m | (HL).bit $\leftarrow 0$              |                            |
|             | SET1     | CY            | 1     | 2      | -         | CY ← 1                               | 1                          |
|             | CLR1     | CY            | 1     | 2      | -         | $CY \leftarrow 0$                    | 0                          |
|             | NOT1     | CY            | 1     | 2      | -         | $CY \leftarrow \overline{CY}$        | ×                          |

2. When an area except the internal high-speed RAM area is accessed

- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.
  - 4. m is the number of waits when the external memory expansion area is written.

| Instruction   | Mnemonic | Operands  | Dutoo |        | locks  | Operation                                                                                                                                                                                                           | I | Flag |   |
|---------------|----------|-----------|-------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|---|
| Group         | whemonic | Operands  | Bytes | Note 1 | Note 2 | Operation                                                                                                                                                                                                           | Ζ | AC C | Y |
| Call/return   | CALL     | !addr16   | 3     | 7      | -      | $(SP - 1) \leftarrow (PC + 3)_{H}, (SP - 2) \leftarrow (PC + 3)_{L},$<br>PC $\leftarrow$ addr16, SP $\leftarrow$ SP - 2                                                                                             |   |      |   |
|               | CALLF    | !addr11   | 2     | 5      | _      | $\begin{split} (SP-1) \leftarrow (PC+2)_{H}, (SP-2) \leftarrow (PC+2)_{L}, \\ PC_{15-11} \leftarrow 00001, PC_{10-0} \leftarrow addr11, \\ SP \leftarrow SP-2 \end{split}$                                          |   |      |   |
|               | CALLT    | [addr5]   | 1     | 6      | _      | $\begin{split} (SP-1) &\leftarrow (PC+1)_{H},  (SP-2) \leftarrow (PC+1)_{L}, \\ PC_{H} &\leftarrow (00000000,  addr5+1), \\ PC_{L} &\leftarrow (00000000,  addr5), \\ SP &\leftarrow SP-2 \end{split}$              |   |      |   |
|               | BRK      |           | 1     | 6      | _      | $\begin{split} (SP-1) &\leftarrow PSW,  (SP-2) \leftarrow (PC+1)_{H}, \\ (SP-3) \leftarrow (PC+1)_{L},  PC_{H} \leftarrow (003FH), \\ PC_{L} \leftarrow (003EH),  SP \leftarrow SP-3,  IE \leftarrow 0 \end{split}$ |   |      |   |
|               | RET      |           | 1     | 6      | -      | $PC_{H} \leftarrow (SP + 1), PC_{L} \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                     |   |      |   |
|               | RETI     |           | 1     | 6      | _      | $\begin{array}{l} PCH \leftarrow (SP+1),  PCL \leftarrow (SP), \\ PSW \leftarrow (SP+2),  SP \leftarrow SP+3, \\ NMIS \leftarrow 0 \end{array}$                                                                     | R | RF   | ٦ |
|               | RETB     |           | 1     | 6      | -      | $\begin{array}{l} PC_{H} \leftarrow (SP+1),  PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2),  SP \leftarrow SP+3 \end{array}$                                                                                     | R | RF   | F |
| Stack         | PUSH     | PSW       | 1     | 2      | _      | $(SP - 1) \leftarrow PSW, SP \leftarrow SP - 1$                                                                                                                                                                     |   |      | _ |
| manipulate    |          | rp        | 1     | 4      | -      | $(SP - 1) \leftarrow rp_H, (SP - 2) \leftarrow rp_L,$<br>$SP \leftarrow SP - 2$                                                                                                                                     |   |      |   |
|               | POP      | PSW       | 1     | 2      | _      | $PSW \leftarrow (SP),  SP \leftarrow SP + 1$                                                                                                                                                                        | R | RF   | ٦ |
|               |          | rp        | 1     | 4      | _      | $rp_{H} \leftarrow (SP + 1), rp_{L} \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                     |   |      |   |
|               | MOVW     | SP, #word | 4     | -      | 10     | $SP \leftarrow word$                                                                                                                                                                                                |   |      | _ |
|               |          | SP, AX    | 2     | -      | 8      | $SP \leftarrow AX$                                                                                                                                                                                                  |   |      | _ |
|               |          | AX, SP    | 2     | -      | 8      | $AX \leftarrow SP$                                                                                                                                                                                                  |   |      |   |
| Unconditional | BR       | !addr16   | 3     | 6      | -      | $PC \leftarrow addr16$                                                                                                                                                                                              |   |      |   |
| branch        |          | \$addr16  | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$                                                                                                                                                                                     |   |      |   |
|               |          | AX        | 2     | 8      | -      | $PC_{H} \leftarrow A,  PC_{L} \leftarrow X$                                                                                                                                                                         |   |      |   |
| Conditional   | вс       | \$addr16  | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 1$                                                                                                                                                                         |   |      |   |
| branch        | BNC      | \$addr16  | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 0$                                                                                                                                                                         |   |      |   |
|               | BZ       | \$addr16  | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 1$                                                                                                                                                                          |   |      |   |
|               | BNZ      | \$addr16  | 2     | 6      | ļ      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 0$                                                                                                                                                                          |   |      |   |

2. When an area except the internal high-speed RAM area is accessed

**Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).

2. This clock cycle applies to the internal ROM program.

| Instruction |          | Quantum da          | Dutin | C      | locks      | Quanting                                                                     | Flag    |
|-------------|----------|---------------------|-------|--------|------------|------------------------------------------------------------------------------|---------|
| Group       | Mnemonic | Operands            | Bytes | Note 1 | Note 2     | Operation                                                                    | Z AC CY |
| Conditional | вт       | saddr.bit, \$addr16 | 3     | 8      | 9          | $PC \leftarrow PC + 3 + jdisp8 \text{ if } (saddr.bit) = 1$                  |         |
| branch      |          | sfr.bit, \$addr16   | 4     | -      | 11         | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1                               |         |
|             |          | A.bit, \$addr16     | 3     | 8      | _          | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1                                 |         |
|             |          | PSW.bit, \$addr16   | 3     | -      | 9          | $PC \leftarrow PC + 3 + jdisp8$ if PSW.bit = 1                               |         |
|             |          | [HL].bit, \$addr16  | 3     | 10     | 11 + n     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1                              |         |
|             | BF       | saddr.bit, \$addr16 | 4     | 10     | 11         | $PC \leftarrow PC + 4 + jdisp8$ if (saddr.bit) = 0                           |         |
|             |          | sfr.bit, \$addr16   | 4     | -      | 11         | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 0                               |         |
|             |          | A.bit, \$addr16     | 3     | 8      | -          | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 0                                 |         |
|             |          | PSW.bit, \$addr16   | 4     | -      | 11         | $PC \leftarrow PC + 4 + jdisp8$ if PSW. bit = 0                              |         |
|             |          | [HL].bit, \$addr16  | 3     | 10     | 11 + n     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 0                              |         |
|             | BTCLR    | saddr.bit, \$addr16 | 4     | 10     | 12         | $PC \leftarrow PC + 4 + jdisp8$ if (saddr.bit) = 1<br>then reset (saddr.bit) |         |
|             |          | sfr.bit, \$addr16   | 4     | -      | 12         | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1<br>then reset sfr.bit         |         |
|             |          | A.bit, \$addr16     | 3     | 8      | _          | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1<br>then reset A.bit             |         |
|             |          | PSW.bit, \$addr16   | 4     | -      | 12         | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1 then reset PSW.bit            | × × ×   |
|             |          | [HL].bit, \$addr16  | 3     | 10     | 12 + n + m | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1<br>then reset (HL).bit       |         |
|             | DBNZ     | B, \$addr16         | 2     | 6      | -          | B ← B – 1, then<br>PC ← PC + 2 + jdisp8 if B $\neq$ 0                        |         |
|             |          | C, \$addr16         | 2     | 6      | -          | C ← C −1, then<br>PC ← PC + 2 + jdisp8 if C $\neq$ 0                         |         |
|             |          | saddr, \$addr16     | 3     | 8      | 10         | (saddr) ← (saddr) – 1, then<br>PC ← PC + 3 + jdisp8 if (saddr) $\neq$ 0      |         |
| CPU         | SEL      | RBn                 | 2     | 4      | -          | RBS1, 0 ← n                                                                  |         |
| control     | NOP      |                     | 1     | 2      | -          | No Operation                                                                 |         |
|             | EI       |                     | 2     | _      | 6          | $IE \leftarrow 1$ (Enable Interrupt)                                         |         |
|             | DI       |                     | 2     | -      | 6          | $IE \leftarrow 0$ (Disable Interrupt)                                        |         |
|             | HALT     |                     | 2     | 6      | _          | Set HALT Mode                                                                |         |
|             | STOP     |                     | 2     | 6      | _          | Set STOP Mode                                                                |         |

- 2. When an area except the internal high-speed RAM area is accessed
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the processor clock control register (PCC).
  - 2. This clock cycle applies to the internal ROM program.
  - 3. n is the number of waits when the external memory expansion area is read.
  - 4. m is the number of waits when the external memory expansion area is written.

# 29.3 Instructions Listed by Addressing Type

# (1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

|                                     |                                                              | 1                                                            |                                                              |            |                                                              | 1                                                            |     | 1          |                                                      | 1                                                            |      |                            |              |
|-------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|------------|--------------------------------------------------------------|--------------------------------------------------------------|-----|------------|------------------------------------------------------|--------------------------------------------------------------|------|----------------------------|--------------|
| Second Operand                      | #byte                                                        | A                                                            | r <sup>Note</sup>                                            | sfr        | saddr                                                        | !addr16                                                      | PSW | [DE]       | [HL]                                                 | [HL + B]                                                     |      | 1                          | None         |
| First Operand                       |                                                              |                                                              |                                                              |            |                                                              |                                                              |     |            |                                                      | [HL + C]                                                     |      |                            |              |
| A                                   | ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP        |                                                              | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR | MOV | MOV<br>XCH | MOV<br>XCH<br>ADD<br>SUB<br>SUBC<br>AND<br>OR<br>XOR | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR |      | ROR<br>ROL<br>RORC<br>ROLC |              |
|                                     |                                                              |                                                              | CMP                                                          |            | CMP                                                          | CMP                                                          |     |            | CMP                                                  | CMP                                                          |      |                            |              |
| r                                   | MOV                                                          | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            | INC<br>DEC   |
| B, C                                |                                                              |                                                              |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              | DBNZ |                            |              |
| sfr                                 | MOV                                                          | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            |              |
| saddr                               | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              | DBNZ |                            | INC<br>DEC   |
| !addr16                             |                                                              | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            |              |
| PSW                                 | MOV                                                          | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            | PUSH<br>POP  |
| [DE]                                |                                                              | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            |              |
| [HL]                                |                                                              | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            | ROR4<br>ROL4 |
| [HL + byte]<br>[HL + B]<br>[HL + C] |                                                              | MOV                                                          |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            |              |
| х                                   |                                                              |                                                              |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            | MULU         |
| С                                   |                                                              |                                                              |                                                              |            |                                                              |                                                              |     |            |                                                      |                                                              |      |                            | DIVUW        |

**Note** Except r = A

# (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| Second Operand<br>First Operand | #word                | AX                   | rp <sup>Note</sup> | sfrp | saddrp | !addr16 | SP   | None                        |
|---------------------------------|----------------------|----------------------|--------------------|------|--------|---------|------|-----------------------------|
| AX                              | ADDW<br>SUBW<br>CMPW |                      | MOVW<br>XCHW       | MOVW | MOVW   | MOVW    | MOVW |                             |
| rp                              | MOVW                 | MOVW <sup>Note</sup> |                    |      |        |         |      | INCW<br>DECW<br>PUSH<br>POP |
| sfrp                            | MOVW                 | MOVW                 |                    |      |        |         |      |                             |
| saddrp                          | MOVW                 | MOVW                 |                    |      |        |         |      |                             |
| !addr16                         |                      | MOVW                 |                    |      |        |         |      |                             |
| SP                              | MOVW                 | MOVW                 |                    |      |        |         |      |                             |

**Note** Only when rp = BC, DE, HL

# (3) Bit manipulation instructions

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| Second Operand<br>First Operand | A.bit                       | sfr.bit                     | saddr.bit                   | PSW.bit                     | [HL].bit                    | CY   | \$addr16          | None                 |
|---------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| A.bit                           |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit                         |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit                       |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit                         |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| [HL].bit                        |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| CY                              | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

### (4) Call instructions/branch instructions

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

| Second Operand<br>First Operand | AX | !addr16    | !addr11 | [addr5] | \$addr16                     |
|---------------------------------|----|------------|---------|---------|------------------------------|
| Basic instruction               | BR | CALL<br>BR | CALLF   | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| Compound instruction            |    |            |         |         | BT<br>BF<br>BTCLR<br>DBNZ    |

# (5) Other instructions

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

# CHAPTER 30 ELECTRICAL SPECIFICATIONS (TARGET VALUES)

These specifications are only target values, and may not be satisfied by mass-produced products.

| Parameter            | Symbol |                                     | Conditions                                                                                                                 | Ratings                                                                                     | Unit |
|----------------------|--------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------|
| Supply voltage       | VDD    |                                     |                                                                                                                            | -0.3 to +6.5                                                                                | V    |
|                      | EVDD   |                                     |                                                                                                                            | -0.3 to +6.5                                                                                | V    |
|                      | REGC   |                                     |                                                                                                                            | -0.3 to +6.5                                                                                | V    |
|                      | Vss    |                                     |                                                                                                                            | -0.3 to +0.3                                                                                | V    |
|                      | EVss   |                                     |                                                                                                                            | -0.3 to +0.3                                                                                | V    |
|                      | AVREF  |                                     |                                                                                                                            | -0.3 to VDD + 0.3 <sup>Note 1</sup>                                                         | V    |
|                      | AVss   |                                     |                                                                                                                            | -0.3 to +0.3                                                                                | V    |
|                      | VPP    | μPD78F0 <sup>-</sup>                | 148 only Note 2                                                                                                            | –0.3 to +10.5                                                                               | v    |
| Input voltage        | VI1    | to P33, P4<br>P61, P64              | 6, P10 to P17, P20 to P27, P30<br>40 to P47, P50 to P57, P60,<br>to P67, P70 to P77, P120,<br>145, X1, X2, XT1, XT2, RESET | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 1</sup>                                             | V    |
|                      | VI2    | P62, P63                            | N-ch open drain                                                                                                            | –0.3 to +13                                                                                 | V    |
|                      |        |                                     | On-chip pull-up resistor                                                                                                   | $-0.3$ to V <sub>DD</sub> + $0.3^{Note 1}$                                                  | V    |
|                      | Vı3    | V <sub>PP</sub> in flas<br>(µPD78F0 | h programming mode<br>1148 only)                                                                                           | -0.3 to +10.5                                                                               | V    |
| Output voltage       | Vo     |                                     |                                                                                                                            | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 1</sup>                                             | V    |
| Analog input voltage | Van    |                                     |                                                                                                                            | AVss $-$ 0.3 to AVREF + 0.3 <sup>Note 1</sup><br>and $-$ 0.3 to VDD + 0.3 <sup>Note 1</sup> | V    |
| Output current, high | Іон    | Per pin                             |                                                                                                                            | -10                                                                                         | mA   |
|                      |        | all pins                            | P00 to P06, P40 to P47, P50 to<br>P57, P64 to P67, P70 to P77,<br>P142 to P145                                             | -30                                                                                         | mA   |
|                      |        |                                     | P10 to P17, P30 to P33, P120,<br>P130, P140, P141                                                                          | -30                                                                                         | mA   |

#### ★ Absolute Maximum Ratings (T<sub>A</sub> = 25°C) (1/2)

**Note 1.** Must be 6.5 V or lower. (Refer to **Note 2** on the next page.)

Caution Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded.

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

#### Absolute Maximum Ratings (T<sub>A</sub> = 25°C) (2/2)

| Parameter                     | Symbol |                               | Conditions                                                                                                            | Ratings     | Unit |
|-------------------------------|--------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------|------|
| Output current, low           | lol    | Per pin                       | P00 to P06, P10 to P17, P30 to<br>P33, P40 to P47, P50 to P57,<br>P64 to P67, P70 to P77, P120,<br>P130, P140 to P145 | 20          | mA   |
|                               |        |                               | P60 to P63                                                                                                            | 30          | mA   |
|                               |        | Total of<br>all pins<br>70 mA | P00 to P06, P40 to P47, P50 to<br>P57, P60, P61, P64 to P67,<br>P70 to P77, P142 to P145                              | 35          | mA   |
|                               |        |                               | P10 to P17, P30 to P33, P62,<br>P63, P120, P130, P140, P141                                                           | 35          | mA   |
| Operating ambient temperature | Та     | In norma                      | l operation mode                                                                                                      | -40 to +85  | °C   |
| Storage temperature           | Tstg   | μPD780 <sup>-</sup>           | 143, 780144, 780146, 780148                                                                                           | –65 to +150 | °C   |
|                               |        | µPD78F0                       | 0148                                                                                                                  | -40 to +125 |      |

**Note** 2. Make sure that the following conditions of the VPP voltage application timing are satisfied when the flash memory is written.

#### When supply voltage rises

VPP must exceed VDD 10  $\mu$ s or more after VDD has reached the lower-limit value (2.7 V) of the operating voltage range (15  $\mu$ s if the supply voltage is dropped by the regulator) (see a in the figure below).

### When supply voltage drops

V<sub>DD</sub> must be lowered 10  $\mu$ s or more after V<sub>PP</sub> falls below the lower-limit value (2.7 V) of the operating voltage range of V<sub>DD</sub> (see b in the figure below).



Caution Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded.

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

| Resonator               | Recommended Circuit            | Parameter                                        | Cond                                                 | ditions                                                                                                | MIN.       | TYP. | MAX.        | Unit |
|-------------------------|--------------------------------|--------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------|------|-------------|------|
| Ceramic resonator       | IC<br>(VPP) X1 X2              | Oscillation<br>frequency (fxp) <sup>Note 1</sup> | When a capacitor is connected to                     | $3.3 \text{ V} \le \text{V}_{DD} < 5.5 \text{ V}$<br>$2.7 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V}$ | 2.0<br>2.0 |      | 8.38<br>5.0 | MHz  |
|                         | │                              |                                                  | the REGC pin <sup>Note 2</sup>                       |                                                                                                        | 2.0        |      | 0.0         |      |
|                         |                                |                                                  | When the REGC                                        | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$                                                                  | 2.0        |      | 10          | MHz  |
|                         | [                              |                                                  | pin is directly<br>connected to VDD                  | $3.3~V \leq V_{\text{DD}} < 4.0~V$                                                                     | 2.0        |      | 8.38        |      |
|                         | 777                            |                                                  | connected to vbb                                     | $2.7~V \leq V_{\text{DD}} < 3.3~V$                                                                     | 2.0        |      | 5.0         |      |
| Crystal                 | IC<br>(V <sub>PP</sub> ) X1 X2 | Oscillation                                      | When a capacitor                                     | $3.3~V \leq V_{\text{DD}} < 5.5~V$                                                                     | 2.0        |      | 8.38        | MHz  |
| resonator               |                                | frequency (fxp) <sup>Note 1</sup>                | is connected to<br>the REGC pin <sup>Note 2</sup>    | $2.7~V \leq V_{\text{DD}} < 3.3~V$                                                                     | 2.0        |      | 5.0         |      |
|                         | C1= C2=                        |                                                  | When the REGC<br>pin is directly<br>connected to VDD | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$                                                                  | 2.0        |      | 10          | MHz  |
|                         |                                |                                                  |                                                      | $3.3~V \leq V_{\text{DD}} < 4.0~V$                                                                     | 2.0        |      | 8.38        |      |
|                         | 777                            |                                                  |                                                      | $2.7~V \leq V_{\text{DD}} < 3.3~V$                                                                     | 2.0        |      | 5.0         |      |
| External                |                                | X1 input                                         | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$                | ,                                                                                                      | 2.0        |      | 10          | MHz  |
| clock <sup>Note 3</sup> | X1 X2                          | frequency (fxp) <sup>Note 1</sup>                | $3.3~V \leq V_{\text{DD}} < 4.0~V$                   | 1                                                                                                      | 2.0        |      | 8.38        |      |
|                         |                                |                                                  | $2.7~V \leq V_{\text{DD}} < 3.3~V$                   | 1                                                                                                      | 2.0        |      | 5.0         |      |
|                         |                                | X1 input high-                                   | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$                | ,                                                                                                      | 46         |      | 500         | ns   |
|                         |                                | /low-level width                                 | $3.3~V \leq V_{\text{DD}} < 4.0~V$                   | /                                                                                                      | 56         |      | 500         |      |
|                         |                                | (txpн, txpl)                                     | $2.7~V \leq V_{\text{DD}} < 3.3~V$                   | /                                                                                                      | 96         |      | 500         |      |

#### **X1 Oscillator Characteristics**

#### $(T_{A} = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{DD} \le \text{EV}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{REF} \le \text{V}_{DD}, \text{V}_{SS} = \text{EV}_{SS} = \text{AV}_{SS} = 0 \text{ V})$

\*

Notes 1. Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.

- 2. When the REGC pin is connected to Vss via a 0.1  $\mu$ F capacitor.
- 3. Connect the REGC pin directly to VDD.
- Cautions 1. When using the X1 oscillator, wire as follows in the area enclosed by the broken lines in the above figures to avoid an adverse effect from wiring capacitance.
  - Keep the wiring length as short as possible.
  - Do not cross the wiring with the other signal lines.
  - Do not route the wiring near a signal line through which a high fluctuating current flows.
  - Always make the ground point of the oscillator capacitor the same potential as Vss.
  - Do not ground the capacitor to a ground pattern through which a high current flows.
  - Do not fetch signals from the oscillator.
  - 2. Since the CPU is started by the Ring-OSC after reset is released, check the oscillation stabilization time of the X1 input clock using the oscillation stabilization time status register (OSTC). Determine the oscillation stabilization time of the OSTC register and oscillation stabilization time select register (OSTS) after sufficiently evaluating the oscillation stabilization time with the resonator to be used.
- **Remark** For the resonator selection and oscillator constant, users are required to either evaluate the oscillation themselves or apply to the resonator manufacturer for evaluation.

#### **Ring-OSC Oscillator Characteristics**

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{DD} \le \text{EV}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{REF} \le \text{V}_{DD}, \text{V}_{SS} = \text{EV}_{SS} = \text{AV}_{SS} = 0 \text{ V})$

| Resonator                   | Parameter                  | Conditions | MIN. | TYP. | MAX. | Unit |
|-----------------------------|----------------------------|------------|------|------|------|------|
| On-chip Ring-OSC oscillator | Oscillation frequency (fR) |            | 120  | 240  | 480  | kHz  |

# Subsystem Clock Oscillator Characteristics

#### $(T_{A} = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}\text{dD} \le \text{EV}\text{dD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}\text{Ref} \le \text{V}\text{dD}, \text{Vss} = \text{EV}\text{ss} = \text{AV}\text{ss} = 0 \text{ V})$

| Resonator            | Recommended Circuit                  | Parameter                                       | Conditions | MIN. | TYP.   | MAX. | Unit |
|----------------------|--------------------------------------|-------------------------------------------------|------------|------|--------|------|------|
| Crystal<br>resonator | IC<br>(VPP) XT2 XT1<br>Rd<br>C4 C3 7 | Oscillation frequency<br>(fxT) <sup>Note</sup>  |            | 32   | 32.768 | 35   | kHz  |
| External clock       | XT2 XT1                              | XT1 input frequency<br>(fxT) <sup>Note</sup>    |            | 32   |        | 38.5 | kHz  |
| *                    |                                      | XT1 input high-/low-level<br>width (txтн, txт∟) |            | 12   |        | 15   | μs   |

Note Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.

# Cautions 1. When using the subsystem clock oscillator, wire as follows in the area enclosed by the broken lines in the above figures to avoid an adverse effect from wiring capacitance.

- Keep the wiring length as short as possible.
- Do not cross the wiring with the other signal lines.
- Do not route the wiring near a signal line through which a high fluctuating current flows.
- Always make the ground point of the oscillator capacitor the same potential as Vss.
- Do not ground the capacitor to a ground pattern through which a high current flows.
- Do not fetch signals from the oscillator.
- 2. The subsystem clock oscillator is designed as a low-amplitude circuit for reducing current consumption, and is more prone to malfunction due to noise than the main system clock oscillator. Particular care is therefore required with the wiring method when the subsystem clock is used.
- **Remark** For the resonator selection and oscillator constant, customers are requested to either evaluate the oscillation themselves or apply to the resonator manufacturer for evaluation.

# DC Characteristics (1/4) (TA = -40 to +85°C, 2.7 V $\leq$ VDD $\leq$ EVDD $\leq$ 5.5 V, 2.7 V $\leq$ AVREF $\leq$ VDD, Vss = EVss = AVss = 0 V)

\*

★

\*

| Parameter            | Symbol           | Condition                                                                                                                            | s                                     | MIN.                  | TYP. | MAX.                 | Unit |
|----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------|------|----------------------|------|
| Output current, high | Іон              | Per pin                                                                                                                              | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |                       |      | -5                   | mA   |
|                      |                  | Total of P10 to P17, P30 to<br>P33, P120, P130, P140,<br>P141                                                                        | $4.0~V \leq V_{DD} \leq 5.5~V$        |                       |      | -25                  | mA   |
|                      |                  | Total of P00 to P06, P40 to<br>P47, P50 to P57, P64 to<br>P67, P70 to P77, P142 to<br>P145                                           | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |                       |      | -25                  | mA   |
|                      |                  | All pins                                                                                                                             | $2.7~V \leq V_{\text{DD}} < 4.0~V$    |                       |      | -10                  | mA   |
| Output current, low  | lol              | Per pin for P00 to P06, P10<br>to P17, P30 to P33, P40 to<br>P47, P50 to P57, P64 to<br>P67, P70 to P77, P120,<br>P130, P140 to P145 | $4.0~V \le V_{DD} \le 5.5~V$          |                       |      | 10                   | mA   |
|                      |                  | Per pin for P60 to P63                                                                                                               | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |                       |      | 15                   | mA   |
|                      |                  | Total of P10 to P17, P30 to<br>P33, P62, P63, P120, P130,<br>P140, P141                                                              | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |                       |      | 30                   | mA   |
|                      |                  | Total of P00 to P06, P40 to<br>P47, P50 to P57, P60, P61,<br>P64 to P67, P70 to P77,<br>P142 to P145                                 | $4.0~V \le V_{\text{DD}} \le 5.5~V$   |                       |      | 30                   | mA   |
|                      |                  | All pins                                                                                                                             | $2.7~V \leq V_{\text{DD}} < 4.0~V$    |                       |      | 10                   | mA   |
| Input voltage, high  | VIH1             | P12, P13, P15, P40 to P47,<br>P67, P144, P145                                                                                        | P50 to P57, P64 to                    | 0.7Vdd                |      | Vdd                  | V    |
|                      | V <sub>IH2</sub> | P00 to P06, P10, P11, P14, P33, P70 to P77, P120, P14                                                                                |                                       | 0.8Vdd                |      | Vdd                  | V    |
|                      | Vінз             | P20 to P27 <sup>Note</sup>                                                                                                           |                                       | 0.7AVREF              |      | AVREF                | V    |
|                      | VIH4             | P60, P61                                                                                                                             |                                       | 0.7VDD                |      | VDD                  | V    |
|                      | V <sub>IH5</sub> | P62, P63                                                                                                                             |                                       | 0.7VDD                |      | 12                   | V    |
|                      | VIH6             | X1, X2, XT1, XT2                                                                                                                     |                                       | $V_{\text{DD}} - 0.5$ |      | VDD                  | V    |
| Input voltage, low   | VIL1             | P12, P13, P15, P40 to P47,<br>P67, P144, P145                                                                                        | P50 to P57, P64 to                    | 0                     |      | 0.3Vdd               | V    |
|                      | VIL2             | P00 to P06, P10, P11, P14, P33, P70 to P77, P120, P14                                                                                |                                       | 0                     |      | 0.2V <sub>DD</sub>   | V    |
|                      | VIL3             | P20 to P27 <sup>Note</sup>                                                                                                           |                                       | 0                     |      | 0.3AV <sub>REF</sub> | V    |
|                      | VIL4             | P60, P61                                                                                                                             |                                       | 0                     |      | 0.3V <sub>DD</sub>   | V    |
|                      | VIL5             | P62, P63                                                                                                                             |                                       | 0                     |      | 0.3V <sub>DD</sub>   | V    |
|                      | VIL6             | X1, X2, XT1, XT2                                                                                                                     |                                       | 0                     |      | 0.4                  | V    |

**Note** When used as A/D converter analog input pins, set  $AV_{REF} = V_{DD}$ .

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

# DC Characteristics (2/4) (TA = -40 to +85°C, 2.7 V $\leq$ VDD $\leq$ EVDD $\leq$ 5.5 V, 2.7 V $\leq$ AVREF $\leq$ VDD, Vss = EVss = AVss = 0 V)

| Parameter                               | Symbol |                                                           | MIN.                                            | TYP.                                                                                 | MAX.                  | Unit |                    |    |
|-----------------------------------------|--------|-----------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------|------|--------------------|----|
| Output voltage, high                    | Vон    | Total of P10<br>to P33, P12<br>P140, P141<br>Іон = –25 m/ |                                                 | $\begin{array}{l} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \\ I_{OH} = -5 \ mA \end{array}$ | V <sub>DD</sub> - 1.0 |      |                    | V  |
|                                         |        | to P47, P50                                               | to P06, P40<br>to P57, P64<br>to P77, P142<br>A | 4.0 V $\leq$ V_DD $\leq$ 5.5 V,<br>IOH = -5 mA                                       | V <sub>DD</sub> - 1.0 |      |                    | V  |
|                                         |        | Іон = –100 <i>µ</i>                                       | ιA                                              | $2.7~V \leq V_{\text{DD}} < 4.0~V$                                                   | Vdd - 0.5             |      |                    | V  |
| Output voltage, low                     | Vol1   |                                                           | -                                               | $\begin{array}{l} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \\ I_{OL} = 10 \ mA \end{array}$ |                       |      | 1.3                | V  |
|                                         |        | to P47, P50                                               |                                                 | $\begin{array}{l} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \\ I_{OL} = 10 \ mA \end{array}$ |                       |      | 1.3                | V  |
|                                         |        | Ioι = 400 μA                                              | ١                                               | $2.7~V \leq V_{\text{DD}} < 4.0~V$                                                   |                       |      | 0.4                | V  |
|                                         | Vol2   | P60 to P63                                                |                                                 | lo∟ = 15 mA                                                                          |                       |      | 2.0                | V  |
| Input leakage current, high             | Ішні   | $V_{I} = V_{DD}$                                          | P33, P40 to P<br>P61, P64 to P                  | 210 to P17, P30 to<br>247, P50 to P57, P60,<br>267, P70 to P77,<br>2 P145, RESET     |                       |      | 3                  | μA |
|                                         |        | $V_{\text{I}} = AV_{\text{REF}}$                          | P20 to P27                                      |                                                                                      |                       |      | 3                  | μA |
| Î                                       | ILIH2  | $V_{\text{I}} = V_{\text{DD}}$                            | X1, X2, XT1,                                    | XT2                                                                                  |                       |      | 20                 | μA |
|                                         | Ілнз   | Vi = 12 V                                                 | P62, P63 (N-0                                   | ch open drain)                                                                       |                       |      | 3                  | μA |
| Input leakage current, low              | Ilili  | V1 = 0 V                                                  | P27, P30 to P<br>to P57, P60, F                 | 210 to P17, P20 to<br>233, P40 to P47, P50<br>P61, P64 to P67, P70<br>P140 to P145,  |                       |      | -3                 | μA |
|                                         |        |                                                           | X1, X2, XT1, 2                                  | XT2                                                                                  |                       |      | -20                | μA |
|                                         | Ililis |                                                           | P62, P63 (N-0                                   | ch open drain)                                                                       |                       |      | -3 <sup>Note</sup> | μA |
| Output leakage current, high            | Ігон   | $V_{\text{O}} = V_{\text{DD}}$                            |                                                 |                                                                                      |                       |      | 3                  | μA |
| Output leakage current, low             | Ilol   | Vo = 0 V                                                  |                                                 |                                                                                      |                       |      | -3                 | μA |
| Pull-up resistance value                | R∟     | V1 = 0 V                                                  |                                                 |                                                                                      | 10                    | 30   | 100                | kΩ |
| VPP supply voltage<br>(µPD78F0148 only) | VPP1   | In normal op                                              | peration mode                                   |                                                                                      | 0                     |      | 0.2Vdd             | V  |

**Note** If there is no on-chip pull-up resistor for P62 and P63 (specified by a mask option) and if port 6 has been set to input mode when a read instruction is executed to read from port 6, a low-level input leakage current of up to  $-45 \ \mu$ A flows during only one cycle. At all other times, the maximum leakage current is  $-3 \ \mu$ A.

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

# **★** DC Characteristics (3/4): μPD78F0148

# $(T_{A} = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{\text{DD}} \le \text{EV}_{\text{DD}} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{\text{REF}} \le \text{V}_{\text{DD}}, \text{V}_{\text{SS}} = \text{EV}_{\text{SS}} = \text{AV}_{\text{SS}} = 0 \text{ V})$

| Parameter                 | Symbol          |                                                                | Condition                                                    | S                                                    | MIN. | TYP. | MAX. | Unit |
|---------------------------|-----------------|----------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------|------|------|------|------|
| Supply                    | DD1             | X1 crystal                                                     | fxp = 10 MHz                                                 | When A/D converter is stopped                        |      | 13.5 | 29.7 | mA   |
| Current <sup>Note 1</sup> |                 | oscillation<br>operating                                       | $V_{\text{DD}} = 5.0 \ V \pm 10\%^{\text{Notes 3, 7}}$       | When A/D converter is<br>operating <sup>Note 9</sup> |      | 14.5 | 31.9 | mA   |
|                           |                 | mode <sup>Note 2</sup>                                         | fxp = 8.38 MHz                                               | When A/D converter is stopped                        |      | 9.5  | 19   | mA   |
|                           |                 |                                                                | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Notes 3, 8}}$ | When A/D converter is operating <sup>Note 9</sup>    |      | 10.5 | 21   | mA   |
|                           |                 |                                                                | fxp = 5 MHz                                                  | When A/D converter is stopped                        |      | 5    | 10   | mA   |
|                           |                 |                                                                | $V_{DD} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$            | When A/D converter is operating <sup>Note 9</sup>    |      | 7    | 14   | mA   |
|                           | IDD2 X1 crystal |                                                                | fxp = 10 MHz                                                 | When peripheral functions are stopped                |      | 1.7  | 3.4  | mA   |
|                           |                 | oscillation HALT                                               | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Notes 3, 7}}$ | When peripheral functions are operating              |      |      | 9.6  | mA   |
|                           |                 | mode                                                           | fxp = 8.38 MHz                                               | When peripheral functions are stopped                |      | 1    | 2    | mA   |
|                           |                 |                                                                | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Notes 3, 8}}$ | When peripheral functions are operating              |      |      | 4.5  | mA   |
|                           | IDD3 Ring-OSC   | fxp = 5 MHz                                                    | When peripheral functions are stopped                        |                                                      | 0.5  | 1    | mA   |      |
|                           |                 | $V_{DD} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$              | When peripheral functions are operating                      |                                                      |      | 2    | mA   |      |
|                           |                 | Ũ                                                              | V <sub>DD</sub> = 5.0 V ±10%                                 |                                                      |      | 0.7  | 2.1  | mA   |
|                           |                 | operating<br>mode <sup>Note 4</sup>                            | $V_{\text{DD}}=3.0~V~\pm10\%$                                |                                                      |      | 0.4  | 1.2  | mA   |
|                           | IDD4            | 32.768 kHz                                                     | V <sub>DD</sub> = 5.0 V ±10%                                 |                                                      |      | 115  | 230  | μA   |
|                           |                 | crystal oscillation<br>operating<br>mode <sup>Notes 4, 6</sup> | V <sub>DD</sub> = 3.0 V ±10%                                 |                                                      |      | 95   | 190  | μA   |
|                           | IDD5            | 32.768 kHz                                                     | $V_{DD} = 5.0 \text{ V} \pm 10\%$                            |                                                      |      | 30   | 60   | μA   |
|                           |                 | crystal oscillation<br>HALT mode <sup>Notes 4, 6</sup>         | $V_{DD} = 3.0 \text{ V} \pm 10\%$                            |                                                      |      | 6    | 18   | μA   |
|                           | IDD6            | STOP mode                                                      | VDD = 5.0 V ±10%                                             | POC: OFF, RING: OFF                                  |      | 0.1  | 30   | μA   |
|                           |                 |                                                                |                                                              | POC: OFF, RING: ON                                   |      | 14   | 58   | μA   |
|                           |                 |                                                                |                                                              | POC: ON <sup>NOTE 5</sup> , RING: OFF                |      | 3.5  | 35.5 | μA   |
|                           |                 |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: ON                 |      | 17.5 | 63.5 | μA   |
|                           |                 |                                                                | $V_{DD} = 3.0 \text{ V} \pm 10\%$                            | POC: OFF, RING: OFF                                  |      | 0.05 | 10   | μA   |
|                           |                 |                                                                |                                                              | POC: OFF, RING: ON                                   |      | 7.5  | 25   | μA   |
|                           |                 |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: OFF                |      | 3.5  | 15.5 | μA   |
|                           |                 |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: ON                 |      | 11   | 30.5 | μA   |

**Notes 1.** Total current flowing through the internal power supply (VDD). Peripheral operation current is included (however, the current that flows through the pull-up resistors of ports is not included).

- 2. IDD1 includes peripheral operation current.
- **3.** When PCC = 00H.
- 4. When main system clock is stopped.
- 5. Including when LVIE (bit 4 of LVIM) = 1 with POC-OFF selected by a mask option.
- 6. When POC-OFF (including LVIE = 0) is selected by a mask option and Ring-OSC oscillation is stopped.
- 7. When the REGC pin is directly connected to  $V_{DD}$ .
- 8. When the REGC pin is connected to Vss via a 0.1  $\mu$ F capacitor.
- **9.** Including the current that flows through the AV<sub>REF</sub> pin.

# **★** DC Characteristics (4/4): μPD780143, 780144, 780146, and 780148

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{DD} \le \text{EV}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{\text{REF}} \le \text{V}_{DD}, \text{V}_{\text{SS}} = \text{EV}_{\text{SS}} = \text{AV}_{\text{SS}} = 0 \text{ V})$

| Parameter                 | Symbol |                                                                | Condition                                                    | Conditions                                           |  |      |      |    |  |
|---------------------------|--------|----------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------|--|------|------|----|--|
| Supply                    | IDD1   | X1 crystal                                                     | fxp = 10 MHz                                                 | When A/D converter is stopped                        |  | 6    | 15   | mA |  |
| current <sup>Note 1</sup> |        | oscillation<br>operating                                       | $V_{\text{DD}} = 5.0 \ V \pm 10\%^{\text{Notes 3, 7}}$       | When A/D converter is operating <sup>Note 9</sup>    |  | 7    | 17.5 | mA |  |
|                           |        | mode <sup>Note 2</sup>                                         | fxp = 8.38 MHz                                               | When A/D converter is stopped                        |  | 4    | 8    | mA |  |
|                           |        |                                                                | $V_{\text{DD}} = 5.0 \ V \pm 10\%^{\text{Notes 3, 8}}$       | When A/D converter is<br>operating <sup>Note 9</sup> |  | 5    | 10   | mA |  |
|                           |        |                                                                | fxp = 5 MHz                                                  | When A/D converter is stopped                        |  | 3    | 6    | mA |  |
|                           |        |                                                                | $V_{\text{DD}} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$     | When A/D converter is<br>operating <sup>Note 9</sup> |  | 4    | 8    | mA |  |
|                           | IDD2   | X1 crystal                                                     | fxp = 10 MHz                                                 | When peripheral functions are stopped                |  | 1.7  | 3.4  | mA |  |
|                           |        | oscillation HALT                                               | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Notes 3, 7}}$ | When peripheral functions are operating              |  |      | 9.6  | mA |  |
|                           |        | mode                                                           | fxp = 8.38 MHz                                               | When peripheral functions are stopped                |  | 1    | 2    | mA |  |
|                           |        |                                                                | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Notes 3, 8}}$ | When peripheral functions are operating              |  |      | 4.5  | mA |  |
|                           |        |                                                                | $f_{XP} = 5 \text{ MHz}$                                     | When peripheral functions are stopped                |  | 0.5  | 1    | mA |  |
|                           |        | $V_{DD} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$              | When peripheral functions are operating                      |                                                      |  | 2    | mA   |    |  |
|                           | IDD3   | Ring-OSC                                                       | $V_{DD} = 5.0 \text{ V} \pm 10\%$                            |                                                      |  | 0.3  | 0.9  | mA |  |
|                           |        | operating<br>mode <sup>Note 4</sup>                            | $V_{DD} = 3.0 \text{ V} \pm 10\%$                            |                                                      |  | 0.19 | 0.57 | mA |  |
|                           | IDD4   | 32.768 kHz                                                     | $V_{DD} = 5.0 \text{ V} \pm 10\%$                            |                                                      |  | 45   | 90   | μA |  |
|                           |        | crystal oscillation<br>operating<br>mode <sup>Notes 4, 6</sup> | $V_{DD} = 3.0 \text{ V} \pm 10\%$                            |                                                      |  | 25   | 50   | μA |  |
|                           | IDD5   | 32.768 kHz                                                     | $V_{DD} = 5.0 \text{ V} \pm 10\%$                            |                                                      |  | 30   | 60   | μA |  |
|                           |        | crystal oscillation<br>HALT mode <sup>Notes 4, 6</sup>         | $V_{DD} = 3.0 \text{ V} \pm 10\%$                            |                                                      |  | 6    | 18   | μA |  |
|                           |        | STOP mode                                                      | $V_{DD} = 5.0 \text{ V} \pm 10\%$                            | POC: OFF, RING: OFF                                  |  | 0.1  | 30   | μA |  |
|                           |        |                                                                |                                                              | POC: OFF, RING: ON                                   |  | 14   | 58   | μA |  |
|                           |        |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: OFF                |  | 3.5  | 35.5 | μA |  |
|                           |        |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: ON                 |  | 17.5 | 63.5 | μA |  |
|                           |        |                                                                | $V_{\text{DD}}=3.0~V\pm10\%$                                 | POC: OFF, RING: OFF                                  |  | 0.05 | 10   | μA |  |
|                           |        |                                                                |                                                              | POC: OFF, RING: ON                                   |  | 7.5  | 25   | μA |  |
|                           |        |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: OFF                |  | 3.5  | 15.5 | μA |  |
|                           |        |                                                                |                                                              | POC: ON <sup>Note 5</sup> , RING: ON                 |  | 11   | 30.5 | μA |  |

**Notes 1.** Total current flowing through the internal power supply (V<sub>DD</sub>). Peripheral operation current is included (however, the current that flows through the pull-up resistors of ports is not included).

- 2. IDD1 includes peripheral operation current.
- **3.** When PCC = 00H.
- 4. When main system clock is stopped.
- 5. Including when LVIE (bit 4 of LVIM) = 1 with POC-OFF selected by a mask option.
- 6. When POC-OFF (including LVIE = 0) is selected by a mask option and Ring-OSC oscillation is stopped.
- 7. When the REGC pin is directly connected to  $V_{DD}$ .
- **8.** When the REGC pin is connected to Vss via a 0.1  $\mu$ F capacitor.
- **9.** Including the current that flows through the AVREF pin.

# **AC Characteristics**

### (1) Basic operation (T<sub>A</sub> = -40 to +85°C, 2.7 V $\leq$ VDD $\leq$ EVDD $\leq$ 5.5 V, 2.7 V $\leq$ AVREF $\leq$ VDD, Vss = EVss = AVss = 0 V)

| Parameter                                                                                  | Symbol          |                                                    | C                                  | Conditions |                                               | MIN.  | TYP. | MAX.  | Unit |
|--------------------------------------------------------------------------------------------|-----------------|----------------------------------------------------|------------------------------------|------------|-----------------------------------------------|-------|------|-------|------|
| Instruction cycle (minimum                                                                 | Тсч             | Main                                               | X1 input                           | Note 1     | $3.3~V \leq V_{\text{DD}} \leq 5.5~V$         | 0.238 |      | 16    | μs   |
| instruction execution time)                                                                |                 | system                                             | clock                              |            | $2.7~V \leq V_{\text{DD}} < 3.3~V$            | 0.4   |      | 16    | μs   |
|                                                                                            |                 | clock<br>operation                                 |                                    | Note 2     | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$         | 0.2   |      | 16    | μs   |
|                                                                                            |                 |                                                    |                                    |            | $3.3~V \leq V_{\text{DD}} < 4.0~V$            | 0.238 |      | 16    | μs   |
|                                                                                            |                 |                                                    |                                    |            | $2.7~V \leq V_{\text{DD}} < 3.3~V$            | 0.4   |      | 16    | μs   |
|                                                                                            |                 |                                                    | Ring-OSC                           | clock      |                                               | 4.17  | 8.33 | 16.67 | μs   |
|                                                                                            |                 | Subsystem clock operation                          |                                    |            |                                               | 114   | 122  | 125   | μs   |
| TI000, TI010, TI001 <sup>Note 3</sup> ,<br>TI011 <sup>Note 3</sup> input high-level width, | tтіно,<br>tтіlo | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$              |                                    |            |                                               |       |      |       | μs   |
| low-level width                                                                            |                 | $2.7 \text{ V} \leq V_{\text{DD}} < 4.0 \text{ V}$ |                                    |            | 2/f <sub>sam</sub> +<br>0.2 <sup>Note 4</sup> |       |      | μs    |      |
| TI50, TI51 input frequency                                                                 | ft15            | $4.0 V \leq V_D$                                   | $V_{\text{DD}} \leq 5.5 \text{ V}$ |            |                                               |       |      | 10    | MHz  |
|                                                                                            |                 | $2.7 \text{ V} \leq \text{V}_{\text{D}}$           | d < 4.0 V                          |            |                                               |       |      | 5     | MHz  |
| TI50, TI51 input high-level width,                                                         | tтiнs,          | $4.0 \text{ V} \leq \text{V}_{\text{D}}$           | d ≤ 5.5 V                          |            |                                               | 50    |      |       | ns   |
| low-level width                                                                            | t⊤il5           | $2.7 \text{ V} \leq V_D$                           | d < 4.0 V                          |            |                                               | 100   |      |       | ns   |
| Interrupt input high-level width, low-level width                                          | tinth,<br>tintl |                                                    |                                    |            |                                               | 1     |      |       | μs   |
| Key return input low-level width                                                           | tкв             | $4.0 \text{ V} \leq \text{V}_{\text{D}}$           | d ≤ 5.5 V                          |            |                                               | 50    |      |       | ns   |
|                                                                                            |                 | $2.7 \ V \leq V_D$                                 | d < 4.0 V                          |            |                                               | 100   |      |       | ns   |
| RESET low-level width                                                                      | <b>t</b> RST    |                                                    |                                    |            |                                               | 10    |      |       | μs   |

**Notes 1.** When the REGC pin is connected to Vss via a 0.1  $\mu$ F capacitor.

2. When the REGC pin is directly connected to VDD.

**3.** *μ*PD780146, 780148, and 78F0148 only.

4. Selection of fsam = fxp, fxp/4, fxp/256, or fxp, fxp/16, fxp/64 is possible using bits 0 and 1 (PRM000, PRM001 or PRM010, PRM011) of prescaler mode registers 00 and 01 (PRM00, PRM01). Note that when selecting the TI000, TI010, TI001, or TI011 valid edge as the count clock, fsam = fxp.



(a) When REGC pin is connected to Vss via 0.1  $\mu$ F capacitor

TCY vs. VDD (X1 Input Clock Operation)

# (b) When REGC pin is directly connected to $V_{DD}$



#### (2) Read/write operation

 $(T_{A} = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}\text{dD} \le \text{EV}\text{dD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}\text{Ref} \le \text{V}\text{dD}, \text{Vss} = \text{EV}\text{ss} = \text{AV}\text{ss} = 0 \text{ V})$ 

|                                                                              |                |            | 1                  |                     | (1/2 |
|------------------------------------------------------------------------------|----------------|------------|--------------------|---------------------|------|
| Parameter                                                                    | Symbol         | Conditions | MIN.               | MAX.                | Unit |
| ASTB high-level width                                                        | <b>t</b> asth  |            | 0.3tcv             |                     | ns   |
| Address setup time                                                           | tads           |            | 20                 |                     | ns   |
| Address hold time                                                            | tadh           |            | 6                  |                     | ns   |
| Data input time from address                                                 | tadd1          |            |                    | (2 + 2n)tcr - 54    | ns   |
|                                                                              | tadd2          |            |                    | (3 + 2n)tcr - 60    | ns   |
| Address output time from $\overline{\text{RD}} {\downarrow}$                 | trdad          |            | 0                  | 100                 | ns   |
| Data input time from $\overline{\mathrm{RD}} \downarrow$                     | trdd1          |            |                    | (2 + 2n)tcr – 87    | ns   |
|                                                                              | trdd2          |            |                    | (3 + 2n)tcy - 93    | ns   |
| Read data hold time                                                          | <b>t</b> RDH   |            | 0                  |                     | ns   |
| RD low-level width                                                           | tRDL1          |            | (1.5 + 2n)tcr – 33 |                     | ns   |
|                                                                              | trdl2          |            | (2.5 + 2n)tcr - 33 |                     | ns   |
| Input time from $\overline{RD} \downarrow$ to $\overline{WAIT} \downarrow$   | trdwt1         |            |                    | tcy - 43            | ns   |
|                                                                              | trdwt2         |            |                    | tcy - 43            | ns   |
| Input time from $\overline{WR} \downarrow$ to $\overline{WAIT} \downarrow$   | twrwт          |            |                    | tcy - 25            | ns   |
| WAIT low-level width                                                         | tw⊤∟           |            | (0.5 + 2n)tcr + 10 | <b>(2 + 2n)t</b> cr | ns   |
| Write data setup time                                                        | twos           |            | 60                 |                     | ns   |
| Write data hold time                                                         | twdн           |            | 6                  |                     | ns   |
| WR low-level width                                                           | twRL1          |            | (1.5 + 2n)tcr – 15 |                     | ns   |
| Delay time from ASTB $\downarrow$ to $\overline{\text{RD}} \downarrow$       | <b>t</b> astrd |            | 6                  |                     | ns   |
| Delay time from ASTB $\downarrow$ to $\overline{\text{WR}}\downarrow$        | <b>t</b> astwr |            | 2tcy – 15          |                     | ns   |
| Delay time from $\overline{RD}\uparrow$ to ASTB $\uparrow$ at external fetch | <b>t</b> rdast |            | 0.8tcy - 15        | 1.2tcr              | ns   |
| Address hold time from $\overline{\text{RD}} \uparrow$ at external fetch     | trdadh         |            | 0.8tcy - 15        | 1.2tcy + 30         | ns   |
| Write data output time from $\overline{\text{RD}}$                           | trdwd          |            | 40                 |                     | ns   |
| Write data output time from $\overline{\rm WR} {\downarrow}$                 | twrwd          |            | 10                 | 60                  | ns   |
| Address hold time from $\overline{\text{WR}} \uparrow$                       | twradh         |            | 0.8tcy - 15        | 1.2tcy + 30         | ns   |
| Delay time from $\overline{WAIT}$ to $\overline{RD}$                         | <b>t</b> wtrd  |            | 0.8tcy             | 2.5tcy + 25         | ns   |
| Delay time from $\overline{WAIT}$ to $\overline{WR}$                         | twrwr          |            | 0.8tcy             | 2.5tcr + 25         | ns   |

Caution Tcy can only be used at 0.238  $\mu$ s (MIN).

Remarks 1. tcy = Tcy/4

- 2. n indicates the number of waits.
- **3.** C<sub>L</sub> = 100 pF (C<sub>L</sub> indicates the load capacitance of the AD0 to AD7, A8 to A15, RD, WR, WAIT, and ASTB pins.)

### (2) Read/write operation

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{DD} \le \text{EV}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{REF} \le \text{V}_{DD}, \text{V}_{SS} = \text{EV}_{SS} = \text{AV}_{SS} = 0 \text{ V})$

|                                                                             |                |            |                    | I                 | (2/  |
|-----------------------------------------------------------------------------|----------------|------------|--------------------|-------------------|------|
| Parameter                                                                   | Symbol         | Conditions | MIN.               | MAX.              | Unit |
| ASTB high-level width                                                       | <b>t</b> asth  |            | 0.3tcy             |                   | ns   |
| Address setup time                                                          | tads           |            | 30                 |                   | ns   |
| Address hold time                                                           | <b>t</b> adh   |            | 10                 |                   | ns   |
| Input time from address to data                                             | tadd1          |            |                    | (2 + 2n)tcr – 108 | ns   |
|                                                                             | tadd2          |            |                    | (3 + 2n)tcr – 120 | ns   |
| Output time from $\overline{\mathrm{RD}} \downarrow$ to address             | trdad          |            | 0                  | 200               | ns   |
| Input time from $\overline{RD} \downarrow$ to data                          | trdd1          |            |                    | (2 + 2n)tcr – 148 | ns   |
|                                                                             | trdd2          |            |                    | (3 + 2n)tcr – 162 | ns   |
| Read data hold time                                                         | <b>t</b> RDH   |            | 0                  |                   | ns   |
| RD low-level width                                                          | tRDL1          |            | (1.5 + 2n)tcr – 40 |                   | ns   |
|                                                                             | tRDL2          |            | (2.5 + 2n)tcr – 40 |                   | ns   |
| Input time from $\overline{RD} \downarrow$ to $\overline{WAIT} \downarrow$  | trdwt1         |            |                    | tcy – 75          | ns   |
|                                                                             | trdwt2         |            |                    | tcy – 60          | ns   |
| Input time from $\overline{WR} \downarrow$ to $\overline{WAIT} \downarrow$  | twrwt          |            |                    | tcy – 50          | ns   |
| WAIT low-level width                                                        | twr∟           |            | (0.5 + 2n)tcr + 10 | (2 + 2n)tcr       | ns   |
| Write data setup time                                                       | twos           |            | 60                 |                   | ns   |
| Write data hold time                                                        | twdн           |            | 10                 |                   | ns   |
| WR low-level width                                                          | twRL1          |            | (1.5 + 2n)tcr – 30 |                   | ns   |
| Delay time from ASTB $\downarrow$ to $\overline{\mathrm{RD}}\downarrow$     | <b>t</b> ASTRD |            | 10                 |                   | ns   |
| Delay time from ASTB $\downarrow$ to $\overline{WR}\downarrow$              | <b>t</b> astwr |            | 2tcy - 30          |                   | ns   |
| Delay time from $\overline{\text{RD}}$ to ASTB $\uparrow$ at external fetch | <b>t</b> rdast |            | 0.8tcy - 30        | 1.2tcv            | ns   |
| Hold time from RD↑ to address at external fetch                             | trdadh         |            | 0.8tcy - 30        | 1.2tcy + 60       | ns   |
| Write data output time from $\overline{RD}^\uparrow$                        | trowd          |            | 40                 |                   | ns   |
| Write data output time from $\overline{WR} \downarrow$                      | twrwd          |            | 20                 | 120               | ns   |
| Hold time from $\overline{WR}^{\uparrow}$ to address                        | twradh         |            | 0.8tcy - 30        | 1.2tcy + 60       | ns   |
| Delay time from $\overline{WAIT}$ to $\overline{RD}$                        | twrrd          |            | 0.5tcy             | 2.5tcy + 50       | ns   |
| Delay time from $\overline{WAIT}$ to $\overline{WR}$                        | twrwr          |            | 0.5tcr             | 2.5tcy + 50       | ns   |

Caution Tcy can only be used at 0.4  $\mu$ s (MIN).

Remarks 1. tcy = Tcy/4

- 2. n indicates the number of waits.
- **3.**  $C_{L} = 100 \text{ pF}$  ( $C_{L}$  indicates the load capacitance of the AD0 to AD7, A8 to A15,  $\overline{RD}$ ,  $\overline{WR}$ ,  $\overline{WAIT}$ , and ASTB pins.)

#### (3) Serial interface

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}\text{dD} \le \text{EV}\text{dD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}\text{ReF} \le \text{V}\text{dD}, \text{Vss} = \text{EV}\text{ss} = \text{AV}\text{ss} = 0 \text{ V})$

#### (a) UART mode (UART6, dedicated baud rate generator output)

| Parameter     | Symbol | Conditions | MIN. | TYP. | MAX.  | Unit |
|---------------|--------|------------|------|------|-------|------|
| Transfer rate |        |            |      |      | 312.5 | kbs  |

#### (b) UART mode (UART0, dedicated baud rate generator output)

| Parameter     | Symbol | Conditions | MIN. | TYP. | MAX.  | Unit |
|---------------|--------|------------|------|------|-------|------|
| Transfer rate |        |            |      |      | 312.5 | kbs  |

#### (c) 3-wire serial I/O mode (master mode, SCK1n... internal clock output)

| Parameter                                                          | Symbol | Conditions                            | MIN.       | TYP. | MAX. | Unit |
|--------------------------------------------------------------------|--------|---------------------------------------|------------|------|------|------|
| SCK1n cycle time                                                   | tксүı  | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ | 200        |      |      | ns   |
|                                                                    |        | $3.3~V \leq V_{\text{DD}} < 4.0~V$    | 240        |      |      | ns   |
|                                                                    |        | $2.7~V \leq V_{\text{DD}} < 3.3~V$    | 400        |      |      | ns   |
| SCK1n high-/low-level width                                        | tкнı,  |                                       | tксү1/2–10 |      |      | ns   |
|                                                                    | tĸ∟1   |                                       |            |      |      |      |
| SI1n setup time (to SCK1n↑)                                        | tsik1  |                                       | 30         |      |      | ns   |
| SI1n hold time (from $\overline{\text{SCK1n}}$ )                   | tksi1  |                                       | 30         |      |      | ns   |
| Delay time from $\overline{\text{SCK1n}}\downarrow$ to SO1n output | tkso1  | C = 100 pF <sup>Note</sup>            |            |      | 30   | ns   |

Note C is the load capacitance of the SCK1n and SO1n output lines.

# (d) 3-wire serial I/O mode (slave mode, SCK1n... external clock input)

| Parameter                                                   | Symbol        | Conditions                         | MIN.    | TYP. | MAX. | Unit |
|-------------------------------------------------------------|---------------|------------------------------------|---------|------|------|------|
| SCK1n cycle time                                            | tkCY2         |                                    | 400     |      |      | ns   |
| SCK1n high-/low-level width                                 | <b>t</b> кн2, |                                    | tксү2/2 |      |      | ns   |
|                                                             | tkl2          |                                    |         |      |      |      |
| SI1n setup time (to SCK1n↑)                                 | tsik2         |                                    | 80      |      |      | ns   |
| SI1n hold time (from SCK1n↑)                                | tksi2         |                                    | 50      |      |      | ns   |
| Delay time from $\overline{SCK1n}\downarrow$ to SO1n output | tkso2         | $C = 100 \text{ pF}^{\text{Note}}$ |         |      | 120  | ns   |

**Note** C is the load capacitance of the SO1n output line.

**Remark** n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148

| Parameter                                                   | Symbol     | Co                                          | onditions                             | MIN.        | TYP. | MAX.   | Unit |
|-------------------------------------------------------------|------------|---------------------------------------------|---------------------------------------|-------------|------|--------|------|
| SCKA0 cycle time                                            | tксүз      | $4.0 V \le V_{DD} \le$                      | 5.5 V                                 | 600         |      |        | ns   |
|                                                             |            | $2.7 \text{ V} \leq \text{V}_{\text{DD}}$ < | : 4.0 V                               | 1200        |      |        | ns   |
| SCKA0 high-/low-level width                                 | t⊤нз, tт∟з | $4.0 V \le V_{DD} \le$                      | 5.5 V                                 | tксүз2–50   |      |        | ns   |
|                                                             |            | $2.7 \text{ V} \leq \text{V}_{\text{DD}}$ < | : 4.0 V                               | tксүз/2–100 |      |        | ns   |
| SIA0 setup time (to SCKA0↑)                                 | tsiкз      |                                             |                                       | 100         |      |        | ns   |
| SIA0 hold time (from SCKA0↑)                                | tหรเง      |                                             |                                       | 300         |      |        | ns   |
| Delay time from $\overline{\text{SCKA0}}\downarrow$ to SOA0 | tкsoз      | $C = 100 \text{ pF}^{\text{Note}}$          | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |             |      | 200    | ns   |
| output                                                      |            |                                             | $2.7~V \leq V_{\text{DD}} < 4.0~V$    |             |      | 300    |      |
| Time from SCKA0↑ to STB0↑                                   | tsbd       |                                             |                                       | tксүз/2–100 |      |        | ns   |
| Strobe signal high-level width                              | tsвw       | $4.0 V \le V_{DD} \le$                      | 5.5 V                                 | tксүз–30    |      |        | ns   |
|                                                             |            | $2.7 \text{ V} \leq \text{V}_{\text{DD}} <$ | : 4.0 V                               | tксүз–60    |      |        | ns   |
| Busy signal setup time (to busy signal detection timing)    | tвys       |                                             |                                       | 100         |      |        | ns   |
| Busy signal hold time (from busy signal detection timing)   | tвүн       | $4.0 V \le V_{DD} \le$                      | 5.5 V                                 | 100         |      |        | ns   |
|                                                             |            | $2.7 \text{ V} \leq \text{V}_{\text{DD}}$ < | : 4.0 V                               | 150         |      |        | ns   |
| Time from busy inactive to $\overline{SCKA0}\downarrow$     | tsps       |                                             |                                       |             |      | 2tксүз | ns   |

(e) 3-wire serial I/O mode with automatic transmit/receive function (SCKA0... internal clock output)

Note C is the load capacitance of the SCKA0 and SOA0 output lines.

# (f) 3-wire serial I/O mode with automatic transmit/receive function (SCKA0 ... external clock input)

| Parameter                                                   | Symbol        | Co                                              | nditions                              | MIN. | TYP. | MAX. | Unit |
|-------------------------------------------------------------|---------------|-------------------------------------------------|---------------------------------------|------|------|------|------|
| SCKA0 cycle time                                            | <b>t</b> ксү4 | $4.0 V \le V_{DD} \le$                          | 5.5 V                                 | 600  |      |      | ns   |
|                                                             |               | $2.7 V \leq V_{DD} <$                           | 4.0 V                                 | 1200 |      |      | ns   |
| SCKA0 high-/low-level width                                 | tĸн4, tĸ∟4    | $4.0 V \le V_{DD} \le$                          | 5.5 V                                 | 300  |      |      | ns   |
|                                                             |               | $2.7 V \leq V_{DD} <$                           | 4.0 V                                 | 600  |      |      | ns   |
| SIA0 setup time (to SCKA0↑)                                 | tsik4         |                                                 |                                       | 100  |      |      | ns   |
| SIA0 hold time (from SCKA0↑)                                | tksi4         |                                                 |                                       | 300  |      |      | ns   |
| Delay time from $\overline{\text{SCKA0}}\downarrow$ to SOA0 | tĸso4         | $C = 100 \text{ pF}^{\text{Note}}$              | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ |      |      | 200  | ns   |
| output                                                      |               |                                                 | $2.7~V \leq V_{\text{DD}} < 4.0~V$    |      |      | 300  | ns   |
| SCKA0 rise/fall time                                        | tr4, tf4      | When external device expansion function is used |                                       |      |      | 120  | ns   |
|                                                             |               | When externation is no                          | al device expansion<br>t used         |      |      | 1000 | ns   |

**Note** C is the load capacitance of the SOA0 output line.

# AC Timing Test Points (Excluding X1 Input)



**Note**  $\mu$ PD780146, 780148, and 78F0148 only.

# **RESET** Input Timing



# **Read/Write Operation**

#### External fetch (no wait):









#### External data access (no wait):

#### External data access (wait insertion):



# Serial Transfer Timing

# 3-wire serial I/O mode:



# **Remark** m = 1, 2

n = 0: μPD780143, 780144 n = 0, 1: μPD780146, 780148, 78F0148



#### 3-wire serial I/O mode with automatic transmit/receive function:

3-wire serial I/O mode with automatic transmit/receive function (busy processing):



Note The signal is not actually driven low here; it is shown as such to indicate the timing.

# ★ A/D Converter Characteristics

#### $(T_{A} = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}\text{dD} \le \text{EV}\text{dD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}\text{Ref} \le \text{V}\text{dD}, \text{Vss} = \text{EV}\text{ss} = \text{AV}\text{ss} = 0 \text{ V})$

| Parameter                                      | Symbol        | Conditions                                                  | MIN. | TYP. | MAX.  | Unit |
|------------------------------------------------|---------------|-------------------------------------------------------------|------|------|-------|------|
| Resolution                                     |               |                                                             | 10   | 10   | 10    | bit  |
| Overall error <sup>Notes 1, 2</sup>            |               | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     |      | ±0.2 | ±0.4  | %FSR |
|                                                |               | $2.7 \text{ V} \le \text{AV}_{\text{REF}} < 4.0 \text{ V}$  |      | ±0.3 | ±0.6  | %FSR |
| Conversion time                                | <b>t</b> CONV | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     | 14   |      | 100   | μs   |
|                                                |               | $2.7 \text{ V} \leq AV_{\text{REF}} < 4.0 \text{ V}$        | 17   |      | 100   | μs   |
| Zero-scale error <sup>Notes 1, 2</sup>         |               | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     |      |      | ±0.4  | %FSR |
|                                                |               | $2.7 \text{ V} \leq AV_{\text{REF}} < 4.0 \text{ V}$        |      |      | ±0.6  | %FSR |
| Full-scale error <sup>Notes 1, 2</sup>         |               | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     |      |      | ±0.4  | %FSR |
|                                                |               | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$ |      |      | ±0.6  | %FSR |
| Integral non-linearity error <sup>Note 1</sup> |               | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     |      |      | ±2.5  | LSB  |
|                                                |               | $2.7 \text{ V} \leq AV_{\text{REF}} < 4.0 \text{ V}$        |      |      | ±4.5  | LSB  |
| Differential non-linearity error Note 1        |               | $4.0~V \leq AV_{\text{REF}} \leq 5.5~V$                     |      |      | ±1.5  | LSB  |
|                                                |               | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$ |      |      | ±2.0  | LSB  |
| Analog input voltage                           | VIAN          |                                                             | AVss |      | AVREF | V    |

**Notes 1.** Excludes quantization error ( $\pm 1/2$  LSB).

2. This value is indicated as a ratio (%FSR) to the full-scale value.

# ★ POC Circuit Characteristics (T<sub>A</sub> = -40 to +85°C)

| Parameter                             | Symbol      | Conditions                                                       | MIN.   | TYP. | MAX. | Unit |
|---------------------------------------|-------------|------------------------------------------------------------------|--------|------|------|------|
| Detection voltage                     | VPOC0       | Mask option = 3.5 V                                              | 3.3    | 3.5  | 3.7  | V    |
|                                       | VPOC1       | Mask option = 2.85 V                                             | 2.7    | 2.85 | 3.0  | V    |
| Power supply rise time                | tртн        | VDD: 0 V $\rightarrow$ 2.7 V                                     | 0.0015 |      | 1500 | ms   |
|                                       |             | VDD: 0 V $\rightarrow$ 3.3 V                                     | 0.002  |      | 1800 | ms   |
| Response delay time 1 <sup>Note</sup> | tртнd       | When power supply rises, after reaching detection voltage (MAX.) |        |      | 3.0  | ms   |
| Response delay time 2 <sup>Note</sup> | <b>t</b> PD | When power supply falls, $V_{DD} = 1.7 V$                        |        |      | 1.0  | ms   |
| Minimum pulse width                   | tew         |                                                                  | 0.2    |      |      | ms   |

Note Time required from voltage detection to reset release.

# **POC Circuit Timing**



# LVI Circuit Characteristics (T<sub>A</sub> = -40 to +85°C)

| Parameter                                                   | Symbol          | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------------------------------------|-----------------|------------|------|------|------|------|
| Detection voltage                                           | VLVIO           |            | 4.1  | 4.3  | 4.5  | V    |
|                                                             | VLVI1           |            | 3.9  | 4.1  | 4.3  | V    |
|                                                             | VLVI2           |            | 3.7  | 3.9  | 4.1  | V    |
|                                                             | VLVI3           |            | 3.5  | 3.7  | 3.9  | V    |
|                                                             | VLVI4           |            | 3.3  | 3.5  | 3.7  | V    |
|                                                             | VLVI5           |            | 3.15 | 3.3  | 3.45 | V    |
|                                                             | VLVI6           |            | 2.95 | 3.1  | 3.25 | V    |
| Response time <sup>Note 1</sup>                             | tld             |            |      | 0.2  | 2.0  | ms   |
| Minimum pulse width                                         | tLw             |            | 0.2  |      |      | ms   |
| Reference voltage stabilization wait time <sup>Note 2</sup> | <b>t</b> lwaito |            |      | 0.5  | 2.0  | ms   |
| Operation stabilization wait time Note 3                    | tlwait1         |            |      | 0.1  | 0.2  | ms   |

 $\star$ 

Notes 1. Time required from voltage detection to interrupt output or RESET output.

- 2. Time required from setting LVIE to 1 to reference voltage stabilization when POC = OFF is selected by the POC mask option.
- 3. Time required from setting LVION to 1 to operation stabilization.

# **Remarks 1.** $V_{LV10} > V_{LV11} > V_{LV12} > V_{LV13} > V_{LV14} > V_{LV15} > V_{LV16}$

**2.**  $V_{POCn} < V_{LVIm}$  (n = 0 and 1, m = 0 to 6)

#### **LVI Circuit Timing**



#### Data Memory STOP Mode Low Supply Voltage Data Retention Characteristics (T<sub>A</sub> = -40 to +85°C)

| Parameter                     | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------|--------|------------|------|------|------|------|
| Data retention supply voltage | VDDDR  |            | 1.6  |      | 5.5  | V    |
| Release signal set time       | tsrel  |            | 0    |      |      | μs   |

#### **★** Flash Memory Programming Characteristics: μPD78F0148

#### $(T_{A} = +10 \text{ to } +60^{\circ}\text{C}, 2.7 \text{ V} \le \text{V}_{DD} = \text{EV}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{AV}_{\text{REF}} \le \text{V}_{DD}, \text{Vss} = \text{EV}_{\text{SS}} = \text{AV}_{\text{SS}} = 0 \text{ V})$

| Parameter                                                         | Symbol           | Conditions                                                    | MIN.  | TYP. | MAX.  | Unit   |
|-------------------------------------------------------------------|------------------|---------------------------------------------------------------|-------|------|-------|--------|
| VPP supply voltage                                                | V <sub>PP2</sub> | During flash memory programming                               | 9.7   | 10.0 | 10.3  | V      |
| VDD supply current                                                | IDD              | When $V_{PP} = V_{PP2}$ , $f_{XP} = 10$ MHz, $V_{DD} = 5.5$ V |       |      | 37    | mA     |
| VPP supply current                                                | IPP              | VPP = VPP2                                                    |       |      | 100   | mA     |
| Step erase time <sup>Note 1</sup>                                 | Ter              |                                                               | 0.199 | 0.2  | 0.201 | S      |
| Overall erase time <sup>Note 2</sup>                              | Tera             | When step erase time = 0.2 s                                  |       |      | 20    | s/chip |
| Writeback time <sup>Note 3</sup>                                  | Twb              |                                                               | 49.4  | 50   | 50.6  | ms     |
| Number of writebacks per 1<br>writeback command <sup>Note 4</sup> | Cwb              | When writeback time = 50 ms                                   |       |      | 60    | Times  |
| Number of erases/writebacks                                       | Cerwb            |                                                               |       |      | 16    | Times  |
| Step write time <sup>Note 5</sup>                                 | Twr              |                                                               | 48    | 50   | 52    | μs     |
| Overall write time per word <sup>Note 6</sup>                     | Twrw             | When step write time = 50 $\mu$ s (1 word = 1 byte)           | 48    |      | 520   | μs     |
| Number of rewrites per chip <sup>Note 7</sup>                     | Cerwr            | 1 erase + 1 write after erase = 1 rewrite                     |       |      | 20    | Times  |

#### (1) Write erase characteristics

Notes 1. The recommended setting value of the step erase time is 0.2 s.

- 2. The prewrite time before erasure and the erase verify time (writeback time) are not included.
- **3.** The recommended setting value of the writeback time is 50 ms.
- 4. Writeback is executed once by the issuance of the writeback command. Therefore, the number of retries must be the maximum value minus the number of commands issued.
- 5. The recommended setting value of the step write time is 50  $\mu$ s.
- 6. The actual write time per word is 100  $\mu$ s longer. The internal verify time during or after a write is not included.
- When a product is first written after shipment, "erase → write" and "write only" are both taken as one rewrite.

Example: P: Write, E: Erase

**Remark** The range of the operating clock during flash memory programming is the same as the range during normal operation.

# (2) Serial write operation characteristics

| Parameter                                                                 | Symbol      | Conditions | MIN.   | TYP. | MAX.               | Unit |
|---------------------------------------------------------------------------|-------------|------------|--------|------|--------------------|------|
| Set time from $V_{\text{DD}}\uparrow$ to $V_{\text{PP}}\uparrow$          | <b>t</b> dp |            | 10     |      |                    | μs   |
| Release time from $V_{PP} \uparrow$ to $\overline{\text{RESET}} \uparrow$ | <b>t</b> PR |            | 10     |      |                    | μs   |
| V <sub>PP</sub> pulse input start time from<br>RESET↑                     | trp         |            | 2      |      |                    | ms   |
| VPP pulse high-/low-level width                                           | tew         |            | 8      |      |                    | μs   |
| V <sub>PP</sub> pulse input end time from<br>RESET↑                       | trpe        |            |        |      | 20                 | ms   |
| VPP pulse low-level input voltage                                         | VPPL        |            | 0.8VDD |      | 1.2V <sub>DD</sub> | V    |
| VPP pulse high-level input voltage                                        | VPPH        |            | 9.7    | 10.0 | 10.3               | V    |

# Flash Write Mode Setting Timing



# 80-PIN PLASTIC TQFP (FINE PITCH) (12x12)



#### NOTE

Each lead centerline is located within 0.08 mm of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS                          |
|------|--------------------------------------|
| А    | 14.0±0.2                             |
| В    | 12.0±0.2                             |
| С    | 12.0±0.2                             |
| D    | 14.0±0.2                             |
| F    | 1.25                                 |
| G    | 1.25                                 |
| Н    | 0.22±0.05                            |
| I    | 0.08                                 |
| J    | 0.5 (T.P.)                           |
| ĸ    | 1.0±0.2                              |
| L    | 0.5                                  |
| М    | 0.145±0.05                           |
| Ν    | 0.08                                 |
| Р    | 1.0                                  |
| Q    | 0.1±0.05                             |
| R    | $3^{\circ + 4^{\circ}}_{-3^{\circ}}$ |
| S    | 1.1±0.1                              |
| Т    | 0.25                                 |
| U    | 0.6±0.15                             |
|      | P80GK-50-9EU-1                       |

# 80-PIN PLASTIC QFP (14x14)



detail of lead end



NOTE

Each lead centerline is located within 0.13 mm of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS                     |
|------|---------------------------------|
| А    | 17.20±0.20                      |
| В    | 14.00±0.20                      |
| С    | 14.00±0.20                      |
| D    | 17.20±0.20                      |
| F    | 0.825                           |
| G    | 0.825                           |
| Н    | 0.32±0.06                       |
| I    | 0.13                            |
| J    | 0.65 (T.P.)                     |
| к    | 1.60±0.20                       |
| L    | 0.80±0.20                       |
| М    | $0.17\substack{+0.03 \\ -0.07}$ |
| Ν    | 0.10                            |
| Р    | 1.40±0.10                       |
| Q    | 0.125±0.075                     |
| R    | 3° <sup>+7°</sup><br>-3°        |
| S    | 1.70 MAX.                       |
|      | P80GC-65-8BT-1                  |

# 32.1 Cautions for Wait

\*

This product has two internal system buses.

One is a CPU bus and the other is a peripheral bus that interfaces with the low-speed peripheral hardware.

Because the clock of the CPU bus and the clock of the peripheral bus are asynchronous, unexpected illegal data may be passed if an access to the CPU conflicts with an access to the peripheral hardware.

When accessing the peripheral hardware that may cause a conflict, therefore, the CPU repeatedly executes processing, until the correct data is passed.

As a result, the CPU does not start the next instruction processing but waits. If this happens, the number of execution clocks of an instruction increases by the number of wait clocks (for the number of wait clocks, refer to **Table 32-1**). This must be noted when real-time processing is performed.

#### 32.2 Peripheral Hardware That Generates Wait

Table 32-1 lists the registers that issue a wait request when accessed by the CPU, and the number of CPU wait clocks.

| Peripheral Hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Register | Access | Number of Wait Clocks                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|--------------------------------------------------------------------------------------|
| Watchdog timer                                                                                                                                                                                                                                                                                                                                                                                                                                                        | WDTM     | Write  | 3 clocks (fixed)                                                                     |
| Serial interface UART0                                                                                                                                                                                                                                                                                                                                                                                                                                                | ASIS0    | Read   | 1 clock (fixed)                                                                      |
| Serial interface UART6                                                                                                                                                                                                                                                                                                                                                                                                                                                | ASIS6    | Read   | 1 clock (fixed)                                                                      |
| A/D converter                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ADM      | Write  | 2 to 5 clocks <sup>Note</sup>                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ADS      | Write  | (when ADM.5 flag = "1")                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PFM      | Write  | 2 to 9 clocks <sup>№te</sup><br>(when ADM.5 flag = "0")                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PFT      | Write  |                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ADCR     | Read   | 1 to 5 clocks<br>(when ADM.5 flag = "1")<br>1 to 9 clocks<br>(when ADM.5 flag = "0") |
| <calculating clocks="" maximum="" number="" of="" wait=""><br/>{(1/f<sub>MACRO</sub>) × 2/(1/f<sub>CPU</sub>)} + 1<br/>*The result after the decimal point is truncated if it is<br/>(1/f<sub>CPU</sub>), and is rounded up if it exceeds t<sub>CPUL</sub>.<br/>f<sub>MACRO</sub>: Macro operating frequency<br/>(When bit 5 (FR2) of ADM = "1": fx/2, when<br/>f<sub>CPU</sub>: CPU clock frequency<br/>t<sub>CPUL</sub>: Low-level width of CPU clock</calculating> |          |        |                                                                                      |

Table 32-1. Registers That Generate Wait and Number of CPU Wait Clocks

Note No wait cycle is generated for the CPU if the number of wait clocks calculated by the above expression is 1.

**Remarks 1.** The clock is the CPU clock (fcPu).

2. When the CPU is operating on the subsystem clock and the X1 input clock is stopped, do not access the registers listed above using an access method in which a wait request is issued.

#### 32.3 Example of Wait Occurrence

<1> Watchdog timer

<On execution of MOV WDTM, A>

Number of execution clocks: 8

(5 clocks when data is written to a register that does not issue a wait (MOV sfr, A).)

<On execution of MOV WDTM, #byte>

Number of execution clocks: 10

(7 clocks when data is written to a register that does not issue a wait (MOV sfr, #byte).)

#### <2> Serial interface UART6

<On execution of MOV A, ASIS6>

Number of execution clocks: 6

(5 clocks when data is read from a register that does not issue a wait (MOV A, sfr).)

<3> A/D converter

#### Table 32-2. Number of Wait Clocks and Number of Execution Clocks on Occurrence of Wait (A/D Converter)

<On execution of MOV ADM, A; MOV ADS, A; or MOV A, ADCR>

• When fx = 10 MHz,  $t_{CPUL} = 50$  ns

| Value of Bit 5 (FR2)<br>of ADM Register | fcpu              | Number of Wait Clocks               | Number of Execution Clocks           |
|-----------------------------------------|-------------------|-------------------------------------|--------------------------------------|
| 0                                       | fx                | 9 clocks                            | 14 clocks                            |
|                                         | fx/2              | 5 clocks                            | 10 clocks                            |
|                                         | fx/2 <sup>2</sup> | 3 clocks                            | 8 clocks                             |
|                                         | fx/2 <sup>3</sup> | 2 clocks                            | 7 clocks                             |
|                                         | fx/2 <sup>4</sup> | 0 clocks (1 clock <sup>Note</sup> ) | 5 clocks (6 clocks <sup>Note</sup> ) |
| 1                                       | fx                | 5 clocks                            | 10 clocks                            |
|                                         | fx/2              | 3 clocks                            | 8 clocks                             |
|                                         | fx/2 <sup>2</sup> | 2 clocks                            | 7 clocks                             |
|                                         | fx/2 <sup>3</sup> | 0 clocks (1 clock <sup>Note</sup> ) | 5 clocks (6 clocks <sup>Note</sup> ) |
|                                         | fx/24             | 0 clocks (1 clock <sup>Note</sup> ) | 5 clocks (6 clocks <sup>Note</sup> ) |

Note On execution of MOV A, ADCR

**Remark** The clock is the CPU clock (fcPu).

fx: X1 input clock frequency

tCPUL: Low-level width of CPU clock

#### APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for the development of systems that employ the 78K0/KF1 Series. Figure A-1 shows the development tool configuration.

#### • Support for PC98-NX series

Unless otherwise specified, products supported by IBM PC/AT<sup>™</sup> compatibles are compatible with PC98-NX series computers. When using PC98-NX series computers, refer to the explanation for IBM PC/AT compatibles.

#### • Windows

Unless otherwise specified, "Windows" means the following OSs.

- Windows 3.1
- Windows 95, 98, 2000
- Windows NT<sup>™</sup> Ver 4.0

Figure A-1. Development Tool Configuration



Remark The item in the broken-line box differs according to the development environment. See A.4.1 Hardware.

#### A.1 Software Package

| SP78K0                        | Development tools (software) common to the 78K/0 Series are combined in this package. |
|-------------------------------|---------------------------------------------------------------------------------------|
| 78K/0 Series software package | Part number: µSxxxxSP78K0                                                             |

**Remark** ×××× in the part number differs depending on the host machine and OS used.

#### μS<u>××××</u>SP78K0

| ×××× | Host Machine          | OS                         | Supply Medium |
|------|-----------------------|----------------------------|---------------|
| AB17 | PC-9800 series,       | Windows (Japanese version) | CD-ROM        |
| BB17 | IBM PC/AT compatibles | Windows (English version)  |               |

#### A.2 Language Processing Software

| RA78K0<br>Assembler package                         | This assembler converts programs written in mnemonics into object codes executable<br>with a microcontroller.<br>This assembler is also provided with functions capable of automatically creating symbol<br>tables and branch instruction optimization.<br>This assembler should be used in combination with a device file (DF780148) (sold<br>separately).<br>< <b>Precaution when using RA78K0 in PC environment&gt;</b><br>This assembler package is a DOS-based application. It can also be used in Windows,<br>however, by using the Project Manager (included in assembler package) on Windows. |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     | Part number: µSxxxxRA78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| CC78K0<br>C compiler package                        | This compiler converts programs written in C language into object codes executable with a microcontroller.<br>This compiler should be used in combination with an assembler package and device file (both sold separately).<br><precaution cc78k0="" environment="" in="" pc="" using="" when=""><br/>This C compiler package is a DOS-based application. It can also be used in Windows, however, by using the Project Manager (included in assembler package) on Windows.</precaution>                                                                                                              |
|                                                     | Part number: µSxxxxCC78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DF780148 <sup>Notes 1, 2</sup><br>Device file       | This file contains information peculiar to the device.<br>This device file should be used in combination with a tool (RA78K0, CC78K0, SM78K0,<br>ID78K0-NS, and ID78K0) (all sold separately).<br>The corresponding OS and host machine differ depending on the tool to be used.                                                                                                                                                                                                                                                                                                                      |
|                                                     | Part number: µSxxxxDF780148                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| CC78K0-L <sup>Note 3</sup><br>C library source file | This is a source file of the functions that configure the object library included in the C compiler package.<br>This file is required to match the object library included in the C compiler package to the user's specifications.<br>Since this is a source file, its working environment does not depend on any particular operating system.                                                                                                                                                                                                                                                        |
|                                                     | Part number: µSxxxxCC78K0-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Notes 1. The DF780148 can be used in common with the RA78K0, CC78K0, SM78K0, ID78K0-NS, and ID78K0.

- 2. Under development
- **3.** The CC78K0-L is not included in the software package (SP78K0).

### μS××××RA78K0 μS<u>××××</u>CC78K0

| ×××× | Host Machine                   | OS                                                                   | Supply Medium   |
|------|--------------------------------|----------------------------------------------------------------------|-----------------|
| AB13 | PC-9800 series,                | Windows (Japanese version)                                           | 3.5-inch 2HD FD |
| BB13 | IBM PC/AT compatibles          | Windows (English version)                                            |                 |
| AB17 |                                | Windows (Japanese version)                                           | CD-ROM          |
| BB17 |                                | Windows (English version)                                            |                 |
| 3P17 | HP9000 series 700 <sup>™</sup> | HP-UX <sup>™</sup> (Rel. 10.10)                                      |                 |
| 3K17 | SPARCstation™                  | SunOS <sup>™</sup> (Rel. 4.1.4)<br>Solaris <sup>™</sup> (Rel. 2.5.1) |                 |

#### $\mu$ S××××DF780148

μS<u>××××</u>CC78K0-L

| <br>XXXX | Host Machine          | OS                         | Supply Medium   |
|----------|-----------------------|----------------------------|-----------------|
| AB13     | PC-9800 series,       | Windows (Japanese version) | 3.5-inch 2HD FD |
| BB13     | IBM PC/AT compatibles | Windows (English version)  |                 |
| 3P16     | HP9000 series 700     | HP-UX (Rel. 10.10)         | DAT             |
| 3K13     | SPARCstation          | SunOS (Rel. 4.1.4)         | 3.5-inch 2HD FD |
| 3K15     |                       | Solaris (Rel. 2.5.1)       | 1/4-inch CGMT   |

#### A.3 Flash Memory Writing Tools

| Flashpro III                  | Flash programmer dedicated to microcontrollers with on-chip flash memory. |  |
|-------------------------------|---------------------------------------------------------------------------|--|
| (part number: FL-PR3, PG-FP3) |                                                                           |  |
| Flash programmer              |                                                                           |  |
| FA-80GK-9EU                   | Flash memory writing adapter used connected to the Flashpro III.          |  |
| FA-80GC-8BT                   | FA-80GK-9EU: For 80-pin plastic TQFP (GK-9EU type)                        |  |
| Flash memory writing adapter  | • FA-80GC-8BT: For 80-pin plastic QFP (GC-8BT type)                       |  |
| Flashpro III controller       | Program to control Flashpro III from a PC. Provided with Flashpro III.    |  |

**Remark** FL-PR3, FA-80GK-9EU, and FA-80GC-8BT are products of Naito Densei Machida Mfg. Co., Ltd. TEL: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.

#### A.4 Debugging Tools

#### A.4.1 Hardware

| IE-78K0-NS<br>In-circuit emulator     |                                   | The in-circuit emulator serves to debug hardware and software when developing application systems using a 78K/0 Series product. It corresponds to the integrated debugger (ID78K0-NS). This emulator should be used in combination with a power supply unit, emulation probe, and the interface adapter required to connect this emulator to the host machine. |  |
|---------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| IE-78K0-NS-PA<br>Performance boa      | rd                                | This board is connected to the IE-78K0-NS to expand its functions. Adding this board adds a coverage function and enhances debugging functions such as tracer and timer functions.                                                                                                                                                                             |  |
| IE-78K0-NS-A<br>In-circuit emulato    | r                                 | Product that combines the IE-78K0-NS and IE-78K0-NS-PA                                                                                                                                                                                                                                                                                                         |  |
| IE-70000-MC-PS<br>Power supply uni    |                                   | This adapter is used for supplying power from a 100 V to 240 V AC outlet.                                                                                                                                                                                                                                                                                      |  |
| IE-70000-98-IF-C<br>Interface adapter |                                   | This adapter is required when using a PC-9800 series computer (except notebook type) as the IE-78K0-NS(-A) host machine (C bus compatible).                                                                                                                                                                                                                    |  |
| IE-70000-CD-IF-/<br>PC card interface |                                   | This is PC card and interface cable required when using a notebook-type computer as the IE-78K0-NS(-A) host machine (PCMCIA socket compatible).                                                                                                                                                                                                                |  |
| IE-70000-PC-IF-0<br>Interface adapter |                                   | This adapter is required when using an IBM PC/AT compatible computer as the IE-78K0-NS(-A) host machine (ISA bus compatible).                                                                                                                                                                                                                                  |  |
| IE-70000-PCI-IF-<br>Interface adapter |                                   | This adapter is required when using a computer with a PCI bus as the IE-78K0-NS(-A) host machine.                                                                                                                                                                                                                                                              |  |
| IE-780148-NS-EN<br>Emulation board    | M1 <sup>Note</sup>                | This board emulates the operations of the peripheral hardware peculiar to a device. It should be used in combination with an in-circuit emulator.                                                                                                                                                                                                              |  |
| NP-80GK<br>Emulation probe            |                                   | This probe is used to connect the in-circuit emulator to a target system and is designed for use with 80-pin plastic TQFP (GK-9EU type).                                                                                                                                                                                                                       |  |
|                                       | TGK-080SDW<br>Conversion adapter  | This conversion socket connects the NP-80GK to a target system board designed for an 80-pin plastic TQFP (GK-9EU type).                                                                                                                                                                                                                                        |  |
| NP-80GC<br>Emulation probe            |                                   | This emulation probe is used to connect the in-circuit emulator and target system, and is designed for an 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                                    |  |
|                                       | EV-9200GC-80<br>Conversion socket | This conversion socket is used to connect the NP-80GC and target system board to which 80-pin plastic QFP (GC-8BT type) can be connected.                                                                                                                                                                                                                      |  |
| NP-80GC-TQ<br>NP-H80GC-TQ             |                                   | This emulation probe is used to connect the in-circuit emulator and target system, and is designed for an 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                                    |  |
| Emulation probe                       | TGC-080SBP<br>Conversion adapter  | This conversion adapter is used to connect the NP-80GC-TQ or NP-H80GC-TQ and a target system board to which an 80-pin plastic QFP (GC-8BT type) can be connected.                                                                                                                                                                                              |  |

Note Under development

- Remarks 1. NP-80GK, NP-80GC, NP-80GC-TQ, and NP-H80GC-TQ are products of Naito Densei Machida Mfg. Co., Ltd.
  - TEL: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.
  - TGK-080SDW and TGC-080SBP are products of TOKYO ELETECH CORPORATION. For further information, contact: Daimaru Kogyo, Ltd. Tokyo Electronics Department (TEL +81-3-3820-7112) Osaka Electronics Department (TEL +81-6-6244-6672)
  - 3. EV-9200GC-80 is sold in five-device units.
  - 4. TGK-080SDW and TGC-080SBP are sold in individual units.

#### A.4.2 Software

| SM78K0<br>System simulator                                                             | This system simulator is used to perform debugging at C source level or assembler level while simulating the operation of the target system on a host machine.<br>This simulator runs on Windows.<br>Use of the SM78K0 allows the execution of application logical testing and performance testing on an independent basis from hardware development without having to use an incircuit emulator, thereby providing higher development efficiency and software quality.<br>The SM78K0 should be used in combination with a device file (DF780148) (sold separately).                                                                                                                                                                                                                 |  |
|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                        | Part number: µSxxxxSM78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| ID78K0-NS<br>Integrated debugger<br>(supporting in-circuit emulator<br>IE-78K0-NS(-A)) | This debugger is a control program used to debug 78K/0 Series microcontrollers.<br>It adopts a graphical user interface, which is equivalent visually and operationally to<br>Windows or OSF/Motif <sup>™</sup> . It also has an enhanced debugging function for C language<br>programs, and thus trace results can be displayed on screen at C-language level by<br>using the windows integration function which links a trace result with its source program,<br>disassembled display, and memory display. In addition, by incorporating function<br>modules such as a task debugger and system performance analyzer, the efficiency of<br>debugging programs that run on real-time OSs can be improved.<br>It should be used in combination with a device file (sold separately). |  |
|                                                                                        | Part number: µS××××ID78K0-NS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |

**Remark** ×××× in the part number differs depending on the host machine and OS used.

#### $\mu$ S××××SM78K0

μS<u>××××</u>ID78K0-NS

| <br>×××× | Host Machine          | OS                         | Supply Medium   |
|----------|-----------------------|----------------------------|-----------------|
| AB13     | PC-9800 series,       | Windows (Japanese version) | 3.5-inch 2HD FD |
| BB13     | IBM PC/AT compatibles | Windows (English version)  |                 |
| AB17     |                       | Windows (Japanese version) | CD-ROM          |
| BB17     |                       | Windows (English version)  |                 |

#### APPENDIX B EMBEDDED SOFTWARE

The following embedded products are available for efficient development and maintenance of the 78K0/KF1 Series.

#### **Real-Time OS**

| RX78K/0      | The RX78K/0 is a real-time OS conforming to the $\mu$ ITRON specifications.              |
|--------------|------------------------------------------------------------------------------------------|
| Real-time OS | A tool (configurator) for generating the nucleus of the RX78K/0 and multiple information |
|              | tables is supplied.                                                                      |
|              | Used in combination with an assembler package (RA78K/0) and device file (DF780148)       |
|              | (both sold separately).                                                                  |
|              | <precaution 0="" environment="" in="" pc="" rx78k="" using="" when=""></precaution>      |
|              | The real-time OS is a DOS-based application. It should be used in the DOS prompt when    |
|              | using it in Windows.                                                                     |
|              | Part number: $\mu$ SXXXXRX78013- $\Delta\Delta\Delta\Delta$                              |

Caution To purchase the RX78K/0, first fill in the purchase application form and sign the user agreement.

**Remark** xxxx and  $\Delta\Delta\Delta\Delta$  in the part number differ depending on the host machine and OS used.

#### $\mu S \times RX78013 - \Delta \Delta \Delta \Delta$

| ΔΔΔΔ | Product Outline        | Maximum Number for Use in Mass Production |
|------|------------------------|-------------------------------------------|
| 001  | Evaluation object      | Do not use for mass-produced product.     |
| 100K | Mass-production object | 0.1 million units                         |
| 001M |                        | 1 million units                           |
| 010M |                        | 10 million units                          |
| S01  | Source program         | Object source program for mass production |

| XXXX | Host Machine          | OS                                         | Supply Medium   |
|------|-----------------------|--------------------------------------------|-----------------|
| AA13 | PC-9800 series        | Windows (Japanese version) <sup>Note</sup> | 3.5-inch 2HD FD |
| AB13 | IBM PC/AT compatibles | Windows (Japanese version) <sup>Note</sup> | 3.5-inch 2HD FD |
| BB13 |                       | Windows (English version) <sup>Note</sup>  |                 |
| 3P16 | HP9000 series 700     | HP-UX (Rel. 10.10)                         | DAT             |
| 3K13 | SPARCstation          | SunOS (Rel. 4.1.4),                        | 3.5-inch 2HD FD |
| 3K15 |                       | Solaris (Rel. 2.5.1)                       | 1/4-inch CGMT   |

Note Can also be operated in DOS environment.

#### APPENDIX C REGISTER INDEX

#### C.1 Register Index (In Alphabetical Order with Respect to Register Names)

#### [A]

A/D conversion result register (ADCR) ... 259 A/D converter mode register (ADM) ... 261 Analog input channel specification register (ADS) ... 263 Asynchronous serial interface control register 6 (ASICL6) ... 314, 321 Asynchronous serial interface operation mode register 0 (ASIM0) ... 282, 286, 287 Asynchronous serial interface operation mode register 6 (ASIM6) ... 308, 316, 317 Asynchronous serial interface reception error status register 0 (ASIS0) ... 284, 289 Asynchronous serial interface reception error status register 6 (ASIS6) ... 310, 319 Asynchronous serial interface transmission status register 6 (ASIF6) ... 311, 320 Automatic data transfer address count register 0 (ADTC0) ... 370 Automatic data transfer interval specification register 0 (ADTP0) ... 377, 392

#### [B]

Baud rate generator control register 0 (BRGC0) ... 285, 296 Baud rate generator control register 6 (BRGC6) ... 313, 338

#### [C]

Capture/compare control register 00 (CRC00) ... 166 Capture/compare control register 01 (CRC01) ... 166 Clock monitor mode register (CLM) ... 467 Clock selection register 6 (CKSR6) ... 312, 337 Clock output selection register (CKS) ... 253

#### [D]

Divisor selection register 0 (BRGCA0) ... 375, 382, 390

#### [E]

8-bit timer compare register 50 (CR50) ... 199
8-bit timer compare register 51 (CR51) ... 199
8-bit timer counter 50 (TM50) ... 199
8-bit timer counter 51 (TM51) ... 199
8-bit timer H carrier control register 1 (TMCYC1) ... 218
8-bit timer H compare register 00 (CMP00) ... 215
8-bit timer H compare register 01 (CMP01) ... 215
8-bit timer H compare register 10 (CMP10) ... 215
8-bit timer H compare register 11 (CMP11) ... 215
8-bit timer H mode register 0 (TMHMD0) ... 215
8-bit timer H mode register 1 (TMHMD1) ... 215
8-bit timer H mode register 50 (TMC50) ... 202
8-bit timer mode control register 51 (TMC51) ... 202

External interrupt falling edge enable register (EGN) ... 437 External interrupt rising edge enable register (EGP) ... 437

#### [I]

Input switch control register (ISC) ... 120 Internal expansion RAM size switching register (IXS) ... 492 Internal memory size switching register (IMS) ... 491 Interrupt mask flag register 0H (MK0H) ... 435 Interrupt mask flag register 0L (MK0L) ... 435 Interrupt mask flag register 1H (MK1H) ... 435 Interrupt mask flag register 1L (MK1L) ... 435 Interrupt request flag register 0H (IF0H) ... 434 Interrupt request flag register 0L (IF0L) ... 434 Interrupt request flag register 1H (IF1H) ... 434

# [K]

Key return mode register (KRM) ... 447

## [L]

Low-voltage detection level selection register (LVIS) ... 479 Low-voltage detection register (LVIM) ... 477

#### [M]

Main OSC control register (MOC) ... 139 Main clock mode register (MCM) ... 138 Memory expansion mode register (MEM) ... 125 Memory expansion wait setting register (MM) ... 126 Multiplier/divider control register 0 (DMUC0) ... 417 Multiplication/division data register A0 (MDA0H, MDA0L) ... 415 Multiplication/division data register B0 (MDB0) ... 416

# [0]

Oscillation stabilization time counter status register (OSTC) ... 139, 450 Oscillation stabilization time select register (OSTS) ... 140, 451

#### [P]

Port 0 (P0) ... 91 Port 1 (P1) ... 95 Port 12 (P12) ... 110 Port 13 (P13) ... 111 Port 14 (P14) ... 112 Port 2 (P2) ... 101 Port 3 (P3) ... 102 Port 4 (P4) ... 104 Port 5 (P5) ... 105 Port 6 (P6) ... 106 Port 7 (P7) ... 109 Port mode register 0 (PM0) ... 116, 173 Port mode register 1 (PM1) ... 116, 204 Port mode register 12 (PM12) ... 116 Port mode register 14 (PM14) ... 116, 255 Port mode register 3 (PM3) ... 116, 204 Port mode register 4 (PM4) ... 116 Port mode register 5 (PM5) ... 116 Port mode register 6 (PM6) ... 116 Port mode register 7 (PM7) ... 116 Power-fail comparison mode register (PFM) ... 264 Power-fail comparison threshold register (PFT) ... 264 Prescaler mode register 00 (PRM00) ... 170 Prescaler mode register 01 (PRM01) ... 170 Priority specification flag register 0H (PR0H) ... 436 Priority specification flag register 0L (PR0L) ... 436 Priority specification flag register 1H (PR1H) ... 436 Priority specification flag register 1L (PR1L) ... 436 Processor clock control register (PCC) ... 135 Pull-up resistor option register 0 (PU0) ... 119 Pull-up resistor option register 1 (PU1) ... 119 Pull-up resistor option register 12 (PU12) ... 119 Pull-up resistor option register 14 (PU14) ... 119 Pull-up resistor option register 3 (PU3) ... 119 Pull-up resistor option register 4 (PU4) ... 119 Pull-up resistor option register 5 (PU5) ... 119 Pull-up resistor option register 6 (PU6) ... 119 Pull-up resistor option register 7 (PU7) ... 119

#### [R]

Receive buffer register 0 (RXB0) ... 281 Receive buffer register 6 (RXB6) ... 307 Receive shift register 0 (RXS0) ... 281 Receive shift register 6 (RXS6) ... 307 Remainder data register 0 (SDR0) ... 415 Reset control flag register (RESF) ... 465 Ring-OSC mode register (RCM) ... 137

#### [S]

Serial I/O shift register 0 (SIOA0) ... 370 Serial I/O shift register 10 (SIO10) ... 347 Serial I/O shift register 11 (SIO11) ... 347 Serial clock selection register 10 (CSIC10) ... 350, 356 Serial clock selection register 11 (CSIC11) ... 350, 356 Serial operation mode register 10 (CSIM10) ... 347, 352, 353 Serial operation mode register 11 (CSIM11) ... 347, 352, 353 Serial operation mode specification register 0 (CSIMA0) ... 370, 378, 379, 387 Serial status register 0 (CSIS0) ... 372, 380, 388 Serial trigger register 0 (CSIT0) ... 374, 390 16-bit timer capture/compare register 000 (CR000) ... 161
16-bit timer capture/compare register 001 (CR001) ... 161
16-bit timer capture/compare register 010 (CR010) ... 162
16-bit timer capture/compare register 011 (CR011) ... 162
16-bit timer counter 00 (TM00) ... 161
16-bit timer mode control register 00 (TMC00) ... 163
16-bit timer mode control register 01 (TMC01) ... 163
16-bit timer output control register 00 (TOC00) ... 167
16-bit timer output control register 01 (TOC01) ... 167

## [T]

Timer clock selection register 50 (TCL50) ... 200 Timer clock selection register 51 (TCL51) ... 200 Transmit buffer register 10 (SOTB10) ... 346 Transmit buffer register 11 (SOTB11) ... 346 Transmit buffer register 6 (TXB6) ... 307 Transmit shift register 0 (TXS0) ... 281 Transmit shift register 6 (TXS6) ... 307

#### [W]

Watchdog timer enable register (WDTE) ... 246 Watchdog timer mode register (WDTM) ... 244 Watch timer operation mode register (WTM) ... 237

# C.2 Register Index (In Alphabetical Order with Respect to Register Symbol)

# [A]

| L1      |                                                                          |
|---------|--------------------------------------------------------------------------|
| ADCR:   | A/D conversion result register 259                                       |
| ADM:    | A/D converter mode register 261                                          |
| ADS:    | Analog input channel specification register 263                          |
| ADTC0:  | Automatic data transfer address count register 0 370                     |
| ADTI0:  | Automatic data transfer interval specification register 0 377, 392       |
| ADTP0:  | Automatic data transfer address point specification register 0 375, 391  |
| ASICL6: | Asynchronous serial interface control register 6 314, 321                |
| ASIF6:  | Asynchronous serial interface transmission status register 6 311, 320    |
| ASIM0:  | Asynchronous serial interface operation mode register 0 282, 286, 287    |
| ASIM6:  | Asynchronous serial interface operation mode register 6 308, 316, 317    |
| ASIS0:  | Asynchronous serial interface reception error status register 0 284, 289 |
| ASIS6:  | Asynchronous serial interface reception error status register 6 310, 319 |
|         |                                                                          |

#### [B]

| BRGCA0: | Divisor selection register 0 375, 382, 390      |  |  |
|---------|-------------------------------------------------|--|--|
| BRGC0:  | Baud rate generator control register 0 285, 296 |  |  |
| BRGC6:  | Baud rate generator control register 6 313, 338 |  |  |

# [C]

| CKS :   | Clock output selection register 253                               |
|---------|-------------------------------------------------------------------|
| CKSR6:  | Clock selection register 6 312, 337                               |
| CLM:    | Clock monitor mode register 467                                   |
| CMP00:  | 8-bit timer H compare register 00 215                             |
| CMP01:  | 8-bit timer H compare register 01 215                             |
| CMP10:  | 8-bit timer H compare register 10 215                             |
| CMP11:  | 8-bit timer H compare register 11 215                             |
| CR000:  | 16-bit timer capture/compare register 000 161                     |
| CR001:  | 16-bit timer capture/compare register 001 161                     |
| CR010:  | 16-bit timer capture/compare register 010 162                     |
| CR011:  | 16-bit timer capture/compare register 011 162                     |
| CR50:   | 8-bit timer compare register 50 199                               |
| CR51:   | 8-bit timer compare register 51 199                               |
| CRC00:  | Capture/compare control register 00 166                           |
| CRC01:  | Capture/compare control register 01 166                           |
| CSIC10: | Serial clock selection register 10 350, 356                       |
| CSIC11: | Serial clock selection register 11 350, 356                       |
| CSIM10: | Serial operation mode register 10 347, 352, 353                   |
| CSIM11: | Serial operation mode register 11 347, 352, 353                   |
| CSIMA0: | Serial operation mode specification register 0 370, 378, 379, 387 |
| CSIS0:  | Serial status register 0 372, 380, 388                            |
| CSIT0:  | Serial trigger register 0 374, 390                                |

#### [D]

DMUC0: Multiplier/divider control register 0 ... 417

| <b>[E]</b><br>EGN:<br>EGP:                                                                          | External interrupt falling edge enable register 437<br>External interrupt rising edge enable register 437                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [I]<br>IF0H:<br>IF0L:<br>IF1H:<br>IF1L:<br>IMS:<br>ISC:<br>IXS:                                     | Interrupt request flag register 0H 434<br>Interrupt request flag register 0L 434<br>Interrupt request flag register 1H 434<br>Interrupt request flag register 1L 434<br>Internal memory size switching register 491<br>Input switch control register 120<br>Internal expansion RAM size switching register 492                                                                                                                                                |
| <b>[K]</b><br>KRM:                                                                                  | Key return mode register 447                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>[L]</b><br>LVIM:<br>LVIS:                                                                        | Low-voltage detection register 477<br>Low-voltage detection level selection register 479                                                                                                                                                                                                                                                                                                                                                                      |
| [M]<br>MCM:<br>MDA0H:<br>MDA0L:<br>MDB0:<br>MEM:<br>MK0H:<br>MK0H:<br>MK1L:<br>MK1L:<br>MM:<br>MOC: | Main clock mode register 138<br>Multiplication/division data register A0 415<br>Multiplication/division data register A0 415<br>Multiplication/division data register B0 416<br>Memory expansion mode register 125<br>Interrupt mask flag register 0H 435<br>Interrupt mask flag register 0L 435<br>Interrupt mask flag register 1H 435<br>Interrupt mask flag register 1L 435<br>Memory expansion wait setting register 126<br>Main OSC control register 139 |
| <b>[O]</b><br>OSTC:<br>OSTS:                                                                        | Oscillation stabilization time counter status register 139,<br>Oscillation stabilization time select register 140, 451                                                                                                                                                                                                                                                                                                                                        |
| [ <b>P</b> ]<br>P0:<br>P1:<br>P12:<br>P13:<br>P14:<br>P2:<br>P3:<br>P4:<br>P5:<br>P6:               | Port 0 91<br>Port 1 95<br>Port 12 110<br>Port 13 111<br>Port 14 112<br>Port 2 101<br>Port 3 102<br>Port 4 104<br>Port 5 105<br>Port 6 106                                                                                                                                                                                                                                                                                                                     |

450

| P7:          | Port 7 109                                   |
|--------------|----------------------------------------------|
| PCC:         | Processor clock control register 135         |
| PFM:         | Power-fail comparison mode register 264      |
| PFT:         | Power-fail comparison threshold register 264 |
| PM0:         | Port mode register 0 116, 173                |
| PM1:         | Port mode register 1 116, 204                |
| PM12:        | Port mode register 12 116                    |
| PM14:        | Port mode register 14 116, 255               |
| PM3:         | Port mode register 3 116, 204                |
| PM4:         | Port mode register 4 116                     |
| PM5:         | Port mode register 5 116                     |
| PM6:         | Port mode register 6 116                     |
| PM7:         | Port mode register 7 116                     |
| PR0H:        | Priority specification flag register 0H 436  |
| PR1H :       | Priority specification flag register 1H 436  |
| PR0L:        | Priority specification flag register 0L 436  |
| PR1L:        | Priority specification flag register 1L 436  |
| PRM00:       | Prescaler mode register 00 170               |
| PRM01:       | Prescaler mode register 01 170               |
| PU0:         | Pull-up resistor option register 0 … 119     |
| PU1:         | Pull-up resistor option register 1 119       |
| PU12:        | Pull-up resistor option register 12 119      |
| PU14:        | Pull-up resistor option register 14 119      |
| PU3:         | Pull-up resistor option register 3 119       |
| PU4:         | Pull-up resistor option register 4 119       |
| PU5:         | Pull-up resistor option register 5 119       |
| PU6:         | Pull-up resistor option register 6 119       |
| PU7:         | Pull-up resistor option register 7 119       |
|              |                                              |
| [R]          |                                              |
| RCM:         | Ring-OSC mode register 137                   |
| RESF:        | Reset control flag register 465              |
| RXB0:        | Receive buffer register 0 281                |
| RXB6:        | Receive buffer register 6 307                |
| RXS0:        | Receive shift register 0 281                 |
| RXS6:        | -                                            |
| HA30.        | Receive shift register 6 307                 |
| [6]          |                                              |
| [ <b>S</b> ] | Demois des dets se sistes 0 445              |
| SDR0:        | Remainder data register 0 415                |
| SIO10:       | Serial I/O shift register 10 347             |
| SIO11:       | Serial I/O shift register 11 347             |
| SIOA0:       | Serial I/O shift register 0 370              |
| SOTB10:      | Transmit buffer register 10 346              |
| SOTB11:      | Transmit buffer register 11 346              |
| · <b>-</b> 1 |                                              |
| [T]          |                                              |
| TCL50:       | Timer clock selection register 50 200        |

| TM00:   | 16-bit timer counter 00 161                  |
|---------|----------------------------------------------|
| TM01:   | 16-bit timer counter 01 161                  |
| TM50:   | 8-bit timer counter 50 199                   |
| TM51:   | 8-bit timer counter 51 199                   |
| TMC00:  | 16-bit timer mode control register 00 163    |
| TMC01:  | 16-bit timer mode control register 01 163    |
| TMC50:  | 8-bit timer mode control register 50 202     |
| TMC51:  | 8-bit timer mode control register 51 202     |
| TMCYC1: | 8-bit timer H carrier control register 1 218 |
| TMHMD0: | 8-bit timer H mode register 0 215            |
| TMHMD1: | 8-bit timer H mode register 1 215            |
| TOC00:  | 16-bit timer output control register 00 167  |
| TOC01:  | 16-bit timer output control register 01 167  |
| TXB6:   | Transmit buffer register 6 307               |
| TXS0:   | Transmit shift register 0 281                |
| TXS6:   | Transmit shift register 6 307                |
|         |                                              |

# [W]

| WDTE: | Watchdog timer enable register 246      |
|-------|-----------------------------------------|
| WDTM: | Watchdog timer mode register 244        |
| WTM : | Watch timer operation mode register 237 |

# FC

# **Facsimile** Message

FAX

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

Address

Tel.

From:

Name

Company

# Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: +1-800-729-9288<br>+1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: +886-2-2719-5951                        |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Market Communication Dept.<br>Fax: +49-211-6503-274                     | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: +82-2-528-4411         | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
| South America<br>NEC do Brasil S.A.<br>Fax: +55-11-6462-6829                                                       | <b>P.R. China</b><br>NEC Electronics Shanghai, Ltd.<br>Fax: +86-21-6841-1137                  | <b>Japan</b><br>NEC Semiconductor Technical Hotline<br>Fax: +81- 44-435-9608                 |

I would like to report the following error/make the following suggestion:

Document title: \_\_\_\_

Document number: \_\_\_\_\_ Page number: \_\_\_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |