# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: http://www.renesas.com

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "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.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



**User's Manual** 

# $\mu$ PD789862 Subseries

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

μ**PD789862** μ**PD78E9862** 

Document No. U15852EJ4V0UD00 (4th edition) Date Published December 2003 N CP(K)

© NEC Electronics 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.

#### (2) 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.

FIP and EEPROM are trademarks of NEC Electronics Corporation.

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.

These commodities, technology or software, must be exported in accordance with the export administration regulations of the exporting country. Diversion contrary to the law of that country is prohibited.

- The information in this document is current as of May, 2003. The information is subject to change without notice. For actual design-in, refer to the latest publications of NEC Electronics data sheets or data books, etc., for the most up-to-date specifications of NEC Electronics products. Not all products and/or types are available in every country. Please check with an NEC Electronics sales 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 Electronics. NEC Electronics assumes no responsibility for any errors that may appear in this document.
- NEC Electronics does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from the use of NEC Electronics products listed in this document or any other liability arising from the use of such products. No license, express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Electronics 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 a customer's equipment shall be done under the full responsibility of the customer. NEC Electronics assumes no responsibility for any losses incurred by customers or third parties arising from the use of these circuits, software and information.
- While NEC Electronics endeavors to enhance the quality, reliability and safety of NEC Electronics products, customers agree and acknowledge that the possibility of defects thereof cannot be eliminated entirely. To minimize risks of damage to property or injury (including death) to persons arising from defects in NEC Electronics products, customers must incorporate sufficient safety measures in their design, such as redundancy, fire-containment and anti-failure features.
- NEC Electronics products are classified into the following three quality grades: "Standard", "Special" and "Specific".

The "Specific" quality grade applies only to NEC Electronics products developed based on a customerdesignated "quality assurance program" for a specific application. The recommended applications of an NEC Electronics product depend on its quality grade, as indicated below. Customers must check the quality grade of each NEC Electronics product 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 and medical equipment for life support, etc.

The quality grade of NEC Electronics products is "Standard" unless otherwise expressly specified in NEC Electronics data sheets or data books, etc. If customers wish to use NEC Electronics products in applications not intended by NEC Electronics, they must contact an NEC Electronics sales representative in advance to determine NEC Electronics' willingness to support a given application.

(Note)

- (1) "NEC Electronics" as used in this statement means NEC Electronics Corporation and also includes its majority-owned subsidiaries.
- (2) "NEC Electronics products" means any product developed or manufactured by or for NEC Electronics (as defined above).

# **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC Electronics product in your application, please contact the NEC Electronics 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.

#### [GLOBAL SUPPORT] http://www.necel.com/en/support/support.html

NEC Electronics America, Inc. (U.S.) NEC Electronics (Europe) GmbH NEC Electronics Hong Kong Ltd. Duesseldorf, Germany Santa Clara, California Hong Kong Tel: 408-588-6000 Tel: 0211-65 03 01 Tel: 2886-9318 800-366-9782 Sucursal en España NEC Electronics Hong Kong Ltd. Madrid, Spain

- Tel: 091-504 27 87 • Succursale Française Vélizy-Villacoublay, France Tel: 01-30-67 58 00
- Filiale Italiana Milano, Italy Tel: 02-66 75 41
- Branch The Netherlands Eindhoven, The Netherlands Tel: 040-244 58 45
- Tyskland Filial Taeby, Sweden Tel: 08-63 80 820
- United Kingdom Branch Milton Kevnes, UK Tel: 01908-691-133

Seoul Branch Seoul, Korea

Tel: 02-558-3737 NEC Electronics Shanghai, Ltd.

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

**NEC Electronics Taiwan Ltd.** Taipei, Taiwan Tel: 02-2719-2377

**NEC Electronics Singapore Pte. Ltd.** Novena Square, Singapore Tel: 6253-8311

# **Major Revisions in This Edition**

| Page   | Description                                                                                       |
|--------|---------------------------------------------------------------------------------------------------|
|        | CHAPTER 1 GENERAL                                                                                 |
| p. 24  | Modification of Note in 1.3 Ordering Information                                                  |
| p. 26  | Revision of 1.5 78K/0S Series Lineup                                                              |
|        | CHAPTER 4 EEPROM (DATA MEMORY)                                                                    |
| p. 62  | Modification of Table 4-1 EEPROM Write Time                                                       |
| р. 65  | Modification of program example of (3) in 4.5 Notes for EEPROM Writing                            |
|        | CHAPTER 7 16-BIT TIMER/EVENT COUNTER 0                                                            |
| р. 114 | Addition of 7.5 (2) Prohibition of compare register change during timer count operation           |
|        | CHAPTER 11 SERIAL INTERFACE 2                                                                     |
| р. 155 | Addition of 11.3 (4) (c) Generation of serial clock from system clock in 3-wire serial I/O mode   |
|        | CHAPTER 12 POWER-ON-CLEAR CIRCUITS                                                                |
| p. 181 | Modification of description and addition of Note in 12.4.1 Power-on-clear (POC) circuit operation |
| p. 184 | Addition of Caution to 12.4.2 Operation of low-voltage detector (LVI)                             |
| р. 185 | Modification of Figure 12-9 LVI Circuit Operation Timing                                          |
|        | CHAPTER 13 BIT SEQUENTIAL BUFFER                                                                  |
| p. 187 | Addition of 13.3 (2) Port mode register 2 (PM2)                                                   |
|        | CHAPTER 18 µPD78E9862                                                                             |
| p. 221 | • Modification of Note 1 in Table 18-1 Differences Between µPD78E9862 and Mask ROM Version        |
| p. 223 | Modification of Table 18-2 Communication Mode List                                                |
|        | CHAPTER 22 ELECTRICAL SPECIFICATIONS (µPD78E9862)                                                 |
| p. 255 | Addition of Caution                                                                               |
| p. 265 | Modification of Note 2 in AC Characteristics (3) EEPROM                                           |
|        | CHAPTER 24 RECOMMENDED SOLDERING CONDITIONS                                                       |
| p. 268 | Change of Table 24-1 Surface Mounting Type Soldering Conditions                                   |

The mark  $\star$  shows major revised points.

#### INTRODUCTION

| Target Readers         | This manual is intended for user engineers who wish to understand the functions of the $\mu$ PD789862 Subseries in order to design and develop its application systems and programs.              |                                                                                                                                                                                                               |                                                                                                                                                                                                                                              |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Purpose                | This manual is intended the <b>Organization</b> below.                                                                                                                                            | to give users an u                                                                                                                                                                                            | nderstanding of the functions described in                                                                                                                                                                                                   |
| Organization           | Two manuals are available for the $\mu$ PD789862 Subseries: this manual and the Instruction Manual (common to the 78K/0S Series).                                                                 |                                                                                                                                                                                                               |                                                                                                                                                                                                                                              |
|                        | μ/PD789862<br>Subseries<br>User's Manual                                                                                                                                                          |                                                                                                                                                                                                               | 78K/0S Series<br>Instructions<br>User's Manual                                                                                                                                                                                               |
|                        | <ul> <li>Pin functions</li> <li>Internal block function</li> <li>Interrupts</li> <li>Other internal periphe</li> <li>Electrical specification</li> </ul>                                          | eral functions                                                                                                                                                                                                | <ul><li>CPU function</li><li>Instruction set</li><li>Instruction description</li></ul>                                                                                                                                                       |
| How to Use This Manual | It is assumed that the re<br>engineering, logic circuits                                                                                                                                          |                                                                                                                                                                                                               | nual have general knowledge of electrical<br>lers.                                                                                                                                                                                           |
|                        | assembler and is de<br>$\diamond$ To learn the detailed fu<br>$\rightarrow$ See <b>APPENDIX B</b><br>$\diamond$ To learn the details of t<br>$\rightarrow$ Refer to <b>78K/0S S</b><br>available. | n the order of the <b>C</b><br>rmats<br>it whose number<br>efined in the C con<br>unctions of a register<br><b>REGISTER INDE</b><br>the instruction func<br><b>Series Instruction</b><br>al specifications of | contents.<br>is enclosed with <> is reserved in the<br>npiler by the header file sfrbit.h.<br>er whose register name is known<br>X.<br>tions of the 78K/0S Series<br><b>ns User's Manual (U11047E)</b> separately<br>the μPD789862 Subseries |
| Conventions            | Data significance:<br>Active low representation<br><b>Note</b> :<br><b>Caution</b> :<br><b>Remark</b> :<br>Numerical representation                                                               | : xxx (overscore of<br>Footnote for item<br>Information requi<br>Supplementary in                                                                                                                             | n marked with <b>Note</b> in the text<br>iring particular attention<br>nformation<br>r ××××B                                                                                                                                                 |

Hexadecimal ... xxxxH

#### **Related Documents**

The 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. |
|------------------------------------------|--------------|
| $\mu$ PD789862 Subseries User's Manual   | This manual  |
| 78K/0S Series Instructions User's Manual | U11047E      |

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

| Document Name                                       |                                        | Document No. |
|-----------------------------------------------------|----------------------------------------|--------------|
| RA78K0S Assembler Package                           | Operation                              | U14876E      |
|                                                     | Language                               | U14877E      |
|                                                     | Structured Assembly Language           | U11623E      |
| CC78K0S C Compiler                                  | Operation                              | U14871E      |
|                                                     | Language                               | U14872E      |
| ID78K Series Integrated Debugger Ver. 2.30 or Later | Operation (Windows <sup>™</sup> Based) | U15185E      |
| Project Manager Ver. 3.12 or Later (Windows Based)  |                                        | U14610E      |

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

| Document Name                     | Document No. |
|-----------------------------------|--------------|
| IE-78K0S-NS In-Circuit Emulator   | U13549E      |
| IE-78K0S-NS-A In-Circuit Emulator | U15207E      |
| IE-789862-NS-EM1 Emulation Board  | U16297E      |

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

#### **Documents Related to Flash Memory Writing**

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

#### **Other Related Documents**

| Document Name                                                                      | Document No. |
|------------------------------------------------------------------------------------|--------------|
| SEMICONDUCTOR SELECTION GUIDE - Products and Packages -                            | X13769X      |
| Semiconductor Device Mount Manual                                                  | Note         |
| 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      |

Note See the "Semiconductor Device Mount Manual" website (http://www.necel.com/pkg/en/mount/index.html)

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

### CONTENTS

| CHAPTI | ER 1 (  | GENERAL                                              | 23 |
|--------|---------|------------------------------------------------------|----|
| 1.1    | Featu   | res                                                  | 23 |
| 1.2    |         | cations                                              |    |
| 1.3    | Order   | ing Information                                      | 24 |
| 1.4    | Pin Co  | onfiguration (Top View)                              | 25 |
| 1.5    | 78K/0   | S Series Lineup                                      | 26 |
| 1.6    |         | Diagram                                              |    |
| 1.7    | Overv   | iew of Functions                                     | 30 |
| СНАРТІ | ER 2 F  | PIN FUNCTIONS                                        | 31 |
| 2.1    | Pin Fu  | Inction List                                         | 31 |
| 2.2    | Descr   | iption of Pin Functions                              | 33 |
|        | 2.2.1   | P00 to P03 (Port 0)                                  |    |
|        | 2.2.2   | P10, P11 (Port 1)                                    |    |
|        | 2.2.3   | P20 to P24 (Port 2)                                  |    |
|        | 2.2.4   | P30 to P33 (Port 3)                                  |    |
|        | 2.2.5   | P40 to P45 (Port 4)                                  |    |
|        | 2.2.6   | P70 (Port 7)                                         |    |
|        | 2.2.7   | EEWE                                                 |    |
|        | 2.2.8   | KRREN                                                | 35 |
|        | 2.2.9   | RESET                                                | 35 |
|        | 2.2.10  | X1, X2                                               | 35 |
|        | 2.2.11  | Vdd                                                  | 35 |
|        | 2.2.12  | Vss                                                  | 35 |
|        | 2.2.13  | Vpp (µPD78E9862 only)                                | 35 |
|        | 2.2.14  | IC (mask ROM version only)                           | 35 |
| 2.3    | Pin I/C | D Circuits and Recommended Connection of Unused Pins | 36 |
| CHAPTI | ER 3 (  | CPU ARCHITECTURE                                     |    |
| 3.1    | Memo    | ry Space                                             |    |
|        | 3.1.1   | Internal program memory space                        |    |
|        | 3.1.2   | Internal data memory space                           |    |
|        | 3.1.3   | Special function register (SFR) area                 | 41 |
|        | 3.1.4   | Data memory addressing                               | 41 |
| 3.2    | Proce   | ssor Registers                                       | 43 |
|        | 3.2.1   | Control registers                                    | 43 |
|        | 3.2.2   | General-purpose registers                            | 46 |
|        | 3.2.3   | Special function registers (SFRs)                    | 47 |
| 3.3    | Instru  | ction Address Addressing                             | 50 |
|        | 3.3.1   | Relative addressing                                  | 50 |

|       | 3.3.2 Imr                                       | mediate addressing                       | 51       |
|-------|-------------------------------------------------|------------------------------------------|----------|
|       | 3.3.3 Tal                                       | ble indirect addressing                  |          |
|       | 3.3.4 Re                                        | gister addressing                        |          |
| 3.4   | Operand /                                       | Address Addressing                       | 53       |
|       | 3.4.1 Dir                                       | rect addressing                          | 53       |
|       | 3.4.2 Sh                                        | ort direct addressing                    | 54       |
|       | 3.4.3 Spe                                       | ecial function register (SFR) addressing | 55       |
|       | 3.4.4 Re                                        | gister addressing                        |          |
|       | 3.4.5 Re                                        | gister indirect addressing               | 57       |
|       | 3.4.6 Bas                                       | sed addressing                           |          |
|       | 3.4.7 Sta                                       | ack addressing                           | 58       |
| СНАРТ | ER 4 EEP                                        | ROM (DATA MEMORY)                        | 59       |
| 4.1   | -                                               | Space                                    |          |
| 4.2   |                                                 | Configuration                            |          |
| 4.3   |                                                 | Control Register                         |          |
| 4.4   |                                                 | er 80                                    |          |
|       |                                                 | onfiguration of 8-bit timer 80           |          |
|       |                                                 | ontrol registers of 8-bit timer 80       |          |
| 4.5   | Notes for                                       | EEPROM Writing                           | 65       |
| СНАРТ | ER 5 POR                                        | RT FUNCTIONS                             | 68       |
| 5.1   |                                                 | s of Ports                               |          |
| 5.2   |                                                 | figuration                               |          |
|       |                                                 | vrt 0                                    |          |
|       |                                                 | vrt 1                                    |          |
|       |                                                 | rt 2                                     |          |
|       |                                                 | vrt 3                                    |          |
|       |                                                 | vrt 4                                    |          |
|       |                                                 | rt 7                                     |          |
| 5.3   |                                                 | ction Control Registers                  |          |
| 5.4   | •                                               | n of Port Functions                      |          |
|       |                                                 | riting to I/O port                       |          |
|       |                                                 | eading from I/O port                     |          |
|       | 5.4.3 Arit                                      | ithmetic operation of I/O port           |          |
| СНАРТ | ER 6 CLO                                        | OCK GENERATOR                            | 83       |
| 6.1   |                                                 | nerator Functions                        |          |
| 6.2   | Clock Ger                                       | nerator Configuration                    |          |
| 6.3   |                                                 |                                          |          |
|       | Clock Ger                                       | nerator Control Register                 | 84       |
| 6.4   | Clock Ger<br>System C                           | Clock Oscillator                         | 84<br>85 |
| 6.4   | Clock Ger<br>System C<br>6.4.1 Sys              | stem clock oscillator                    | 84<br>   |
| 6.4   | Clock Ger<br>System C<br>6.4.1 Sys<br>6.4.2 Exa | Clock Oscillator                         |          |

| 6.5        | Clock Generator Operation                                                                        |     |
|------------|--------------------------------------------------------------------------------------------------|-----|
| 6.6        | Changing Setting of CPU Clock                                                                    | 89  |
|            | 6.6.1 Time required for switching CPU clock                                                      |     |
|            | 6.6.2 Switching CPU clock                                                                        |     |
| СНАРТЕ     | ER 7 16-BIT TIMER/EVENT COUNTER 0                                                                | 90  |
| 7.1        | Functions of 16-Bit Timer/Event Counter 0                                                        |     |
| 7.2        | Configuration of 16-Bit Timer/Event Counter 0                                                    | 91  |
| 7.3        | Control Registers of 16-Bit Timer/Event Counter 0                                                | 94  |
| 7.4        | Operation of 16-Bit Timer/Event Counter 0                                                        | 100 |
|            | 7.4.1 Interval timer operation                                                                   |     |
|            | 7.4.2 PPG output operations                                                                      |     |
|            | 7.4.3 Pulse width measurement operations                                                         |     |
|            | 7.4.4 External event counter operation                                                           |     |
|            | 7.4.5 Square-wave output operation                                                               |     |
| 7.5        | Cautions on 16-Bit Timer/Event Counter 0                                                         | 114 |
| СНАРТЕ     | ER 8 16-BIT TIMER D                                                                              | 118 |
| 8.1        | Features                                                                                         | 110 |
| 8.2        | Function Overview                                                                                | -   |
| 8.3        | Basic Configuration of 16-Bit Timer D                                                            | -   |
| 8.4        | 16-Bit Timer D                                                                                   |     |
| 8.5        | 16-Bit Timer D Control Register                                                                  |     |
| 8.6        | 16-Bit Timer D Operation                                                                         |     |
| 8.7        | Application Examples                                                                             |     |
| 8.8        | Cautions                                                                                         |     |
| СНАРТЕ     | ER 9 8-BIT TIMER/EVENT COUNTER 5                                                                 |     |
|            | Functions of 8-Bit Timer/Event Counter 5                                                         |     |
| 9.1        |                                                                                                  | -   |
| 9.2<br>9.3 | Configuration of 8-Bit Timer/Event Counter 5<br>Control Registers of 8-Bit Timer/Event Counter 5 |     |
| 9.3<br>9.4 | Operations of 8-Bit Timer/Event Counter 5                                                        |     |
| 5.4        | 9.4.1 Interval timer (8-bit) operation                                                           |     |
|            | 9.4.1 Interval timer (8-bit) operation                                                           |     |
|            |                                                                                                  |     |
|            |                                                                                                  |     |
| 9.5        | 9.4.4 PWM output operation<br>Cautions on 8-Bit Timer/Event Counter 5                            |     |
|            |                                                                                                  | -   |
|            | ER 10 WATCHDOG TIMER                                                                             |     |
|            | Watchdog Timer Functions                                                                         |     |
|            | Watchdog Timer Configuration                                                                     |     |
|            | Watchdog Timer Control Registers                                                                 |     |
| 10.4       | Operation of Watchdog Timer                                                                      |     |
|            | 10.4.1 Operation as watchdog timer                                                               |     |
|            | 10.4.2 Operation as interval timer                                                               |     |

| CHAPTE | R 11 SERIAL INTERFACE 2                                         | 144 |
|--------|-----------------------------------------------------------------|-----|
| 11.1   | Functions of Serial Interface 2                                 | 144 |
| 11.2   | Configuration of Serial Interface 2                             | 145 |
| 11.3   | Control Registers of Serial Interface 2                         | 149 |
| 11.4   | Operation of Serial Interface 2                                 | 156 |
|        | 11.4.1 Operation stopped mode                                   |     |
|        | 11.4.2 Asynchronous serial interface (UART) mode                |     |
|        | 11.4.3 3-wire serial I/O mode                                   |     |
| СНАРТЕ | R 12 POWER-ON-CLEAR CIRCUITS                                    | 177 |
| 12.1   | Power-on-Clear Circuit Functions                                |     |
| 12.2   | Configuration of Power-on-Clear Circuit                         |     |
| 12.3   | Power-on-Clear Circuit Control Registers                        | 179 |
| 12.4   | Power-on-Clear Circuit Operation                                |     |
|        | 12.4.1 Power-on-clear (POC) circuit operation                   |     |
|        | 12.4.2 Operation of low-voltage detector (LVI)                  |     |
| СНАРТЕ | R 13 BIT SEQUENTIAL BUFFER                                      |     |
| 13.1   | Bit Sequential Buffer Functions                                 |     |
| 13.2   | Bit Sequential Buffer Configuration                             |     |
|        | Bit Sequential Buffer Control Registers                         |     |
|        | Bit Sequential Buffer Operation                                 |     |
| 13.5   | Notes                                                           |     |
| СНАРТЕ | R 14 KEY RETURN CIRCUIT                                         | 191 |
| 14.1   | Key Return Circuit Function                                     |     |
| 14.2   | Key Return Circuit Configuration and Operation                  | 192 |
| СНАРТЕ | R 15 INTERRUPT FUNCTIONS                                        | 194 |
| 15.1   | Interrupt Function Types                                        | 194 |
| 15.2   | Interrupt Sources and Configuration                             |     |
| 15.3   | Interrupt Function Control Registers                            | 197 |
| 15.4   | Interrupt Servicing Operation                                   | 202 |
|        | 15.4.1 Non-maskable interrupt request acknowledgement operation |     |
|        | 15.4.2 Maskable interrupt request acknowledgement operation     | 204 |
|        | 15.4.3 Multiple interrupt servicing                             |     |
|        | 15.4.4 Interrupt request pending                                |     |
| СНАРТЕ | R 16 STANDBY FUNCTION                                           |     |
| 16.1   | Standby Function and Configuration                              | 209 |
|        | 16.1.1 Standby function                                         |     |
|        | 16.1.2 Standby function control register                        | 210 |
| 16.2   | Standby Function Operation                                      | 211 |
|        | 16.2.1 HALT mode                                                | 211 |

| 1       | 16.2.2 STOP mode                                   | 214 |
|---------|----------------------------------------------------|-----|
| CHAPTER | R 17 RESET FUNCTION                                | 217 |
| CHAPTER | R 18 μPD78E9862                                    | 221 |
| 18.1 F  | Features of EEPROM (Program Memory)                |     |
| 1       | 18.1.1 Programming environment                     |     |
| 1       | 18.1.2 Communication mode                          |     |
| 1       | 18.1.3 On-board pin processing                     | 226 |
| 1       | 18.1.4 Connection on EEPROM writing adapter        |     |
| CHAPTER | R 19 MASK OPTIONS                                  | 232 |
| CHAPTER | R 20 INSTRUCTION SET OVERVIEW                      | 233 |
| 20.1    | Operation                                          | 233 |
| 2       | 20.1.1 Operand identifiers and description methods | 233 |
| 2       | 20.1.2 Description of "Operation" column           | 234 |
|         | 20.1.3 Description of "Flag" column                |     |
|         | Operation List                                     |     |
| 20.3    | nstructions Listed by Addressing Type              | 240 |
| CHAPTER | R 21 ELECTRICAL SPECIFICATIONS (µPD789862)         | 243 |
| CHAPTER | R 22 ELECTRICAL SPECIFICATIONS ( $\mu$ PD78E9862)  | 255 |
| CHAPTER | R 23 PACKAGE DRAWING                               | 267 |
| CHAPTER | R 24 RECOMMENDED SOLDERING CONDITIONS              | 268 |
| APPENDI | X A DEVELOPMENT TOOLS                              | 270 |
| A.1 \$  | Software Package                                   |     |
| A.2 I   | Language Processing Software                       | 272 |
|         | Control Software                                   |     |
|         | EEPROM (Program Memory) Writing Tools              |     |
|         | Debugging Tools                                    |     |
|         | A.5.1 Hardware                                     |     |
| -       | A.5.2 Software<br>Notes on Target System Design    |     |
| A.0 I   | Notes on Target System Design                      |     |
| APPENDI | X B REGISTER INDEX                                 |     |
| B.1 F   | Register Name Index (in Alphabetical Order)        | 278 |

| B.2 Register  | Symbol Index (in Alphabetical Orde | er)280 |
|---------------|------------------------------------|--------|
|               |                                    |        |
| APPENDIX C RE | EVISION HISTORY                    |        |

# LIST OF FIGURES (1/5)

| Figure No. | Title                                          | Page |
|------------|------------------------------------------------|------|
| 2-1        | Pin I/O Circuits                               |      |
| 3-1        | Memory Map (μPD789862)                         |      |
| 3-2        | Memory Map (μPD78E9862)                        |      |
| 3-3        | Data Memory Addressing (µPD789862)             | 41   |
| 3-4        | Data Memory Addressing (µPD78E9862)            | 42   |
| 3-5        | Program Counter Configuration                  | 43   |
| 3-6        | Program Status Word Configuration              | 43   |
| 3-7        | Stack Pointer Configuration                    | 45   |
| 3-8        | Data to Be Saved to Stack Memory               | 45   |
| 3-9        | Data to Be Restored from Stack Memory          | 45   |
| 3-10       | General-Purpose Register Configuration         | 46   |
| 4-1        | EEPROM Block Diagram                           |      |
| 4-2        | Block Diagram of 8-Bit Timer 80                | 60   |
| 4-3        | Format of EEPROM Write Control Register 10     | 61   |
| 4-4        | Format of 8-Bit Timer Mode Control Register 80 | 64   |
| 5-1        | Port Types                                     | 68   |
| 5-2        | Block Diagram of P00 to P03                    |      |
| 5-3        | Block Diagram of P10 and P11                   | 71   |
| 5-4        | Block Diagram of P20 and P21                   | 72   |
| 5-5        | Block Diagram of P22 and P23                   |      |
| 5-6        | Block Diagram of P24                           | 74   |
| 5-7        | Block Diagram of P30                           | 75   |
| 5-8        | Block Diagram of P31                           |      |
| 5-9        | Block Diagram of P32 and P33                   | 77   |
| 5-10       | Block Diagram of P40 to P45                    |      |
| 5-11       | Block Diagram of P70                           |      |
| 5-12       | Port Mode Register Format                      | 81   |
| 5-13       | Format of Pull-Up Resistor Option Register     | 81   |
| 6-1        | Block Diagram of Clock Generator               | 83   |
| 6-2        | Format of Processor Clock Control Register     |      |
| 6-3        | External Circuit of System Clock Oscillator    |      |
| 6-4        | Examples of Incorrect Resonator Connection     |      |
| 6-5        | Switching Between System Clock and CPU Clock   |      |
| 7-1        | Block Diagram of 16-Bit Timer/Event Counter 0  | 91   |

# LIST OF FIGURES (2/5)

| Figure No. | Title                                                                                       | Page |
|------------|---------------------------------------------------------------------------------------------|------|
| 7-2        | Format of 16-Bit Timer Mode Control Register 0 (TMC0)                                       | 95   |
| 7-3        | Format of Capture/Compare Control Register 0 (CRC0)                                         |      |
| 7-4        | Format of 16-Bit Timer Output Control Register 0 (TOC0)                                     |      |
| 7-5        | Format of Prescaler Mode Register 0 (PRM0)                                                  |      |
| 7-6        | Format of Port Mode Register 2 (PM2)                                                        |      |
| 7-7        | Control Register Settings for Interval Timer Operation                                      |      |
| 7-8        | Interval Timer Configuration Diagram                                                        |      |
| 7-9        | Timing of Interval Timer Operation                                                          |      |
| 7-10       | Control Register Settings for PPG Output Operation                                          |      |
| 7-11       | PPG Output Configuration Diagram                                                            |      |
| 7-12       | PPG Output Operation Timing                                                                 |      |
| 7-13       | Control Register Settings for Pulse Width Measurement with Free-Running Counter and One     |      |
|            | Capture Register                                                                            | 104  |
| 7-14       | Configuration Diagram for Pulse Width Measurement by Free-Running Counter                   | 105  |
| 7-15       | Timing of Pulse Width Measurement Operation by Free-Running Counter and One Capture         |      |
|            | Register (with Both Edges Specified)                                                        | 105  |
| 7-16       | Control Register Settings for Measurement of Two Pulse Widths with Free-Running Counter     | 106  |
| 7-17       | CR01 Capture Operation with Rising Edge Specified                                           | 107  |
| 7-18       | Timing of Pulse Width Measurement Operation by Free-Running Counter (with Both Edges        |      |
|            | Specified)                                                                                  | 107  |
| 7-19       | Control Register Settings for Pulse Width Measurement with Free-Running Counter and Two     |      |
|            | Capture Registers                                                                           | 108  |
| 7-20       | Timing of Pulse Width Measurement Operation by Free-Running Counter and Two Capture         |      |
|            | Registers (with Rising Edge Specified)                                                      |      |
| 7-21       | Control Register Settings for Pulse Width Measurement by Means of Restart                   |      |
| 7-22       | Timing of Pulse Width Measurement Operation by Means of Restart (with Rising Edge Specified |      |
| 7-23       | Control Register Settings in External Event Counter Mode                                    |      |
| 7-24       | External Event Counter Configuration Diagram                                                |      |
| 7-25       | External Event Counter Operation Timing (with Rising Edge Specified)                        |      |
| 7-26       | Control Register Settings in Square-Wave Output Mode                                        |      |
| 7-27       | Square-Wave Output Operation Timing                                                         |      |
| 7-28       | Start Timing of 16-Bit Timer Counter 0 (TM0)                                                |      |
| 7-29       | Capture Register Data Retention Timing                                                      |      |
| 7-30       | Operation Timing of OVF0 Flag                                                               | 115  |
| 8-1        | Block Diagram of 16-Bit Timer D                                                             |      |
| 8-2        | Example of Timing During TMD Operation                                                      |      |
| 8-3        | Format of 16-Bit Timer Mode Control Register D (TMCD)                                       |      |
| 8-4        | TMD Compare Operation Example                                                               | 123  |

# LIST OF FIGURES (3/5)

| Figure No. | Title                                                                          | Page |
|------------|--------------------------------------------------------------------------------|------|
| 9-1        | Block Diagram of 8-Bit Timer/Event Counter 5                                   | 126  |
| 9-2        | Format of Timer Clock Select Register 5 (TCL5)                                 |      |
| 9-3        | Format of 8-Bit Timer Mode Control Register 5 (TMC5)                           |      |
| 9-4        | Format of Port Mode Register 2 (PM2)                                           |      |
| 9-5        | Interval Timer Operation Timing                                                |      |
| 9-6        | External Event Counter Operation Timing (with Rising Edge Specified)           |      |
| 9-7        | Square-Wave Output Operation Timing                                            |      |
| 9-8        | PWM Output Operation Timing                                                    |      |
| 9-9        | Timing of Operation by CR5 Transition                                          |      |
| 9-10       | Start Timing of 8-Bit Timer Counter 5                                          |      |
| 10-1       | Block Diagram of Watchdog Timer                                                | 139  |
| 10-2       | Format of Watchdog Timer Clock Select Register                                 | 140  |
| 10-3       | Format of Watchdog Timer Mode Register                                         | 141  |
| 11-1       | Block Diagram of Serial Interface 2                                            | 146  |
| 11-2       | Block Diagram of Baud Rate Generator                                           | 147  |
| 11-3       | Format of Serial Operating Mode Register 2                                     | 149  |
| 11-4       | Format of Asynchronous Serial Interface Mode Register 2                        | 150  |
| 11-5       | Format of Asynchronous Serial Interface Status Register 2                      | 152  |
| 11-6       | Format of Baud Rate Generator Control Register 2                               | 153  |
| 11-7       | Format of Asynchronous Serial Interface Transmit/Receive Data                  | 164  |
| 11-8       | Asynchronous Serial Interface Transmission Completion Interrupt Timing         |      |
| 11-9       | Asynchronous Serial Interface Reception Completion Interrupt Timing            |      |
| 11-10      | Receive Error Timing                                                           |      |
| 11-11      | 3-Wire Serial I/O Mode Timing                                                  | 175  |
| 12-1       | Block Diagram of Power-on-Clear Circuit                                        |      |
| 12-2       | Block Diagram of Low-Voltage Detection Circuit                                 |      |
| 12-3       | Format of Power-on-Clear Register                                              |      |
| 12-4       | Format of Low-Voltage Detection Register                                       |      |
| 12-5       | Format of Low-Voltage Detection Level Selection Register                       |      |
| 12-6       | Timing of Internal Reset Signal Generation When POC Circuit Normally Operating |      |
| 12-7       | Timing of Internal Reset Signal Generation When POC Circuit Normally Halted    |      |
| 12-8       | Timing of Internal Reset Signal Generation in POC Switching Circuit            |      |
| 12-9       | LVI Circuit Operation Timing                                                   | 185  |
| 13-1       | Block Diagram of Bit Sequential Buffer                                         |      |
| 13-2       | Format of Bit Sequential Buffer 1 Output Control Register                      |      |

# LIST OF FIGURES (4/5)

| Figure No. | Title                                                                                      | Page |
|------------|--------------------------------------------------------------------------------------------|------|
| 13-3       | Format of Port Mode Register 2 (PM2)                                                       | 187  |
| 13-4       | Operation Timing of Bit Sequential Buffer                                                  |      |
| 13-5       | Match Signal of 16-Bit Timer D                                                             |      |
|            |                                                                                            |      |
| 14-1       | Block Diagram of Key Return Circuit                                                        | 192  |
| 14-2       | Format of Key Return Edge Detection Register                                               | 193  |
| 15-1       | Basic Configuration of Interrupt Function                                                  | 196  |
| 15-2       | Format of Interrupt Request Flag Register                                                  |      |
| 15-3       | Format of Interrupt Mask Flag Register                                                     |      |
| 15-4       | Format of External Interrupt Mode Register 0                                               |      |
| 15-5       | Program Status Word Configuration                                                          |      |
| 15-6       | Flowchart from Non-Maskable Interrupt Request Generation to Acknowledgement (INTWDT)       |      |
| 15-7       | Timing of Non-Maskable Interrupt Request Acknowledgement                                   |      |
| 15-8       | Acknowledgement of Non-Maskable Interrupt Request                                          |      |
| 15-9       | Interrupt Request Acknowledgement Processing Algorithm                                     | 205  |
| 15-10      | Interrupt Request Acknowledgement Timing (Example of MOV A, r)                             | 206  |
| 15-11      | Interrupt Request Acknowledgement Timing (When Interrupt Request Flag Is Set at Last Clock |      |
|            | During Instruction Execution)                                                              | 206  |
| 15-12      | Example of Multiple Interrupts                                                             | 207  |
| 16-1       | Format of Oppillation Stabilization Time Selection Productor                               | 210  |
| -          | Format of Oscillation Stabilization Time Selection Register                                |      |
| 16-2       | Releasing HALT Mode by Interrupt                                                           |      |
| 16-3       | Releasing HALT Mode by RESET Input                                                         |      |
| 16-4       | Releasing STOP Mode by Interrupt                                                           |      |
| 16-5       | Releasing STOP Mode by RESET Input                                                         | 216  |
| 17-1       | Block Diagram of Reset Function                                                            | 217  |
| 17-2       | Reset Timing by RESET Input                                                                | 218  |
| 17-3       | Reset Timing by Watchdog Timer Overflow                                                    | 218  |
| 17-4       | Reset Timing by RESET Input in STOP Mode                                                   | 218  |
| 18-1       | Environment for Writing Program to EEPROM (Program Memory)                                 |      |
| 18-2       | Communication Mode Selection Format                                                        |      |
| 18-3       | Example of Connection with Dedicated Flash Programmer                                      |      |
| 18-4       | VPP Pin Connection Example                                                                 |      |
| 18-5       | Signal Conflict (Input Pin of Serial Interface)                                            |      |
| 18-6       | Abnormal Operation of Other Device                                                         |      |

# LIST OF FIGURES (5/5)

| Figure No. | Title                                                               | Page |
|------------|---------------------------------------------------------------------|------|
|            |                                                                     |      |
| 18-7       | Signal Conflict (RESET Pin)                                         | 228  |
| 18-8       | Wiring Example for EEPROM Writing Adapter in 3-Wire Serial I/O Mode | 229  |
| 18-9       | Wiring Example for EEPROM Writing Adapter in UART Mode              | 230  |
| 18-10      | Wiring Example for EEPROM Writing Adapter in Pseudo 3-Wire Mode     | 231  |
| A-1        | Development Tools                                                   | 271  |
| A-2        | Distance Between In-Circuit Emulator and Conversion Adapter         | 276  |
| A-3        | Connection Condition of Target System                               | 277  |

# LIST OF TABLES (1/2)

| Table No. | Title                                                                                   | Page |
|-----------|-----------------------------------------------------------------------------------------|------|
| 2-1       | Types of Pin I/O Circuits and Recommended Connection of Unused Pins                     | 36   |
| 3-1       | Internal ROM Capacity                                                                   | 40   |
| 3-2       | Vector Table                                                                            | 40   |
| 3-3       | Special Function Registers                                                              | 48   |
| 4-1       | EEPROM Write Time                                                                       | 62   |
| 4-2       | Configuration of 8-Bit Timer 80                                                         | 63   |
| 5-1       | Port Functions                                                                          | 69   |
| 5-2       | Configuration of Port                                                                   | 70   |
| 5-3       | Port Mode Register and Output Latch Settings When Using Alternate Functions             | 80   |
| 6-1       | Configuration of Clock Generator                                                        | 83   |
| 6-2       | Maximum Time Required for Switching CPU Clock                                           | 89   |
| 7-1       | Configuration of 16-Bit Timer/Event Counter 0                                           | 91   |
| 7-2       | TI00/TO0/P23 Pin Valid Edge and CR00, CR01 Capture Trigger                              | 92   |
| 7-3       | TI01/P24/INTP0 Pin Valid Edge and CR00 Capture Trigger                                  | 92   |
| 8-1       | Configuration of 16-Bit Timer D                                                         | 118  |
| 9-1       | Configuration of 8-Bit Timer/Event Counter 5                                            | 127  |
| 10-1      | Inadvertent Loop Detection Time of Watchdog Timer                                       | 138  |
| 10-2      | Interval Time                                                                           | 138  |
| 10-3      | Configuration of Watchdog Timer                                                         | 139  |
| 10-4      | Inadvertent Loop Detection Time of Watchdog Timer                                       | 142  |
| 10-5      | Interval Time of Interval Timer                                                         | 143  |
| 11-1      | Configuration of Serial Interface 2                                                     | 145  |
| 11-2      | Operation Mode Settings for Serial Interface 2                                          | 151  |
| 11-3      | Example of Relationship Between System Clock and Baud Rate                              | 154  |
| 11-4      | Relationship Between ASCK2 Pin Input Frequency and Baud Rate (When BRGC2 Is Set to 80H) | 155  |
| 11-5      | Example of Relationship Between System Clock and Baud Rate                              | 161  |
| 11-6      | Relationship Between ASCK2 Pin Input Frequency and Baud Rate (When BRGC2 Is Set to 80H) | 162  |
| 11-7      | Receive Error Causes                                                                    | 168  |
| 13-1      | Configuration of Bit Sequential Buffer                                                  | 186  |

# LIST OF TABLES (2/2)

| Table No. | Title                                                           | Page |
|-----------|-----------------------------------------------------------------|------|
| 13-2      | Count Clock and Match Signal High Level Width of 16-Bit Timer D |      |
| 15-1      | Interrupt Source List                                           |      |
| 15-2      | Flags Corresponding to Interrupt Request Signal                 | 197  |
| 15-3      | Time from Generation of Maskable Interrupt Request to Servicing | 204  |
| 16-1      | Operation Statuses in HALT Mode                                 | 211  |
| 16-2      | Operation After Releasing HALT Mode                             | 213  |
| 16-3      | Operation Statuses in STOP Mode                                 | 214  |
| 16-4      | Operation After Releasing STOP Mode                             | 216  |
| 17-1      | Status of Hardware After Reset                                  | 219  |
| 18-1      | Differences Between $\mu$ PD78E9862 and Mask ROM Version        | 221  |
| 18-2      | Communication Mode List                                         | 223  |
| 18-3      | Pin Connection List                                             | 225  |
| 20-1      | Operand Identifiers and Description Methods                     | 233  |
| 24-1      | Surface Mounting Type Soldering Conditions                      |      |

#### 1.1 Features

• ROM and RAM capacity

| ltem         | Program Mer | nory  | Data Memory             |                     |  |  |
|--------------|-------------|-------|-------------------------|---------------------|--|--|
| Product Name | (ROM)       |       | Internal High-Speed RAM | EEPROM <sup>™</sup> |  |  |
| μPD789862    | Mask ROM    | 16 KB | 512 bytes               | 256 bytes           |  |  |
| μPD78E9862   | EEPROM      | 16 KB |                         |                     |  |  |

• System clock: Ceramic/crystal oscillation

Minimum instruction execution time can be changed from high-speed (0.4 μs) to low-speed (1.6 μs) at 5.0 MHz operation with system clock.

- I/O ports: 22
- Timer: 4 channels
- 16-bit timer: 2 channels
- 8-bit timer: 1 channel
- Watchdog timer: 1 channel
- Serial interface: 1 channel

3-wire serial I/O mode/UART mode selectable

- On-chip key return circuit
- On-chip power-on-clear circuit
- On-chip bit sequential buffer
- Vectored interrupt sources: 13
- Power supply voltage: VDD = 1.8 to 5.5 V
- Operating ambient temperature:  $T_A = -40$  to  $+85^{\circ}C$  ( $\mu$ PD789862)

 $T_A = -40$  to +70°C ( $\mu$ PD78E9862)

#### **1.2 Applications**

Keyless entry and other automotive electrical equipment

# 1.3 Ordering Information

| Part Number                      | Package                             | Internal ROM |
|----------------------------------|-------------------------------------|--------------|
| μPD789862MC-×××-5A4              | 30-pin plastic SSOP (7.62 mm (300)) | Mask ROM     |
| μPD78E9862MC-5A4 <sup>Νοτε</sup> | 30-pin plastic SSOP (7.62 mm (300)) | EEPROM       |

\* Note The  $\mu$ PD78E9862 is provided exclusively for program development; the product life and reliability are not guaranteed. Use the  $\mu$ PD789862 for reliability testing and mass production.

· RESET

-O P03

#### 1.4 Pin Configuration (Top View)

#### 30-pin plastic SSOP (7.62 mm (300)) μPD789862MC-×××-5A4 μPD78E9862MC-5A4 EEWE O 1 30 P70/RESOUT O-2 29 P22/TI50/TO50 O-3 -O P02 28 P23/TI00/TO0 O-4 27 KRREN O-5 26 P40/KR0 O-6 25 P41/KR1 O-7 24



#### Caution Connect the IC (Internally Connected) pin directly to Vss.

**Remark** Pin connections in parentheses are intended for the  $\mu$ PD78E9862.

| ASCK2:        | Asynchronous serial input    | RESET:            | Reset                      |
|---------------|------------------------------|-------------------|----------------------------|
| BSFO0, BSFO1: | Bit sequential buffer output | RESOUT:           | Reset output               |
| EEWE:         | EEPROM write enable          | RxD2:             | Receive data               |
| IC:           | Internally connected         | SCK2:             | Serial clock               |
| INTP0, INTP1: | Interrupt from peripherals   | SI2:              | Serial input               |
| KR0 to KR5:   | Key return                   | SO2:              | Serial output              |
| KRREN:        | Key return reset enable      | TI00, TI01, TI50: | Timer input                |
| P00 to P03:   | Port 0                       | TO0, TO50:        | Timer output               |
| P10, P11:     | Port 1                       | TxD2:             | Transmit data              |
| P20 to P24:   | Port 2                       | Vdd:              | Power supply               |
| P30 to P33:   | Port 3                       | Vpp:              | Programming power supply   |
| P40 to P45:   | Port 4                       | Vss:              | Ground                     |
| P70:          | Port 7                       | X1, X2:           | Crystal/ceramic oscillator |

#### \* 1.5 78K/0S Series Lineup







The major functional differences between the subseries are listed below.

|                         | Function       | ROM               |       | Tir    | mer   |      | 8-Bit | 10-Bit | Serial               | I/O | Vdd                   | Remarks                |
|-------------------------|----------------|-------------------|-------|--------|-------|------|-------|--------|----------------------|-----|-----------------------|------------------------|
| Culture N               |                | Capacity          | 8-Bit | 16-Bit | Watch | WDT  | A/D   | A/D    | Interface            |     | MIN.                  |                        |
| Subseries Na            |                |                   |       |        |       |      |       |        |                      |     | Value                 |                        |
| Small-scale package,    | μPD789046      | 16 KB             | 1 ch  | 1 ch   | 1 ch  | 1 ch | -     | -      | 1 ch<br>(UART: 1 ch) | 34  | 1.8 V                 | -                      |
| general-                | μPD789026      | 4 KB to 16 KB     |       |        | -     |      |       |        |                      |     |                       |                        |
| purpose<br>applications | μPD789088      | 16 KB to<br>32 KB | 3 ch  |        |       |      |       |        |                      | 24  |                       |                        |
|                         | μPD789074      | 2 KB to 8 KB      | 1 ch  |        |       |      |       |        |                      |     |                       |                        |
|                         | μPD789014      | 2 KB to 4 KB      | 2 ch  | _      |       |      |       |        |                      | 22  |                       |                        |
|                         | μPD789062      | 4 KB              |       |        |       |      |       |        | -                    | 14  |                       | RC oscillation version |
|                         | μPD789052      |                   |       |        |       |      |       |        |                      |     |                       | _                      |
| Small-scale             | μPD789177      | 16 KB to          | 3 ch  | 1 ch   | 1 ch  | 1 ch | _     | 8 ch   | 1 ch                 | 31  | 1.8 V                 | _                      |
| package,                | μPD789167      | 24 KB             |       |        |       |      | 8 ch  | _      | (UART: 1 ch)         |     |                       |                        |
| general-<br>purpose     | μPD789156      | 8 KB to 16 KB     | 1 ch  |        | _     |      | _     | 4 ch   |                      | 20  |                       | On-chip                |
| applications            | μPD789146      |                   |       |        |       |      | 4 ch  | _      |                      |     |                       | EEPROM                 |
| and A/D<br>converter    | μPD789134A     | 2 KB to 8 KB      |       |        |       |      | _     | 4 ch   |                      |     |                       | RC oscillation         |
| conventer               | μPD789124A     |                   |       |        |       |      | 4 ch  | _      |                      |     |                       | version                |
|                         | μPD789114A     |                   |       |        |       |      | _     | 4 ch   |                      |     |                       | _                      |
|                         | μPD789104A     |                   |       |        |       |      | 4 ch  | -      |                      |     |                       |                        |
| LCD drive               | μPD789835      | 24 KB to<br>60 KB | 6 ch  | -      | 1 ch  | 1 ch | 3 ch  | -      | 1 ch<br>(UART: 1 ch) | 37  | 1.8 V <sup>Note</sup> | Dot LCD<br>supported   |
|                         | μPD789830      | 24 KB             | 1 ch  | 1 ch   |       |      | _     |        |                      | 30  | 2.7 V                 |                        |
|                         | μPD789488      | 32 KB to<br>48 KB | 3 ch  |        |       |      |       | 8 ch   | 2 ch<br>(UART: 1 ch) | 45  | 1.8 V                 | _                      |
|                         | μPD789478      | 24 KB to<br>48 KB |       |        |       |      | 8 ch  | -      |                      |     |                       |                        |
|                         | μPD789417A     | 12 KB to          |       |        |       |      | _     | 7 ch   | 1 ch                 | 43  |                       |                        |
|                         | μPD789407A     | 24 KB             |       |        |       |      | 7 ch  | -      | (UART: 1 ch)         |     |                       |                        |
|                         | μPD789456      | 12 KB to          | 2 ch  |        |       |      | _     | 6 ch   |                      | 30  |                       |                        |
|                         | μPD789446      | 16 KB             |       |        |       |      | 6 ch  | -      |                      |     |                       |                        |
|                         | μPD789436      |                   |       |        |       |      | _     | 6 ch   |                      | 40  |                       |                        |
|                         | μPD789426      |                   |       |        |       |      | 6 ch  | -      |                      |     |                       |                        |
|                         | μPD789316      | 8 KB to 16 KB     |       |        |       |      | _     |        | 2 ch<br>(UART: 1 ch) | 23  |                       | RC oscillation version |
|                         | μPD789306      |                   |       |        |       |      |       |        |                      |     |                       | _                      |
|                         | ,<br>μPD789467 | 4 KB to 24 KB     |       | _      |       |      | 1 ch  |        | _                    | 18  |                       |                        |
|                         | ,<br>μPD789327 |                   |       |        |       |      | _     |        | 1 ch                 | 21  |                       |                        |

Series for General-purpose applications and LCD drive

Note Flash memory version: 3.0 V

|                           | Function   |                   | Timer |        |       | 8-Bit 10-Bit | Serial | I/O  | Vdd                  | Remarks |                         |                                               |
|---------------------------|------------|-------------------|-------|--------|-------|--------------|--------|------|----------------------|---------|-------------------------|-----------------------------------------------|
|                           |            | Capacity          | 8-Bit | 16-Bit | Watch | WDT          | A/D    | A/D  | Interface            |         | MIN.                    |                                               |
| Subseries Name            |            |                   |       |        |       |              |        |      |                      |         | Value                   |                                               |
| USB                       | μPD789800  | 8 KB              | 2 ch  | -      | -     | 1 ch         | -      | -    | 2 ch<br>(USB: 1 ch)  | 31      | 4.0 V                   | -                                             |
| Inverter<br>control       | μPD789842  | 8 KB to 16 KB     | 3 ch  | Note 1 | 1 ch  | 1 ch         | 8 ch   | -    | 1 ch<br>(UART: 1 ch) | 30      | 4.0 V                   | -                                             |
| On-chip bus<br>controller | μPD789852  | 24 KB to<br>32 KB | 3 ch  | 1 ch   | _     | 1 ch         | _      | 8 ch | 3 ch<br>(UART: 2 ch) | 31      | 4.0 V                   | -                                             |
|                           | μPD789850A | 16 KB             | 1 ch  |        |       |              | 4 ch   | -    | 2 ch<br>(UART: 1 ch) | 18      |                         |                                               |
| Keyless<br>entry          | μPD789861  | 4 KB              | 2 ch  | _      | _     | 1 ch         | _      | _    | _                    | 14      | 1.8 V                   | RC oscillation<br>version, on-<br>chip EEPROM |
|                           | μPD789860  | ]                 |       |        |       |              |        |      |                      |         |                         | On-chip                                       |
|                           | μPD789862  | 16 KB             | 1 ch  | 2 ch   |       |              |        |      | 1 ch<br>(UART: 1 ch) | 22      |                         | EEPROM                                        |
| VFD drive                 | μPD789871  | 4 KB to 8 KB      | 3 ch  | -      | 1 ch  | 1 ch         | -      | -    | 1 ch                 | 33      | 2.7 V                   | _                                             |
| Meter<br>control          | μPD789881  | 16 KB             | 2 ch  | 1 ch   | _     | 1 ch         | -      | -    | 1 ch<br>(UART: 1 ch) | 28      | 2.7 V <sup>Note 2</sup> | _                                             |

#### Series for ASSP

Notes 1. 10-bit timer: 1 channel

2. Flash memory version: 3.0 V

#### 1.6 Block Diagram



**Remark** Pin connections in parentheses are intended for the  $\mu$ PD78E9862.

### **1.7 Overview of Functions**

|                           | Part Number    | μPD789862                                                                                                 | μPD78E9862 |  |  |  |  |
|---------------------------|----------------|-----------------------------------------------------------------------------------------------------------|------------|--|--|--|--|
| Item                      |                |                                                                                                           |            |  |  |  |  |
| Internal memory           | ROM            | Mask ROM                                                                                                  | EEPROM     |  |  |  |  |
|                           |                | 16 KB                                                                                                     |            |  |  |  |  |
|                           | High-speed RAM | 512 bytes                                                                                                 |            |  |  |  |  |
|                           | EEPROM         | 256 bytes                                                                                                 |            |  |  |  |  |
| Oscillator                |                | Ceramic/crystal oscillator                                                                                |            |  |  |  |  |
| Minimum instruction       | execution time | 0.4/0.8/1.6 µs (@5.0 MHz operation with system clock)                                                     |            |  |  |  |  |
| General-purpose reg       | isters         | 8 bits $\times$ 8 registers                                                                               |            |  |  |  |  |
| Instruction set           |                | <ul><li>16-bit operations</li><li>Bit manipulations (such as set, reset, and test)</li></ul>              |            |  |  |  |  |
| I/O ports                 |                | Total:22CMOS I/O:13CMOS input:6CMOS output:1N-ch open drain:2                                             |            |  |  |  |  |
| Timers                    |                | 16-bit timer: 2 channels     8-bit timer: 1 channel     Watchdog timer: 1 channel                         |            |  |  |  |  |
| Serial interface          |                | 3-wire serial I/O mode/UART mode<br>Selectable: 1 channel                                                 |            |  |  |  |  |
| Power-on-clear<br>circuit | POC circuit    | Generates internal reset signal according to comparison of detection voltage with power supply voltage    |            |  |  |  |  |
|                           | LVI circuit    | Generates interrupt request signal according to comparison of detection voltage with power supply voltage |            |  |  |  |  |
| Bit sequential buffer     | •              | 8 bits + 8 bits = 16 bits                                                                                 |            |  |  |  |  |
| Key return function       |                | Generates key return signal according to falling edge detection<br>(only one edge selectable)             |            |  |  |  |  |
| Vectored interrupt        | Maskable       | Internal: 9, external: 2                                                                                  |            |  |  |  |  |
| sources                   | Non-maskable   | Internal: 1, external: 1                                                                                  |            |  |  |  |  |
| Power supply voltage      |                | V <sub>DD</sub> = 1.8 to 5.5 V                                                                            |            |  |  |  |  |
| Operating ambient te      | emperature     | $T_A = -40 \text{ to } +85^{\circ}\text{C}$ $T_A = -40 \text{ to } +70^{\circ}\text{C}$                   |            |  |  |  |  |
| Package                   |                | 30-pin plastic SSOP (7.62 mm (300))                                                                       |            |  |  |  |  |

#### **CHAPTER 2 PIN FUNCTIONS**

## 2.1 Pin Function List

# (1) Port pins

| Pin Name   | I/O    | Function                                                                                                                                                                                                  | After Reset | Alternate Function |
|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| P00 to P03 | I/O    | Port 0<br>4-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be<br>used by setting pull-up resistor option register 0 (PUB0). | Input       | _                  |
| P10, P11   | I/O    | Port 1<br>2-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be<br>used by setting pull-up resistor option register 1 (PUB1). | Input       | _                  |
| P20        | I/O    | Port 2                                                                                                                                                                                                    | Input       | BSFO0              |
| P21        |        | 5-bit I/O port (P20 and P21 are N-ch open drain I/O ports.)<br>Input/output can be specified in 1-bit units.                                                                                              |             | BSFO1              |
| P22        |        | When used as an input port, an on-chip pull-up resistor can be<br>used by setting pull-up resistor option register 2 (PUB2).                                                                              |             | TI50/TO50          |
| P23        |        |                                                                                                                                                                                                           |             | TI00/TO0           |
| P24        |        |                                                                                                                                                                                                           |             | TI01/INTP0         |
| P30        | I/O    | Port 3                                                                                                                                                                                                    | Input       | SCK2/ASCK2         |
| P31        |        | <ul><li>4-bit I/O port</li><li>Input/output can be specified in 1-bit units.</li><li>When used as an input port, an on-chip pull-up resistor can be</li></ul>                                             |             | TxD2/SO2           |
| P32        |        |                                                                                                                                                                                                           |             | RxD2/SI2           |
| P33        |        | used by setting pull-up resistor option register 3 (PUB3).                                                                                                                                                |             | INTP1              |
| P40 to P45 | Input  | Port 4<br>6-bit input-only port<br>On-chip pull-up resistor                                                                                                                                               | Input       | KR0 to KR5         |
| P70        | Output | Port 7<br>1-bit output-only port                                                                                                                                                                          | Output      | RESOUT             |

## (2) Non-port pins

| Pin Name        | I/O    | Function                                                                                                              | After Reset | Alternate Function |
|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| BSFO0,<br>BSFO1 | Output | Bit sequential buffer output                                                                                          | Input       | P20, P21           |
| TI50            | Input  | 8-bit timer (TM5) input                                                                                               | Input       | P22/TO50           |
| TO50            | Output | 8-bit timer (TM5) output                                                                                              | Input       | P22/TI50           |
| TI00            | Input  | 16-bit timer (TM0) input                                                                                              | Input       | P23/TO0            |
| TI01            |        |                                                                                                                       |             | P24/INTP0          |
| TO0             | Output | 16-bit timer (TM0) output                                                                                             | Input       | P23/TI00           |
| SCK2            | I/O    | Serial clock input/output of serial interface                                                                         | Input       | P30/ASCK2          |
| SI2             | Input  | Serial data input of serial interface                                                                                 | Input       | P32/RxD2           |
| SO2             | Output | Serial data output of serial interface                                                                                | Input       | P31/TxD2           |
| ASCK2           | Input  | Serial clock input for asynchronous serial interface                                                                  | Input       | P30/SCK2           |
| RxD2            | Input  | Serial data input for asynchronous serial interface                                                                   | Input       | P32/SI2            |
| TxD2            | Output | Serial data output for asynchronous serial interface                                                                  | Input       | P31/SO2            |
| KR0 to KR5      | Input  | Key return input                                                                                                      | Input       | P40 to P45         |
| KRREN           | Input  | Non-maskable interrupt/reset switch input for key return                                                              | Input       | _                  |
| INTP0           | Input  | External interrupt input for which the valid edge can be                                                              | Input       | P24/TI01           |
| INTP1           |        | specified (rising, falling, or both rising and falling edges)                                                         |             | P33                |
| RESOUT          | Output | Reset signal output                                                                                                   | Output      | P70                |
| EEWE            | Input  | Write enable input of EEPROM master data area                                                                         | Input       | _                  |
| X1              | Input  | Connecting ceramic/crystal resonator for system clock                                                                 | -           | _                  |
| X2              | -      | oscillation                                                                                                           | -           | _                  |
| RESET           | Input  | System reset input                                                                                                    | Input       | _                  |
| Vdd             | -      | Positive supply voltage                                                                                               | -           | _                  |
| Vss             | -      | Ground potential                                                                                                      | -           | -                  |
| IC              | -      | Internally connected. Connect directly to Vss.                                                                        | -           |                    |
| Vpp             | -      | This pin is used to set the EEPROM programming mode and applies a high voltage when a program is written or verified. | -           | _                  |

#### 2.2 Description of Pin Functions

#### 2.2.1 P00 to P03 (Port 0)

These pins constitute a 4-bit I/O port and can be set to input or output port mode in 1-bit units by setting port mode register 0 (PM0). When used as an input port, an on-chip pull-up resistor can be used by setting pull-up resistor option register 0 (PUB0).

#### 2.2.2 P10, P11 (Port 1)

These pins constitute a 2-bit I/O port and can be set to input or output port mode in 1-bit units by setting port mode register 1 (PM1). When used as an input port, an on-chip pull-up resistor can be used by setting pull-up resistor option register 1 (PUB1).

#### 2.2.3 P20 to P24 (Port 2)

These pins constitute a 5-bit I/O port. In addition, these pins function as the timer I/O, external interrupt input, and bit sequential buffer output.

P20 and P21 are the N-ch open drain I/O ports.

#### (1) Port mode

In port mode, P20 to P24 function as a 5-bit I/O port and can be specified as an input or output port in 1-bit units by setting port mode register 2 (PM2). When used as an input port, an on-chip pull-up resistor can be used by setting pull-up resistor option register 2 (PUB2).

#### (2) Control mode

In control mode, P20 to P24 function as the timer I/O, external interrupt input, and bit sequential buffer output.

#### (a) BSFO0, BSFO1

These pins are the bit sequential buffer output pins.

#### (b) TI50, TO50

These pins are the 8-bit timer/event counter 5 I/O pins.

#### (c) TI00, TI01, TO0

These pins are the 16-bit timer/event counter 0 I/O pins.

#### (d) INTP0

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

#### 2.2.4 P30 to P33 (Port 3)

These pins constitute a 4-bit I/O port. In addition, these pins function as the external interrupt input, data I/O of the serial interface, and clock I/O.

#### (1) Port mode

In port mode, P30 to P33 function as a 4-bit I/O port and can be specified as an input or output port by setting port mode register 3 (PM3). When used as an input port, an on-chip pull-up resistor can be used by setting pull-up resistor option register 3 (PUB3).

#### (2) Control mode

In control mode, P30 to P33 function as the external interrupt input, data I/O of the serial interface, and clock I/O.

#### (a) SI2, SO2

SI2 and SO2 are the serial data I/O pins of the serial interface.

#### (b) SCK2

SCK2 is the serial clock I/O pin of the serial interface.

#### (c) RxD2, TxD2

RxD2 and TxD2 are the serial data I/O pins for the asynchronous serial interface.

#### (d) ASCK2

ASCK2 is the serial clock input pin for the asynchronous serial interface.

# Caution When a pin is used as a serial interface pin, I/O and the output latch must be set in accordance with the function. For how to make these settings, refer to Table 11-2 Operation Mode Settings for Serial Interface 2.

#### (e) INTP1

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

#### 2.2.5 P40 to P45 (Port 4)

These pins constitute a 6-bit input-only port, which functions as the key return input as well as a general-purpose input port.

An on-chip pull-up resistor is provided.

#### (1) Port mode

In port mode, P40 to P45 function as a 6-bit input-only port.

#### (2) Control mode

In control mode, P40 to P45 function as the key return input (KR0 to KR5).

#### 2.2.6 P70 (Port 7)

This pin constitutes a 1-bit output-only port, which functions as the reset output as well as a general-purpose output port.

#### (1) Port mode

In port mode, P70 functions as a 1-bit output-only port.

#### (2) Control mode

In control mode, P70 functions as the reset output (RESOUT).

#### 2.2.7 EEWE

This pin is an input pin to enable writing to the EEPROM master data area.

#### 2.2.8 KRREN

This pin is an input pin to switch between non-maskable interrupt and reset for the key return function.

#### 2.2.9 **RESET**

An active-low system reset signal is input to this pin.

#### 2.2.10 X1, X2

These pins are used to connect a crystal or ceramic resonator for system clock oscillation. To supply an external clock, input the clock to X1 and input the inverted signal to X2.

# 2.2.11 VDD

This pin supplies positive power.

#### 2.2.12 Vss

This pin is the ground potential pin.

#### 2.2.13 VPP (µPD78E9862 only)

A high voltage should be applied to this pin when the EEPROM programming mode is set and when the program is written or verified.

Perform either of the following pin handling.

- Independently connect a 10 k $\Omega$  pull-down resistor.
- Connect to a dedicated flash programmer in the programming mode and directly to Vss in the normal operation mode by using a jumper on the board.

If the wiring length between the VPP and Vss pins is too long or if external noise is superimposed on the VPP pin, the user program may not run correctly.

#### 2.2.14 IC (mask ROM version only)

The IC (Internally Connected) pin is used to set the  $\mu$ PD789862 to test mode before shipment. In normal operation mode, directly connect this pin to the Vss pin with as short a wiring length as possible.

If a potential difference is generated between the IC pin and the Vss pin due to a long wiring length between these pins or an external noise superimposed on the IC pin, the user program may not run correctly.

#### • Directly connect the IC pin to the Vss pin.



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

The I/O circuit type of each pin and recommended connection of unused pins are shown in Table 2-1. For the I/O circuit configuration of each type, refer to **Figure 2-1**.

| Pin Name           | I/O Circuit Type | I/O    | Recommended Connection of Unused Pins                                             |
|--------------------|------------------|--------|-----------------------------------------------------------------------------------|
| P00 to P03         | 5-A              | I/O    | Input: Independently connect to VDD or VSS via a resistor.                        |
| P10, P11           |                  |        | Output: Leave open.                                                               |
| P20/BSFO0          | 13-AG            |        |                                                                                   |
| P21/BSFO1          |                  |        |                                                                                   |
| P22/TI50/TO50      | 8-A              |        |                                                                                   |
| P23/TI00/TO0       |                  |        |                                                                                   |
| P24/TI01/INTP0     |                  |        | Input: Independently connect to Vss via a resistor.<br>Output: Leave open.        |
| P30/SCK2/ASCK2     |                  |        | Input: Independently connect to VDD or VSS via a resistor.                        |
| P31/TxD2/SO2       | 5-A              |        | Output: Leave open.                                                               |
| P32/RxD2/SI2       | 8-A              |        |                                                                                   |
| P33/INTP1          |                  |        | Input: Independently connect to Vss via a resistor.<br>Output: Leave open.        |
| P40/KR0 to P45/KR5 | 2-J              | Input  | Connect directly to VDD.                                                          |
| P70/RESOUT         | 3                | Output | Leave open.                                                                       |
| EEWE               | 2-1              | Input  | Connect directly to Vss.                                                          |
| KRREN              | 2                | Input  |                                                                                   |
| RESET              | 2-J              | Input  | _                                                                                 |
| IC                 | -                | -      | Connect directly to Vss.                                                          |
| Vpp                |                  |        | Independently connect 10 $k\Omega$ pull-down resistor or connect directly to Vss. |

Table 2-1. Types of Pin I/O Circuits and Recommended Connection of Unused Pins

| Figure | 2-1. | Pin | I/O | Circuits | 5 |
|--------|------|-----|-----|----------|---|
|        |      |     |     |          |   |



# CHAPTER 3 CPU ARCHITECTURE

# 3.1 Memory Space

The  $\mu$ PD789862 Subseries can access up to 64 KB of memory space. Figures 3-1 and 3-2 show the memory maps.



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



Figure 3-2. Memory Map (*µ*PD78E9862)

# 3.1.1 Internal program memory space

The internal program memory space stores programs and table data. This space is usually addressed by the program counter (PC).

The µPD789862 Subseries provide the following internal ROMs (or EEPROM) containing the following capacities.

| Table 3-1. Internal ROM Capacity |  |
|----------------------------------|--|
|----------------------------------|--|

| Part Number | Interna   | al ROM                 |  |  |
|-------------|-----------|------------------------|--|--|
|             | Structure | Capacity               |  |  |
| μPD789862   | Mask ROM  | 16,384 $\times$ 8 bits |  |  |
| μPD78E9862  | EEPROM    |                        |  |  |

The following areas are allocated to the internal program memory space.

#### (1) Vector table area

The 26-byte area of addresses 0000H to 0019H is reserved as a vector table area. This area stores program start addresses to be used when branching by  $\overrightarrow{\text{RESET}}$  input or interrupt request generation. Of a 16-bit address, the lower 8 bits are stored in an even address, and the higher 8 bits are stored in an odd address.

| Table 3-2. | Vector | Table |
|------------|--------|-------|
|------------|--------|-------|

| Vector Table Address | Interrupt Request | Vector Table Address | Interrupt Request |
|----------------------|-------------------|----------------------|-------------------|
| 0000H                | RESET input       | 000EH                | INTTM01           |
| 0002H                | INTKR00           | 0010H                | INTTM50           |
| 0004H                | INTWDT            | 0012H                | INTSR20/INTCSI20  |
| 0006H                | INTP0             | 0014H                | INTST20           |
| 0008H                | INTP1             | 0016H                | INTLVI1           |
| 000AH                | INTCMD            | 0018H                | INTEE0            |
| 000CH                | INTTM00           |                      |                   |

#### (2) CALLT instruction table area

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

#### 3.1.2 Internal data memory space

The  $\mu$ PD789862 Subseries provide the following RAMs.

#### (1) Internal high-speed RAM

The internal high-speed RAM is provided in the area of FD00H to FEFFH. The internal high-speed RAM can also be used as a stack memory.

#### (2) EEPROM

The EEPROM is provided in the area of F800H to F8FFH. For details of EEPROM, refer to **CHAPTER 4 EEPROM (DATA MEMORY)**.

#### 3.1.3 Special function register (SFR) area

Special function registers (SFRs) of on-chip peripheral hardware are allocated to the area of FF00H to FFFFH (see **Table 3-3**).

#### 3.1.4 Data memory addressing

The  $\mu$ PD789862 Subseries is provided with a wide range of addressing modes to make memory manipulation as efficient as possible. The data memory area (FD00H to FFFFH) can be accessed using a unique addressing mode according to its use, such as a special function register (SFR). Figures 3-3 and 3-4 illustrate the data memory addressing.



Figure 3-3. Data Memory Addressing (µPD789862)



Figure 3-4. Data Memory Addressing (µPD78E9862)

# 3.2 Processor Registers

The  $\mu$ PD789862 Subseries provide the following on-chip processor registers.

#### 3.2.1 Control registers

The control registers have special functions to control the program sequence statuses and stack memory. The control registers include a program counter, a program status word, and a stack pointer.

#### (1) Program counter (PC)

The program counter is a 16-bit register which 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 or register contents are set.

RESET input sets the reset vector table values at addresses 0000H and 0001H to the program counter.

#### Figure 3-5. Program Counter Configuration

| 15           |      |      |      |      |     |     |     |     |     |     |     |     |     | 0   |
|--------------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| PC PC15 PC14 | PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |

#### (2) Program status word (PSW)

The program status word is an 8-bit register consisting of various flags to be 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 RETI and POP PSW instructions. RESET input sets PSW to 02H.

#### Figure 3-6. Program Status Word Configuration

|     | 7  |   |   |    |   |   |   | 0  |
|-----|----|---|---|----|---|---|---|----|
| PSW | IE | Z | 0 | AC | 0 | 0 | 1 | CY |

# (a) Interrupt enable flag (IE)

This flag controls interrupt request acknowledge operations of the CPU.

When IE = 0, the interrupt disabled (DI) status is set. All interrupt requests except non-maskable interrupt are disabled.

When IE = 1, the interrupt enabled (EI) status is set. Interrupt request acknowledgment is controlled with an interrupt mask flag for various interrupt sources.

This flag is reset to 0 upon DI instruction execution or interrupt acknowledgment and is set to 1 upon EI instruction execution.

# (b) Zero flag (Z)

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

# (c) Auxiliary carry flag (AC)

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

#### (d) Carry flag (CY)

This flag stores overflow and underflow that have occurred 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-7. Stack Pointer Configuration

|    | 15   |      |      |      |      |      |     |     |     |     |     |     |     |     |     | 0   |
|----|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| SP | SP15 | SP14 | SP13 | SP12 | SP11 | SP10 | SP9 | SP8 | SP7 | SP6 | SP5 | SP4 | SP3 | SP2 | SP1 | SP0 |

The SP is decremented before writing (saving) to the stack memory and is incremented after reading (restoring) from the stack memory.

Each stack operation saves/restores data as shown in Figures 3-8 and 3-9.

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



#### Figure 3-8. Data to Be Saved to Stack Memory





# 3.2.2 General-purpose registers

The general-purpose registers consist of eight 8-bit registers (X, A, C, B, E, D, L, and H).

In addition to being used as an 8-bit register, 8-bit registers can be used in pairs as a 16-bit register (AX, BC, DE, and HL).

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).

# Figure 3-10. General-Purpose Register Configuration

#### (a) Absolute names

| 16-bit processing | <br>8-bit processing |
|-------------------|----------------------|
| RP3               | R7                   |
| KF3               | R6                   |
| RP2               | R5                   |
| RF2               | R4                   |
| RP1               | R3                   |
|                   | R2                   |
| RP0               | R1                   |
|                   | R0                   |
| 15 0              | 7 0                  |

# (b) Function names

| 16-bit processing |   | 8-bit processing |
|-------------------|---|------------------|
| HL                |   | н                |
|                   |   | L                |
| DE                |   | D                |
| DE                |   | E                |
| вС                |   | В                |
| ВС                |   | С                |
| AX                |   | A                |
| AX                |   | Х                |
| 15 0              | ) | 7 0              |

#### 3.2.3 Special function registers (SFRs)

Unlike the general-purpose registers, each special function register has a special function.

The special function registers are allocated to the 256-byte area FF00H to FFFFH.

The special function registers can be manipulated, like the general-purpose registers, with operation, transfer, and bit manipulation instructions. Manipulatable bit units (1, 8, and 16) differ depending on the special function register type.

Each manipulation bit unit can be specified as follows.

• 1-bit manipulation

Describes a 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

Describes a 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

Describes a symbol reserved by the assembler for the 16-bit manipulation instruction operand. When specifying an address, describe an even address.

Table 3-3 lists the special function registers. The meanings of the symbols in this table are as follows.

Symbol

Indicates the addresses of the implemented special function registers. The symbols shown in this column are reserved words in the assembler, and have already been defined in a header file called "sfrbit.h" in the C compiler. Therefore, these symbols can be used as instruction operands if an assembler or integrated debugger is used.

• R/W

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

R/W: Read/write

- R: Read only
- W: Write only
- Number of bits manipulated simultaneously Indicates the bit units (1, 8, and 16) in which the special function register can be manipulated.
- After reset

Indicates the status of the special function register when the RESET signal is input.

| Address | Special Function Register (SFR) Name            | Syn     | nbol                   | R/W |       | of Bits Ma<br>multaneou | -            | After Reset           |
|---------|-------------------------------------------------|---------|------------------------|-----|-------|-------------------------|--------------|-----------------------|
|         |                                                 |         |                        |     | 1 Bit | 8 Bits                  | 16 Bits      |                       |
| FF00H   | Port 0                                          | P0      |                        | R/W |       | $\checkmark$            | -            | 00H                   |
| FF01H   | Port 1                                          | P1      |                        |     |       |                         | -            |                       |
| FF02H   | Port 2                                          | P2      |                        |     |       |                         | -            |                       |
| FF03H   | Port 3                                          | P3      |                        |     |       |                         | -            |                       |
| FF04H   | Port 4                                          | P4      |                        | R   |       |                         | -            |                       |
| FF07H   | Port 7                                          | P7      |                        | R/W |       |                         | -            |                       |
| FF10H   | Bit sequential buffer 1 data register L         | BSFRL10 | BSFR10                 | W   | -     | $\checkmark$            | $\checkmark$ | Undefined             |
| FF11H   | Bit sequential buffer 1 data register H         | BSFRH10 | )                      |     | -     |                         |              |                       |
| FF12H   | 16-bit timer counter 0                          | TM0     |                        | R   | -     | -                       |              | 0000H                 |
| FF13H   |                                                 |         |                        |     |       |                         |              |                       |
| FF14H   | 16-bit timer capture/compare register 00        | CR00    |                        | R/W | -     | _                       |              |                       |
| FF15H   |                                                 |         |                        |     |       |                         |              |                       |
| FF16H   | 16-bit timer capture/compare register 01        | CR01    |                        |     | _     | _                       | $\checkmark$ |                       |
| FF17H   |                                                 |         |                        |     |       |                         |              |                       |
| FF18H   | 16-bit timer counter D                          | TMD     |                        | R   | _     | _                       | $\checkmark$ |                       |
| FF19H   |                                                 |         |                        |     |       |                         |              |                       |
| FF1AH   | 16-bit compare register D                       | CMD     |                        | R/W | _     | _                       | $\checkmark$ |                       |
| FF1BH   |                                                 |         |                        |     |       |                         |              |                       |
| FF20H   | Port mode register 0                            | PM0     |                        |     |       |                         | _            | FFH                   |
| FF21H   | Port mode register 1                            | PM1     |                        |     |       |                         | _            |                       |
| FF22H   | Port mode register 2                            | PM2     |                        |     |       |                         | _            |                       |
| FF23H   | Port mode register 3                            | PM3     |                        |     |       |                         | _            |                       |
| FF30H   | Pull-up resistor option register 0              | PUB0    |                        |     |       |                         | _            | 00H                   |
| FF31H   | Pull-up resistor option register 1              | PUB1    |                        |     |       |                         | _            |                       |
| FF32H   | Pull-up resistor option register 2              | PUB2    |                        |     |       |                         | _            |                       |
| FF33H   | Pull-up resistor option register 3              | PUB3    |                        |     |       |                         | _            |                       |
| FF42H   | Watchdog timer clock select register            | WDCS    |                        |     | _     |                         | _            |                       |
| FF50H   | 8-bit timer counter 5                           | TM5     |                        | R   | _     |                         | _            |                       |
| FF51H   | 8-bit timer compare register 5                  | CR5     |                        | R/W | _     |                         | _            |                       |
| FF52H   | Timer clock select register 5                   | TCL5    |                        |     | _     |                         | _            |                       |
| FF53H   | 8-bit timer mode control register 5             | TMC5    |                        |     |       |                         | _            |                       |
| FF5CH   | 16-bit timer mode control register D            | TMCD    |                        |     |       |                         | _            |                       |
| FF60H   | Bit sequential buffer 1 output control register | BSF1C   |                        |     |       |                         | _            |                       |
| FF70H   | Asynchronous serial interface mode register 2   | ASIM2   |                        |     |       |                         | _            |                       |
| FF71H   | Asynchronous serial interface status register 2 | ASIS2   |                        | R   |       |                         | _            |                       |
| FF72H   | Serial operating mode register 2                | CSIM2   |                        | R/W |       |                         | _            |                       |
| FF73H   | Baud rate generator control register 2          | BRGC2   |                        |     | -     |                         | _            |                       |
| FF74H   | Transmit shift register 2                       | TXS2    | SIO2 <sup>Note 1</sup> | W   | _     |                         | _            | FFH                   |
|         | Receive buffer register 2                       | RXB2    |                        | R   | -     |                         | _            | Undefined             |
| FF80H   | Power-on-clear register                         | POCF    | 1                      | R/W |       |                         | <u> </u>     | 00H <sup>Note 2</sup> |

| Table 3-3. | Special | Function  | Registers | (1/2) | ۱ |
|------------|---------|-----------|-----------|-------|---|
|            | opeciai | i unction | Registers | (1/2) | 1 |

**Notes 1.** The SIO2 register can be read and written.

2. This value is 04H only after a power-on-clear reset.

| Address | Special Function Register (SFR) Name              | Symbol | R/W |              | of Bits Ma<br>nultaneou | •       | After Reset           |
|---------|---------------------------------------------------|--------|-----|--------------|-------------------------|---------|-----------------------|
|         |                                                   |        |     | 1 Bit        | 8 Bits                  | 16 Bits |                       |
| FF81H   | Low-voltage detection register                    | LVIF   | R/W | $\checkmark$ | $\checkmark$            | -       | 00H                   |
| FF82H   | Low-voltage detection level selection register    | LVIS   |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FF90H   | Key return edge detection register                | EDG    |     | $\checkmark$ | $\checkmark$            | -       | Note 1                |
| FFA6H   | 16-bit timer mode control register 0              | TMC0   |     | $\checkmark$ | $\checkmark$            | -       | 00H                   |
| FFA7H   | Prescaler mode register 0                         | PRM0   |     | -            | $\checkmark$            | -       |                       |
| FFA8H   | Capture/compare control register 0                | CRC0   |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FFA9H   | 16-bit timer output control register 0            | TOC0   |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FFD7H   | 8-bit timer mode control register 80              | TMC80  |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FFD8H   | 8-bit timer compare register 80                   | CR80   | W   | -            | $\checkmark$            | -       | Undefined             |
| FFD9H   | 8-bit timer counter 80                            | TM80   | R   | -            | $\checkmark$            | -       | 00H                   |
| FFDCH   | EEPROM write control register 10                  | EEWC10 | R/W | $\checkmark$ | $\checkmark$            | -       | 08H <sup>Note 2</sup> |
| FFE0H   | Interrupt request flag register 0                 | IF0    |     | $\checkmark$ | $\checkmark$            | _       | 00H                   |
| FFE1H   | Interrupt request flag register 1                 | IF1    |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FFE4H   | Interrupt mask flag register 0                    | MK0    |     | $\checkmark$ | $\checkmark$            | -       | FFH                   |
| FFE5H   | Interrupt mask flag register 1                    | MK1    |     | $\checkmark$ | $\checkmark$            | -       |                       |
| FFECH   | External interrupt mode register 0                | INTM0  |     | -            | $\checkmark$            | -       | 00H                   |
| FFF9H   | Watchdog timer mode register                      | WDTM   |     | $\checkmark$ | $\checkmark$            | _       |                       |
| FFFAH   | Oscillation stabilization time selection register | OSTS   | 7   | -            | $\checkmark$            | -       | 04H                   |
| FFFBH   | Processor clock control register                  | PCC    | 7   | $\checkmark$ | $\checkmark$            | -       | 02H                   |

Table 3-3. Special Function Registers (2/2)

**Notes 1.** The value is 1000000XB after a key return reset (bit 0 retains the value before the key return reset), and 00H after other resets.

2. The default value of bit 7 (EEWEM10) depends on the condition of the EEWE pin.

#### 3.3 Instruction Address Addressing

An instruction address is determined by the program counter (PC) contents. The PC contents are 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 address information is set to the PC and branched by the following types of addressing (for details of each instruction, refer to **78K/0S Series Instructions User's Manual (U11047E)**).

#### 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 the sign bit. In other words, the range of branch in relative addressing is between -128 and +127 of the start address of the following instruction.

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

#### [Illustration]



When S = 0,  $\alpha$  indicates that all bits are 0. When S = 1,  $\alpha$  indicates that all bits 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 and BR !addr16 instructions are executed. CALL !addr16 and BR !addr16 instructions can be used to branch to all the memory spaces.

#### [Illustration]

In case of CALL !addr16 and BR !addr16 instructions



#### 3.3.3 Table indirect addressing

# [Function]

The table contents (branch destination address) of the particular location to be addressed by the immediate data of an instruction code from bit 1 to bit 5 are transferred to the program counter (PC) and branched. Table indirect addressing is carried out when the CALLT [addr5] instruction is executed. This instruction can be used to branch to all the memory spaces according to the address stored in the memory table 40H to 7FH.

#### [Illustration]



#### 3.3.4 Register addressing

#### [Function]

The 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 (addressing) are available to specify the register and memory to undergo manipulation during instruction execution.

# 3.4.1 Direct addressing

#### [Function]

The memory indicated by immediate data in an instruction word is directly addressed.

#### [Operand format]

| Identifier | Description                    |
|------------|--------------------------------|
| addr16     | Label or 16-bit immediate data |

# [Description example]

MOV A, !FE00H; When setting !addr16 to FE00H



# [Illustration]



# 3.4.2 Short direct addressing

# [Function]

The memory to be manipulated in the fixed space is directly addressed with the 8-bit data in an instruction word. The fixed space where this addressing is applied is the 256-byte space FE20H to FF1FH. An internal high-speed RAM is mapped at FE20H to FEFFH and the special function registers (SFR) are mapped at FF00H to FF1FH.

The SFR area where short direct addressing is applied (FF00H to FF1FH) is a part of the total SFR area. In this area, ports which are frequently accessed in a program and a compare register of the timer counter are mapped, and these SFRs can 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. See **[Illustration]** 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 FE90H, #50H; When setting saddr to FE90H and the 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.3 Special function register (SFR) addressing

# [Function]

A memory-mapped special function register (SFR) is addressed with the 8-bit immediate data in an instruction word.

This addressing is applied to the 256-byte space FF00H to FFFFH. However, SFRs mapped at FF00H to FF1FH can also be accessed with short direct addressing.

#### [Operand format]

| Identifier | Description                    |
|------------|--------------------------------|
| sfr        | Special function register name |

#### [Description example]

MOV PM0, A; When selecting PM0 for sfr



# [Illustration]



# 3.4.4 Register addressing

# [Function]

A general-purpose register is accessed as an operand.

The general-purpose register to be accessed is specified with the register specify code and functional name in the instruction 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 instruction 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 with 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 the C register for r



INCW DE; When selecting the DE register pair for rp



#### 3.4.5 Register indirect addressing

# [Function]

The memory is addressed with the contents of the register pair specified as an operand. The register pair to be accessed is specified with the register pair specify code in the instruction code. This addressing can be carried out for all the memory spaces.

# [Operand format]

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

# [Description example]

MOV A, [DE]; When selecting register pair [DE]

Instruction code 0 0 1 0 1 0 1 1

# [Illustration]



#### 3.4.6 Based addressing

# [Function]

8-bit immediate data is added to the contents of the base register, that is, the HL register pair, 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.7 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/restored upon interrupt request generation. Stack addressing can be used to access the internal high-speed RAM area only.

#### [Description example]

In the case of PUSH DE



# CHAPTER 4 EEPROM (DATA MEMORY)

#### 4.1 Memory Space

Besides internal high-speed RAM, the  $\mu$ PD789862 Subseries has 256 × 8 bits of electrically erasable PROM (EEPROM) on-chip as data memory.

Unlike normal RAM, EEPROM can maintain its contents even if its power supply is cut. In addition, unlike EPROM, its contents can be erased electrically.

#### 4.2 EEPROM Configuration

EEPROM consists of the EEPROM itself and a control block.

The control block consists of EEPROM write control register 10 (EEWC10) which controls EEPROM writing and a part that detects the termination of writing and generates an interrupt request signal (INTEE0).

Also, 8-bit timer 80 is provided as a timer dedicated to writing EEPROM. For details, refer to **4.4 8-Bit Timer 80**. The block diagrams of EEPROM and 8-bit timer 80 are shown in Figures 4-1 and 4-2, respectively.



#### Figure 4-1. EEPROM Block Diagram

Caution When the status of the EEWE pin is low level, writing to EEPROM area 2 (64 bytes) is disabled. Only reading is enabled. If writing to EEPROM area 2 (64 bytes) is executed when the EEWE pin is low level, the instruction is ignored.

Writing to EEPROM area 2 (64 bytes) is enabled only when the status of the EEWE pin is high level. EEPROM area 1 (192 bytes) can be read/written independently of the status of the EEWE pin.

Keep the EEWE pin high level while EEPROM area 2 (64 bytes) is being written. If the EEWE pin changes to low level during writing, the EEPROM cell value of the address will be undefined.



Figure 4-2. Block Diagram of 8-Bit Timer 80

# 4.3 EEPROM Control Register

EEPROM is controlled by EEPROM write control register 10 (EEWC10).

EEWC10 is the register that sets the EEPROM count clock selection and EEPROM write control.

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

RESET input sets this register to 08H.

Figure 4-3 shows the format of EEPROM write control register 10. Table 4-1 shows the EEPROM write time.

# Figure 4-3. Format of EEPROM Write Control Register 10

| Symbol | 7       | 6       | 5       | 4       | 3 | <2>   | <1>    | <0>   | Address | After reset           | R/W            |
|--------|---------|---------|---------|---------|---|-------|--------|-------|---------|-----------------------|----------------|
| EEWC10 | EEWEM10 | EWCS102 | EWCS101 | EWCS100 | 1 | ERE10 | EWST10 | EWE10 | FFDCH   | 08H <sup>Note 1</sup> | $R/W^{Note 2}$ |

| EWCS102          | EWCS101 | EWCS100 | EEF                      | PROM timer count clock selec      | tion                              |
|------------------|---------|---------|--------------------------|-----------------------------------|-----------------------------------|
|                  |         |         |                          | When operating at<br>fx = 5.0 MHz | When operating at<br>fx = 3.0 MHz |
| 1                | 0       | 0       | fx/2 <sup>7</sup>        | 39.1 kHz                          | 23.4 kHz                          |
| 1                | 1       | 1       | Output of 8-bit timer 80 |                                   |                                   |
| Other than above |         |         | Setting prohibited       |                                   |                                   |

| ERE10 | EWE10 | Write              | Read     | Remarks                                                 |
|-------|-------|--------------------|----------|---------------------------------------------------------|
| 0     | 0     | Disabled           | Disabled | EEPROM is in standby state (low power consumption mode) |
| 0     | 1     | Setting prohibited |          |                                                         |
| 1     | 0     | Disabled           | Enabled  |                                                         |
| 1     | 1     | Enabled            | Enabled  |                                                         |

| EWST10 | EEPROM write status flag                                                                          |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0      | Not writing to EEPROM (EEPROM can be read or written. However, writing is disabled if EWE10 = 0.) |  |  |  |  |  |  |
| 1      | Writing to EEPROM (EEPROM cannot be read or written.)                                             |  |  |  |  |  |  |

| EEWEM10 | A10 EEWE pin status flag                                     |  |  |  |  |
|---------|--------------------------------------------------------------|--|--|--|--|
| 0       | Low level (Writing to EEPROM area 2 (64 bytes) is disabled.) |  |  |  |  |
| 1       | High level (Writing to EEPROM area 2 (64 bytes) is enabled.) |  |  |  |  |

Notes 1. The initial value of bit 7 (EEWEM10) depends on the status of the EEWE pin.

2. Bits 1 and 7 are read only.

Caution Be sure to set bit 3 to 1.

**Remark** fx: System clock oscillation frequency

| EWCS102      | EWCS101 | EWCS100 | EEPROM Timer Count Clock |                                         |                                         | EEPROM Data Write Time <sup>Note</sup> |                                         |                                         |
|--------------|---------|---------|--------------------------|-----------------------------------------|-----------------------------------------|----------------------------------------|-----------------------------------------|-----------------------------------------|
|              |         |         |                          | When<br>operating<br>at fx = 5.0<br>MHz | When<br>operating<br>at fx = 3.0<br>MHz |                                        | When<br>operating<br>at fx = 5.0<br>MHz | When<br>operating<br>at fx = 3.0<br>MHz |
| 1            | 0       | 0       | fx/27                    | 39.1 kHz                                | 23.4 kHz                                | $2^7/f_X 	imes 145$                    | 3.71 ms                                 | 6.18 ms                                 |
| 1            | 1       | 0       | Output of 8-bit timer 80 |                                         |                                         | Output of 8-bit timer $80 \times 145$  |                                         |                                         |
| Other than a | bove    |         | Setting prohil           | bited                                   |                                         |                                        |                                         |                                         |

Table 4-1. EEPROM Write Time

**Note** Be sure to set the EEPROM write time within the range of 3.3 to 6.6 ms.

**Remark** fx: System clock oscillation frequency

 $\star$ 

# 4.4 8-Bit Timer 80

#### 4.4.1 Configuration of 8-bit timer 80

8-bit timer 80 includes the following hardware.

| Item             | Configuration                                |
|------------------|----------------------------------------------|
| Timer counter    | 8 bits × 1 (TM80)                            |
| Register         | Compare register: 8 bits $\times$ 1 (CR80)   |
| Control register | 8-bit timer mode control register 80 (TMC80) |

#### Table 4-2. Configuration of 8-Bit Timer 80

# (1) 8-bit timer compare register 80 (CR80)

This is an 8-bit register that compares the value set to CR80 with the 8-bit timer counter 80 (TM80) count value, and if they match, generates the inverted signal of the TO80 F/F.

CR80 is set by an 8-bit memory manipulation instruction. The values 00H to FFH can be set. RESET input makes CR80 undefined.

# Caution When rewriting CR80 in timer counter operation mode, be sure to stop the timer operation beforehand. If CR80 is rewritten in the timer operation-enabled state, a match interrupt request signal may occur at the moment of rewrite.

#### (2) 8-bit timer counter 80 (TM80)

This is an 8-bit register used to count count pulses. TM80 is read with an 8-bit memory manipulation instruction. RESET input clears TM80 to 00H.

#### 4.4.2 Control registers of 8-bit timer 80

The following register is used to control 8-bit timer 80.

• 8-bit timer mode control register 80 (TMC80)

#### (1) 8-bit timer mode control register 80 (TMC80)

This register controls enabling/stopping the operation of 8-bit timer counter 80 (TM80), and sets the counter clock of TM80.

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

RESET input clears TMC80 to 00H.

# Figure 4-4. Format of 8-Bit Timer Mode Control Register 80

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2      | 1      | 0 | Address | After reset | R/W |
|--------|-------|---|---|---|---|--------|--------|---|---------|-------------|-----|
| TMC80  | TCE80 | 0 | 0 | 0 | 0 | TCL801 | TCL800 | 0 | FFD7H   | 00H         | R/W |

| TCE8                                    | 8-bit timer counter 80 operation control |  |
|-----------------------------------------|------------------------------------------|--|
| 0 Operation stopped (TM80 cleared to 0) |                                          |  |
| 1                                       | Operation enabled                        |  |

| TCL801 | TCL800 | 8-bit timer counter 80 count clock selection |
|--------|--------|----------------------------------------------|
| 0      | 0      | fx                                           |
| 0      | 1      | fx/2                                         |
| 1      | 0      | fx/2 <sup>2</sup>                            |
| 1      | 1      | Setting prohibited                           |

#### Cautions 1. Be sure to set TMC80 after stopping timer operation.

2. Bits 0 and 3 to 6 must be set to 0.

Remark fx: System clock oscillation frequency

# 4.5 Notes for EEPROM Writing

The following caution points pertain to writing to EEPROM.

- (1) When fetching an instruction from EEPROM or stopping the system clock oscillator, be sure to do so after setting EEPROM to write-disabled (EWE10 = 0).
- (2) Set the count clock in a state in which the selected clock is operating (oscillating). If the selected count clock is stopped, there is no transition to the state in which writing is possible even if the clock operation is subsequently started and EEPROM is set to write-enabled (EWE10 = 1).
- (3) Be sure to set the EEPROM write time within the range of 3.3 to 6.6 ms.

| Example | When setting the write time to | EEPROM to 3.4 ms using 8-bit timer 80 (Condition: fx = 4 MHz)     |
|---------|--------------------------------|-------------------------------------------------------------------|
|         | MOV TMC80,#00H                 | ; Set count clock = fx                                            |
|         | MOV CR80,#2EH                  | ; TM80 cycle = 1/4 MHz $\times$ 47 = 11.75 $\mu$ s                |
|         |                                | The clock to EEPROM is double that of the TM80 cycle (flip-flop   |
|         |                                | output). Therefore, the count clock to the EEPROM timer = 11.75   |
|         |                                | $\mu$ s × 2 = 23.5 $\mu$ s                                        |
|         | MOV EEWC10,#01101000B          | ; Write time to EEPROM = 23.5 $\mu$ s $\times$ 145 $\cong$ 3.4 ms |
|         |                                |                                                                   |

- (4) When setting ERE10 and EWE10, be sure to use the following procedure. If you set these using other than the following procedure, there is no transition to the state in which writing to EEPROM is possible.
  - <1> Set ERE10 to 1 (In a state in which EWE10 = 0)
  - <2> Set EWE10 to 1 (In a state in which ERE10 = 1)
  - <3> Wait 1 ms or more using software
  - <4> Shift to state in which writing to EEPROM is possible



- A (ERE10 = 1): Transition to state in which reading is possible
- B (EWE10 = 1): Set count clock before this point.
- C: Transition to state in which writing is possible
- D: When ERE10 is cleared (ERE10 = 0), EWE10 is also cleared (EWE10 = 0). Reading or writing is not possible in this state.

- (5) When writing to EEPROM, write after confirming that EWST10 = 0.If EEPROM is written when EWST10 = 1, the instruction is ignored.
- (6) Do not execute the following operations while writing to EEPROM, as execution will cause the EEPROM cell value at that address to become undefined.
  - Turn off the power
  - Execute a reset
  - Set ERE10 to 0
  - Set EWE10 to 0
  - Switch the EEPROM timer count clock
- (7) Do not execute the following operation while writing to EEPROM after selecting system clock division for the EEPROM timer count clock, as execution will cause the EEPROM cell value at that address to become undefined.
  - Execute a STOP instruction
- (8) Do not execute the following operations while writing to EEPROM after selecting 8-bit timer 80 output for the EEPROM timer count clock, as execution will cause the EEPROM cell value at that address to become undefined.
  - Execute a STOP instruction
  - Stop 8-bit timer 80 timer output
  - Stop 8-bit timer 80 operation
- (9) Do not execute the following operations while writing to or reading from EEPROM, as execution will cause the EEPROM data read next to become undefined, and a CPU inadvertent program loop could result.
  - Set ERE10 to 0
  - Execute a write to EEPROM
- (10) When not writing to or reading from EEPROM, it is possible to enter low-power-consumption mode by setting ERE10 to 0. In the ERE10 = 1 state, a current of about 0.27 mA (V<sub>DD</sub> = 3.6 V) is always flowing. If an instruction to read from EEPROM is then executed, a further 0.9 mA current will flow, increasing the total current flow at this time to approximately 1.17 mA (V<sub>DD</sub> = 3.6 V).

In the ERE10 = 1, EWE10 = 1 state, a current of about 0.3 mA ( $V_{DD}$  = 3.6 V) is always flowing. If an instruction to write to EEPROM is then executed, a further 0.7 mA current will flow, and if an instruction to read from EEPROM is executed, a further 0.9 mA current will flow, increasing the total current flow at this time to approximately 1.0 mA ( $V_{DD}$  = 3.6 V) for the former case and 1.2 mA ( $V_{DD}$  = 3.6 V) for the latter.

(11) Execution of a STOP instruction causes an automatic change to low-power-consumption mode, regardless of the ERE10 and EWE10 settings. The states of ERE10 and EWE10 at that time are maintained. During the wait time following STOP mode release, a current of approximately 300  $\mu$ A (V<sub>DD</sub> = 3.6 V) flows. Executing a HALT instruction does not change the mode to low-power-consumption mode.

(12) When the status of the EEWE pin is low level, writing to EEPROM area 2 (64 bytes) is disabled. Only reading is enabled. If writing to EEPROM area 2 (64 bytes) is executed when the EEWE pin is low level, the instruction is ignored.

Writing to EEPROM area 2 (64 bytes) is enabled only when the status of the EEWE pin is high level. EEPROM area 1 (192 bytes) can be read/written independently of the status of the EEWE pin.

Keep the EEWE pin high level while EEPROM area 2 (64 bytes) is being written. If the EEWE pin changes to low level during writing, the EEPROM cell value of the address will be undefined.

# **CHAPTER 5 PORT FUNCTIONS**

# 5.1 Functions of Ports

The  $\mu$ PD789862 Subseries provides the ports shown in Figure 5-1, enabling various methods of control.

Numerous other functions are provided that can be used in addition to the digital I/O port function. For more information on these additional functions, refer to **CHAPTER 2 PIN FUNCTIONS**.



Figure 5-1. Port Types

# Table 5-1. Port Functions

| Pin Name   | I/O    | Function                                                                                                                                                                                                  | After Reset | Alternate Function |
|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| P00 to P03 | I/O    | Port 0<br>4-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be<br>used by setting pull-up resistor option register 0 (PUB0). | Input       | _                  |
| P10, P11   | I/O    | Port 1<br>2-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be<br>used by setting pull-up resistor option register 1 (PUB1). | Input       | _                  |
| P20        | I/O    | Port 2                                                                                                                                                                                                    | Input       | BSFO0              |
| P21        |        | 5-bit I/O port (P20 and P21 are N-ch open drain I/O ports.)                                                                                                                                               |             | BSFO1              |
| P22        |        | Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be                                                                                           |             | TI50/TO50          |
| P23        |        | used by setting pull-up resistor option register 2 (PUB2).                                                                                                                                                |             | TI00/TO0           |
| P24        |        |                                                                                                                                                                                                           |             | TI01/INTP0         |
| P30        | I/O    | Port 3                                                                                                                                                                                                    | Input       | SCK2/ASCK2         |
| P31        |        | 4-bit I/O port                                                                                                                                                                                            |             | TxD2/SO2           |
| P32        |        | Input/output can be specified in 1-bit units.<br>When used as an input port, an on-chip pull-up resistor can be                                                                                           |             | RxD2/SI2           |
| P33        |        | used by setting pull-up resistor option register 3 (PUB3).                                                                                                                                                |             | INTP1              |
| P40 to P45 | Input  | Port 4<br>6-bit input-only port<br>On-chip pull-up resistor                                                                                                                                               | Input       | KR0 to KR5         |
| P70        | Output | Port 7<br>1-bit output-only port                                                                                                                                                                          | Output      | RESOUT             |

# 5.2 Port Configuration

A port includes the following hardware.

|                   | 5                                                                                           |
|-------------------|---------------------------------------------------------------------------------------------|
| ltem              | Configuration                                                                               |
| Control registers | Port mode register (PMm: m = 0 to 3)<br>Pull-up resistor option register (PUBm: m = 0 to 3) |
| Ports             | Total: 22 (input: 6, output: 1, I/O: 15)                                                    |
| Pull-up resistors | Total: 15 (software control only)                                                           |

#### Table 5-2. Configuration of Port

# 5.2.1 Port 0

This is a 4-bit I/O port with output latches. Port 0 can be specified as an input or output port in 1-bit units by using port mode register 0 (PM0). When pins P00 to P03 are used as input port pins, on-chip pull-up resistors can be connected in 4-bit units by using pull-up resistor option register 0 (PUB0).

RESET input sets port 0 to input mode.

Figure 5-2 shows the block diagram of port 0.





PUB0: Pull-up resistor option register 0

- PM: Port mode register
- RD: Port 0 read signal
- WR: Port 0 write signal

## 5.2.2 Port 1

This is a 2-bit I/O port with output latches. Port 1 can be specified as an input or output port in 1-bit units by using port mode register 1 (PM1). When pins P10 and P11 are used as input port pins, on-chip pull-up resistors can be connected in 2-bit units by using pull-up resistor option register 1 (PUB1).

RESET input sets port 1 to input mode.

Figure 5-3 shows the block diagram of port 1.

#### Figure 5-3. Block Diagram of P10 and P11



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

# 5.2.3 Port 2

This is a 5-bit I/O port with output latches. P20 and P21 are N-ch open drain I/O port pins. Port 2 can be specified as an input or output port in 1-bit units by using port mode register 2 (PM2). When pins P20 to P24 are used as input port pins, use of on-chip pull-up resistors can be specified in 1-bit units by using pull-up resistor option register 2 (PUB2).

The port is also used for timer I/O, external interrupt input, and bit sequential buffer output.

RESET input sets port 2 to input mode.

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





| ter 2 |
|-------|
|       |

- PM: Port mode register
- RD: Port 2 read signal
- WR: Port 2 write signal



Figure 5-5. Block Diagram of P22 and P23

- PUB2: Pull-up resistor option register 2
- PM: Port mode register
- RD: Port 2 read signal
- WR: Port 2 write signal

Figure 5-6. Block Diagram of P24



- PUB2: Pull-up resistor option register 2
- PM: Port mode register
- RD: Port 2 read signal
- WR: Port 2 write signal

## 5.2.4 Port 3

This is a 4-bit I/O port with output latches. Port 3 can be specified as an input or output port in 1-bit units by using port mode register 3 (PM3). Use of on-chip pull-up resistors can be specified for pins P30 to P33 in 1-bit units by using pull-up resistor option register 3 (PUB3).

The port is also used for serial interface I/O, clock I/O, and external interrupt input.

RESET input sets port 3 to input mode.

Figures 5-7 to 5-9 show block diagrams of port 3.

Caution When using the pins of port 3 for the serial interface, the I/O or output latch must be set according to the function to be used. For how to set the latches, see Table 11-2 Operation Mode Settings for Serial Interface 2.





| PUB3: Pull-up resistor option regist |
|--------------------------------------|
|--------------------------------------|

- PM: Port mode register
- RD: Port 3 read signal
- WR: Port 3 write signal

Figure 5-8. Block Diagram of P31



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



Figure 5-9. Block Diagram of P32 and P33

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

# 5.2.5 Port 4

This is a 6-bit input port. It incorporates a pull-up resistor.

The port is also used for key return input.

RESET input sets port 4 to input mode.

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

# Figure 5-10. Block Diagram of P40 to P45



RD: Port 4 read signal

# 5.2.6 Port 7

This is a 1-bit output port.

This port is also used for reset output.

RESET input sets port 7 to output mode.

When read, the value of the output latch can be read.

Figure 5-11 shows a block diagram of port 7.





- RD: Port 7 read signal
- WR: Port 7 write signal

# 5.3 Port Function Control Registers

The following two types of registers control the ports.

- Port mode registers (PM0 to PM3)
- Pull-up resistor option registers (PUB0 to PUB3)

## (1) Port mode registers (PM0 to PM3)

These registers are used to set port input/output in 1-bit units. Port mode registers are independently 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 according to Table 5-3.

Caution As ports 2 and 3 have an alternate function as external interrupt inputs, when the port function output mode is specified and the output level is changed, the interrupt request flag is set. When the output mode is used, therefore, the interrupt mask flag should be set to 1 beforehand.

| Pin Name | Alternate Function |        | PM×× | P×× |
|----------|--------------------|--------|------|-----|
|          | Name               | I/O    |      |     |
| P20      | BSFO0              | Output | 0    | 0   |
| P21      | BSFO1              | Output | 0    | 0   |
| P22      | TI50               | Input  | 1    | ×   |
|          | TO50               | Output | 0    | 0   |
| P23      | ТІОО               | Input  | 1    | ×   |
|          | ТОО                | Output | 0    | 0   |
| P24      | TI01               | Input  | 1    | ×   |
|          | INTP0              | Input  | 1    | ×   |
| P33      | INTP1              | Input  | 1    | ×   |

Caution When port 3 is used for the serial interface, the I/O latch or output latch must be set according to its function. For the setting method, refer to Table 11-2 Operation Mode Settings for Serial Interface 2.

 Remark
 ×:
 Don't care

 PM××:
 Port mode register

 P××:
 Port output latch

| Symbol | 7        | 6     | 5      | 4        | 3        | 2      | 1      | 0        | Address           | After reset   | R/W |  |
|--------|----------|-------|--------|----------|----------|--------|--------|----------|-------------------|---------------|-----|--|
| PM0    | 1        | 1     | 1      | 1        | PM03     | PM02   | PM01   | PM00     | FF20H             | FFH           | R/W |  |
|        |          |       |        |          |          |        |        |          |                   |               |     |  |
| PM1    | 1        | 1     | 1      | 1        | 1        | 1      | PM11   | PM10     | FF21H             | FFH           | R/W |  |
|        |          |       |        |          |          |        |        |          |                   |               |     |  |
| PM2    | 1        | 1     | 1      | PM24     | PM23     | PM22   | PM21   | PM20     | FF22H             | FFH           | R/W |  |
|        | <u> </u> |       |        |          |          |        |        |          |                   |               |     |  |
| PM3    | 1        | 1     | 1      | 1        | PM33     | PM32   | PM31   | PM30     | FF23H             | FFH           | R/W |  |
|        |          |       |        |          |          |        |        |          |                   |               |     |  |
|        | PMmn     |       |        |          | P        | mn pin | I/O mo | de seleo | ction (m = 0 to 3 | , n = 0 to 7) |     |  |
|        | 0        | Outpu | t mode | e (outpu | t buffer | on)    |        |          |                   |               |     |  |
|        |          |       |        |          |          |        |        |          |                   |               |     |  |

### Figure 5-12. Port Mode Register Format

#### (2) Pull-up resistor option registers (PUBm: m = 0 to 3)

Input mode (output buffer off)

The pull-up resistor option registers (PUBm) set whether to use on-chip pull-up resistors at each port or not. At a port where use of on-chip pull-up resistors has been specified by PUBm, the pull-up resistors can be internally used only for the bits set to input mode. No on-chip pull-up resistors can be used for the bits set to output mode, in spite of the setting of PUBm. On-chip pull-up resistors can also not be used when the pins are used as the alternate-function output pins.

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

RESET input clears PUBm to 00H.

1

| Symbol | 7 | 6 | 5 | 4     | <3>   | <2>   | <1>   | <0>   | Address | After reset | R/W |
|--------|---|---|---|-------|-------|-------|-------|-------|---------|-------------|-----|
| PUB0   | 0 | 0 | 0 | 0     | PUB03 | PUB02 | PUB01 | PUB00 | FF30H   | 00H         | R/W |
|        | 7 | 6 | 5 | 4     | 3     | 2     | <1>   | <0>   |         |             |     |
| PUB1   | 0 | 0 | 0 | 0     | 0     | 0     | PUB11 | PUB10 | FF31H   | 00H         | R/W |
|        | 7 | 6 | 5 | <4>   | <3>   | <2>   | <1>   | <0>   |         |             |     |
| PUB2   | 0 | 0 | 0 | PUB24 | PUB23 | PUB22 | PUB21 | PUB20 | FF32H   | 00H         | R/W |
| _      | 7 | 6 | 5 | 4     | <3>   | <2>   | <1>   | <0>   |         |             |     |
| PUB3   | 0 | 0 | 0 | 0     | PUB33 | PUB32 | PUB31 | PUB30 | FF33H   | 00H         | R/W |

#### Figure 5-13. Format of Pull-Up Resistor Option Register

| PUBm | Pm on-chip pull-up resistor selection (m = 0 to 3) |  |  |  |  |  |
|------|----------------------------------------------------|--|--|--|--|--|
| 0    | On-chip pull-up resistor not used                  |  |  |  |  |  |
| 1    | On-chip pull-up resistor used                      |  |  |  |  |  |

# 5.4 Operation of Port Functions

The operation of a port differs depending on whether the port is set to input or output mode, as described below.

## 5.4.1 Writing to I/O port

#### (1) In output mode

A value can be written to the output latch by using a transfer instruction. The contents of the output latch can be output from the pins of the port.

The data once written to the output latch is retained until new data is written to the output latch.

## (2) In input mode

A value can be written to the output latch by using a transfer instruction. However, the status of the port pin is not changed because the output buffer is off.

The data once written to the output latch is retained until new data is written to the output latch.

Caution A 1-bit memory manipulation instruction is executed to manipulate 1 bit of a port. However, this instruction accesses the port in 8-bit units. When this instruction is executed to manipulate a bit of an input/output port, therefore, the contents of the output latch of the pin that is set in the input mode and not subject to manipulation become undefined.

## 5.4.2 Reading from I/O port

#### (1) In output mode

The contents of the output latch can be read by using a transfer instruction. The contents of the output latch are not changed.

#### (2) In input mode

The status of a pin can be read by using a transfer instruction. The contents of the output latch are not changed.

#### 5.4.3 Arithmetic operation of I/O port

#### (1) In output mode

An arithmetic operation can be performed with the contents of the output latch. The result of the operation is written to the output latch. The contents of the output latch are output from the port pins. The data once written to the output latch is retained until new data is written to the output latch.

## (2) In input mode

The contents of the output latch become undefined. However, the status of the pin is not changed because the output buffer is off.

Caution A 1-bit memory manipulation instruction is executed to manipulate 1 bit of a port. However, this instruction accesses the port in 8-bit units. When this instruction is executed to manipulate a bit of an input/output port, therefore, the contents of the output latch of the pin that is set in the input mode and not subject to manipulation become undefined.

# CHAPTER 6 CLOCK GENERATOR

# 6.1 Clock Generator Functions

The clock generator generates the clock to be supplied to the CPU and peripheral hardware. The following type of system clock oscillator is used.

System clock (crystal/ceramic) oscillator
 This circuit oscillates at 1.0 to 5.0 MHz. Oscillation can be stopped by executing the STOP instruction.

## 6.2 Clock Generator Configuration

The clock generator includes the following hardware.

#### Table 6-1. Configuration of Clock Generator

| Item             | Configuration                          |
|------------------|----------------------------------------|
| Control register | Processor clock control register (PCC) |
| Oscillator       | Crystal/ceramic oscillator             |





# 6.3 Clock Generator Control Register

The clock generator is controlled by the following register.

- Processor clock control register (PCC)
- Processor clock control register (PCC)
   PCC selects the CPU clock and the division ratio.
   PCC is set by a 1-bit or 8-bit memory manipulation instruction.
   RESET input sets PCC to 02H.

# Figure 6-2. Format of Processor Clock Control Register

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    | Address | After reset | R/W |
|--------|---|---|---|---|---|---|------|------|---------|-------------|-----|
| PCC    | 0 | 0 | 0 | 0 | 0 | 0 | PCC1 | PCC0 | FFFBH   | 02H         | R/W |

| PCC1 | PCC0 | CPU clock (fcpu) selection | Minimum instruction execution time: 2/fcpu |
|------|------|----------------------------|--------------------------------------------|
|      |      |                            | fx = 5.0 MHz                               |
| 0    | 0    | fx                         | 0.4 μs                                     |
| 0    | 1    | fx/2                       | 0.8 µs                                     |
| 1    | 0    | fx/2 <sup>2</sup>          | 1.6 μs                                     |
| 1    | 1    | Setting prohibited         |                                            |

#### Caution Bits 2 to 7 must be set to 0.

**Remark** fx: System clock oscillation frequency

# 6.4 System Clock Oscillator

### 6.4.1 System clock oscillator

The system clock oscillator is oscillated by the crystal or ceramic resonator (5.0 MHz TYP.) connected across the X1 and X2 pins.

Figure 6-3 shows the external circuit of the system clock oscillator.

#### Figure 6-3. External Circuit of System Clock Oscillator

#### Crystal or ceramic oscillation



- Caution When using the system clock oscillator, wire as follows in the area enclosed by the broken lines in Figure 6-3 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.

## 6.4.2 Examples of incorrect resonator connection

Figure 6-4 shows examples of incorrect resonator connection.



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

(d) Current flowing through ground line of oscillator (potential at points A, B, and C fluctuates)

(b) Crossed signal line

X1

Vss

7/7

 $\begin{array}{l} PORTn \\ (n = 0 \text{ to } 4, 7) \end{array}$ 

X2



(c) Wiring near high fluctuating current



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





# 6.4.3 Frequency divider

The frequency divider divides the system clock oscillator output (fx) and generates clocks.

## 6.5 Clock Generator Operation

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

- System clock fx
- CPU clock fcpu
- Clock to peripheral hardware

The operation of the clock generator is determined by the processor clock control register (PCC) as follows.

- (a) The slow mode (1.6  $\mu$ s: at 5.0 MHz operation) of the system clock is selected when the RESET signal is generated (PCC = 02H). While a low level is being input to the RESET pin, oscillation of the system clock is stopped.
- (b) Three types of minimum instruction execution time (0.4  $\mu$ s, 0.8  $\mu$ s, 1.6  $\mu$ s: at 5.0 MHz operation) can be selected by the PCC setting.
- (c) Two standby modes, STOP and HALT, can be used.
- (d) The clock for the peripheral hardware is generated by dividing the frequency of the system clock. Therefore, the peripheral hardware stops when the system clock stops (except for an externally input clock).

## 6.6 Changing Setting of CPU Clock

#### 6.6.1 Time required for switching CPU clock

The CPU clock can be selected by using bits 0 and 1 (PCC0 and PCC1) of the processor clock control register (PCC).

Actually, the specified clock is not selected immediately after the setting of PCC has been changed, and the old clock is used for the duration of several instructions after that (see **Table 6-2**).

| Set Value Bet | fore Switching | Set Value After Switching |      |                |      |                |      |  |  |
|---------------|----------------|---------------------------|------|----------------|------|----------------|------|--|--|
| PCC1          | PCC0           | PCC1                      | PCC0 | PCC1           | PCC0 | PCC1           | PCC0 |  |  |
|               |                | 0                         | 0    | 0              | 1    | 1              | 0    |  |  |
| 0             | 0              |                           |      | 4 instructions |      | 4 instructions |      |  |  |
| 0             | 1              | 2 instructions            |      |                |      | 2 instructions |      |  |  |
| 1             | 0              | 1 instruction             |      | 1 instruction  |      |                |      |  |  |

Table 6-2. Maximum Time Required for Switching CPU Clock

#### 6.6.2 Switching CPU clock

The following figure illustrates how the CPU clock is switched.





<1> The CPU is reset when the RESET pin is made low on power application. The effect of resetting is released when the RESET pin is later made high, and the system clock starts oscillating. At this time, the oscillation stabilization time (2<sup>12</sup>/fx) is automatically secured.

After that, the CPU starts instruction execution at the slow speed of the system clock (1.6  $\mu$ s: @ 5.0 MHz operation).

<2> After the time required for the VDD voltage to rise to the level at which the CPU can operate at the high speed has elapsed, the processor clock control register (PCC) is rewritten so that the high-speed operation can be selected.

# CHAPTER 7 16-BIT TIMER/EVENT COUNTER 0

# 7.1 Functions of 16-Bit Timer/Event Counter 0

16-bit timer/event counter 0 has the following functions.

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

#### (1) Interval timer

16-bit timer/event counter 0 generates interrupt requests at the preset time interval.

## (2) PPG output

16-bit timer/event counter 0 can output a square wave whose frequency and output pulse can be set freely.

## (3) Pulse width measurement

16-bit timer/event counter 0 can measure the pulse width of an externally input signal.

#### (4) External event counter

16-bit timer/event counter 0 can measure the number of pulses of an externally input signal.

#### (5) Square-wave output

16-bit timer/event counter 0 can output a square wave with any selected frequency.

# 7.2 Configuration of 16-Bit Timer/Event Counter 0

16-bit timer/event counter 0 includes the following hardware.

| Item              | Configuration                                                                                                                                                                                                                                              |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer/counter     | 16 bits $\times$ 1 (TM0)                                                                                                                                                                                                                                   |
| Register          | 16-bit timer capture/compare register: 16 bits × 2 (CR00, CR01)                                                                                                                                                                                            |
| Timer output      | 1 (TO0)                                                                                                                                                                                                                                                    |
| Control registers | 16-bit timer mode control register 0 (TMC0)<br>Capture/compare control register 0 (CRC0)<br>16-bit timer output control register 0 (TOC0)<br>Prescaler mode register 0 (PRM0)<br>Port mode register 2 (PM2) <sup>Note</sup><br>Port 2 (P2) <sup>Note</sup> |

Note See Figure 5-5 Block Diagram of P22 and P23 and Figure 5-6 Block Diagram of P24.

Figure 7-1 shows a block diagram of 16-bit timer/event counter 0.





## (1) 16-bit timer counter 0 (TM0)

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

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

#### <1> At RESET input

- <2> If TMC03 and TMC02 are cleared
- <3> If the valid edge of TI00 is input in the clear & start mode entered by inputting the valid edge of TI00
- <4> If TM0 and CR00 match in the clear & start mode on a match between TM0 and CR00

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

CR00 is a 16-bit register which 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 (CRC00) of capture/compare control register 0 (CRC0).

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

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

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

It is possible to select the valid edge of the TI00/TO0/P23 pin or the TI01/P24/INTP0 pin as the capture trigger. Setting of the TI00 or TI01 valid edge is performed by means of prescaler mode register 0 (PRM0). If CR00 is specified as a capture register and capture trigger is specified to be the valid edge of the TI00/TO0/P23 pin, the situation is as shown in Table 7-2. On the other hand, when capture trigger is specified to be the valid edge of the TI01/P24/INTP0 pin, the situation is as shown in Table 7-3.

#### Table 7-2. TI00/TO0/P23 Pin Valid Edge and CR00, CR01 Capture Trigger

| ES01 | ES00 | TI00/TO0/P23 Pin Valid Edge   | TI00/TO0/P23 Pin Valid Edge CR00 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-3. TI01/P24/INTP0 Pin Valid Edge and CR00 Capture Trigger

| ES11 | ES10 | TI01/P24/INTP0 Pin Valid Edge | CR00 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 |

CR00 is set by a 16-bit memory manipulation instruction. After  $\overline{\text{RESET}}$  input, the value of CR00 is set to 0000H.

- Cautions 1. Set a value other than 0000H in CR00 in the clear & start mode entered on a match between TM0 and CR00. However, in the free-running mode and in the clear mode using the valid edge of TI00, if 0000H is set to CR00, an interrupt request (INTTM00) is generated following an overflow (FFFFH) when the value changes from 0000H to 0001H.
  - 2. When P23 is used as the input pin of the valid edge of TI00, it cannot be used as timer output (TO0). Moreover, when P23 is used as TO0, it cannot be used as the input pin of the valid edge of TI00.
  - 3. If the register read period and the input of the capture trigger conflict when CR00 is used as a capture register, the read data is undefined (the capture data itself is a normal value).

If the count stop input and capture trigger input conflict, the capture data is undefined.

4. CR00 must not be rewritten during the TM0 operation.

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

CR01 is a 16-bit register which 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 (CRC02) of capture/compare control register 0 (CRC0).

## • When CR01 is used as a compare register

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

## • When CR01 is used as a capture register

It is possible to select the valid edge of the TI00/TO0/P23 pin as the capture trigger. The TI00/TO0/P23 valid edge is set by means of prescaler mode register 0 (PRM0).

CR01 is set by a 16-bit memory manipulation instruction. After  $\overline{\text{RESET}}$  input, the value of CR01 is set to 0000H.

## Cautions 1. CR01 can be set to 0000H.

However, in the free-running mode and in the clear mode using the valid edge of TI00, if CR01 is set to 0000H, an interrupt request (INTTM01) is generated following an overflow (FFFFH) when the value changes from 0000H to 0001H.

2. If the register read period and the input of the capture trigger conflict when CR01 is used as a capture register, the read data is undefined (the capture data itself is a normal value).

If the count stop input and capture trigger input conflict, the capture data is undefined.

3. CR01 can be rewritten during the TM0 operation. For details, refer to Remark 2 in Figure 7-12.

# 7.3 Control Registers of 16-Bit Timer/Event Counter 0

The following six registers are used to control 16-bit timer/event counter 0.

- 16-bit timer mode control register 0 (TMC0)
- Capture/compare control register 0 (CRC0)
- 16-bit timer output control register 0 (TOC0)
- Prescaler mode register 0 (PRM0)
- Port mode register 2 (PM2)
- Port 2 (P2)

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

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

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

RESET input sets TMC0 value to 00H.

Caution 16-bit timer counter 0 (TM0) starts operation at the moment TMC02 and TMC03 are set to values other than 0, 0 (operation stop mode), respectively. Set TMC02 and TMC03 to 0, 0 to stop the operation.

# Figure 7-2. Format of 16-Bit Timer Mode Control Register 0 (TMC0)

| Address: FFA6H |   | 6H | After reset: 00H |   |       | R/W   |   |      |
|----------------|---|----|------------------|---|-------|-------|---|------|
| Symbol         | 7 | 6  | 5                | 4 | <3>   | <2>   | 1 | <0>  |
| TMC0           | 0 | 0  | 0                | 0 | TMC03 | TMC02 | 0 | OVF0 |

| TMC03 | TMC02 | Operation mode and<br>clear mode selection  | TO0 output timing selection                                 | Interrupt request generation                      |
|-------|-------|---------------------------------------------|-------------------------------------------------------------|---------------------------------------------------|
| 0     | 0     | Operation stop<br>(TM0 cleared to 0)        | No change                                                   | Not generated                                     |
| 0     | 1     | Free-running mode                           | Match between TM0 and CR00<br>or match between TM0 and CR01 | Generated on match between TM0 and CR00, or match |
| 1     | 0     | Clear & start on TI00 valid edge            | _                                                           | between TM0 and CR01                              |
| 1     | 1     | Clear & start on match between TM0 and CR00 | Match between TM0 and CR00<br>or match between TM0 and CR01 |                                                   |

| OVF0 | 16-bit timer counter 0 (TM0) overflow detection |
|------|-------------------------------------------------|
| 0    | Overflow not detected                           |
| 1    | Overflow detected                               |

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

- 2. Set the valid edge of the TI00/TO0/P23 pin using prescaler mode register 0 (PRM0).
- 3. If clear & start mode entered on a match between TM0 and CR00, clear & start mode entered on the valid edge of TI00, or the free-running mode is selected, when the set value of CR00 is FFFFH and the TM0 value changes from FFFFH to 0000H, the OVF0 flag is set to 1.
- 4. Bits 1 and 4 to 7 must be set to 0.
- Remarks 1. TOO: 16-bit timer/event counter 0 output pin
  - 2. TI00: 16-bit timer/event counter 0 input pin
  - **3.** TM0: 16-bit timer counter 0
  - 4. CR00: 16-bit timer capture/compare register 00
  - 5. CR01: 16-bit timer capture/compare register 01

## (2) Capture/compare control register 0 (CRC0)

This register controls the operation of the 16-bit timer capture/compare registers (CR00, CR01). CRC0 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets the CRC0 value to 00H.

#### Figure 7-3. Format of Capture/Compare Control Register 0 (CRC0)

Address: FFA8H After reset: 00H R/W

| Symbol | 7 | 6 | 5 | 4 | 3 | <2>   | <1>   | <0>   |
|--------|---|---|---|---|---|-------|-------|-------|
| CRC0   | 0 | 0 | 0 | 0 | 0 | CRC02 | CRC01 | CRC00 |

| CRC02 | CR01 operation mode selection |
|-------|-------------------------------|
| 0     | Operates as compare register  |
| 1     | Operates as capture register  |

| CRC01 | CR00 capture trigger selection                                  |  |  |
|-------|-----------------------------------------------------------------|--|--|
| 0     | Captures on valid edge of TI01                                  |  |  |
| 1     | Captures on valid edge of TI00 by reverse phase <sup>Note</sup> |  |  |

| CRC00 | CR00 operation mode selection |  |  |
|-------|-------------------------------|--|--|
| 0     | Operates as compare register  |  |  |
| 1     | Operates as capture register  |  |  |

- **Note** If both the rising and falling edges have been selected as the valid edges of TI00, CR00 does not perform capture.
- Cautions 1. Timer operation must be stopped before setting CRC0.
  - 2. When clear & start mode entered on a match between TM0 and CR00 is selected by 16bit timer mode control register 0 (TMC0), CR00 should not be specified as a capture register.
  - 3. To ensure the reliability of the capture operation, the capture trigger requires a pulse two cycles longer than the count clock selected by prescaler mode register 0 (PRM0).

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

This register controls the operation of the 16-bit timer/event counter 0 output controller. It controls R-S type flip-flop (LV0) setting/resetting, output inversion enabling/disabling, and 16-bit timer/event counter 0 timer output enabling/disabling.

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

RESET input sets TOC0 value to 00H.

Figure 7-4 shows the format of TOC0.

## Figure 7-4. Format of 16-Bit Timer Output Control Register 0 (TOC0)

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

| Symbol | 7 | 6 | 5 | <4>   | <3>  | <2>  | <1>   | <0>  |
|--------|---|---|---|-------|------|------|-------|------|
| TOC0   | 0 | 0 | 0 | TOC04 | LVS0 | LVR0 | TOC01 | TOE0 |

| TOC04 | Timer output F/F control by match of CR01 and TM0 |
|-------|---------------------------------------------------|
| 0     | Inversion operation disabled                      |
| 1     | Inversion operation enabled                       |

| LVS0 | LVR0 | 16-bit timer/event counter 0 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                                           |

| TOC01 | Timer output F/F control by match of CR00 and TM0 |
|-------|---------------------------------------------------|
| 0     | Inversion operation disabled                      |
| 1     | Inversion operation enabled                       |

| TOE0 | 16-bit timer/event counter 0 output control |
|------|---------------------------------------------|
| 0    | Output disabled (output set to level 0)     |
| 1    | Output enabled                              |

#### Cautions 1. Timer operation must be stopped before setting TOC0.

2. If LVS0 and LVR0 are read, they will be 0.

\*

3. Do not set LVS0 to 1 before setting TOE0, and do not set LVS0 and TOE0 to 1 at the same time.

### (4) Prescaler mode register 0 (PRM0)

This register is used to set the 16-bit timer counter 0 (TM0) count clock and TI00, TI01 input valid edges. PRM0 is set by an 8-bit memory manipulation instruction. RESET input sets PRM0 value to 00H.

## Figure 7-5. Format of Prescaler Mode Register 0 (PRM0)

Address: FFA7H After reset: 00H R/W

| Symbol | <7>  | <6>  | <5>  | <4>  | 3 | 2 | <1>   | <0>   |
|--------|------|------|------|------|---|---|-------|-------|
| PRM0   | ES11 | ES10 | ES01 | ES00 | 0 | 0 | PRM01 | PRM00 |

| ES11 | ES10 | TI01 valid edge selection     |
|------|------|-------------------------------|
| 0    | 0    | Falling edge                  |
| 0    | 1    | Rising edge                   |
| 1    | 0    | Setting prohibited            |
| 1    | 1    | Both falling and rising edges |

| ES01 | ES00 | TI00 valid edge selection     |
|------|------|-------------------------------|
| 0    | 0    | Falling edge                  |
| 0    | 1    | Rising edge                   |
| 1    | 0    | Setting prohibited            |
| 1    | 1    | Both falling and rising edges |

| PRM01 | PRM00 | Count clock selection           |
|-------|-------|---------------------------------|
| 0     | 0     | fx (0.2 μs)                     |
| 0     | 1     | fx/2 (0.4 μs)                   |
| 1     | 0     | fx/2 <sup>3</sup> (1.6 μs)      |
| 1     | 1     | TI00 valid edge <sup>Note</sup> |

**Note** The external clock requires a pulse two cycles longer than internal clock  $(fx/2^3)$ .

Cautions 1. Always set data to PRM0 after stopping the timer operation.

- 2. If the valid edge of TI00 is to be set for the count clock, do not set the clear & start mode and the capture trigger at the valid edge of TI00.
- 3. If the TI00 or TI01 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 TI00 pin or TI01 pin to enable the operation of the 16-bit timer counter 0 (TM0). Care is therefore needed when pulling up the TI00 pin or the TI01 pin. However, when re-enabling operation after the operation has been stopped once, the rising edge is not detected.
- 4. When P23 is used as the input pin of the valid edge of TI00, it cannot be used as timer output (TO0). Moreover, when P23 is used as TO0, it cannot be used as the input pin of the valid edge of TI00.

**Remarks 1.** fx: System clock oscillation frequency

- 2. TI00, TI01: 16-bit timer/event counter 0 input pin
- **3.** Figures in parentheses are for operation with fx = 5.0 MHz.

## (5) Port mode register 2 (PM2)

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

When using the P23/TO0/TI00 pin for timer output, set PM23 and the output latch of P23 to 0.

When using the P23/TO0/TI00 pin for timer input, set PM23 to 0. At this time, the output latch of P23 may be either 0 or 1.

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

RESET input sets PM2 value to FFH.

## Figure 7-6. Format of Port Mode Register 2 (PM2)

| Symbol         7         6         5         4         3         2         1         0           PM2         1         1         1         PM24         PM23         PM22         PM21         PM | Address: | FF22 | H Af | ter rese | et: FFH | R/W  |      |      |      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|------|----------|---------|------|------|------|------|
| PM2 1 1 1 PM24 PM23 PM22 PM21 PM                                                                                                                                                                  | Symbol   | 7    | 6    | 5        | 4       | 3    | 2    | 1    | 0    |
|                                                                                                                                                                                                   | PM2      | 1    | 1    | 1        | PM24    | PM23 | PM22 | PM21 | PM20 |

| PM2n | P2n pin I/O mode selection (n = 0 to 4) |
|------|-----------------------------------------|
| 0    | Output mode (output buffer on)          |
| 1    | Input mode (output buffer off)          |

# 7.4 Operation of 16-Bit Timer/Event Counter 0

#### 7.4.1 Interval timer operation

Setting 16-bit timer mode control register 0 (TMC0) and capture/compare control register 0 (CRC0) as shown in Figure 7-7 allows operation as an interval timer. Interrupt requests are generated repeatedly using the count value set in 16-bit timer capture/compare register 00 (CR00) beforehand as the interval.

When the count value of 16-bit timer counter 0 (TM0) matches the value set to CR00, counting continues with the TM0 value cleared to 0 and the interrupt request signal (INTTM00) is generated.

The count clock of the 16-bit timer/event counter can be selected with bits 0 and 1 (PRM00, PRM01) of prescaler mode register 0 (PRM0).

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



### (b) Capture/compare control register 0 (CRC0)



**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with the interval timer. See **Figure 7-3**.





Note OVF0 becomes 1 only when CR00 is set to FFFFH.





 $\label{eq:Remark} \begin{array}{ll} \mbox{Remark} & \mbox{Interval time} = (N + 1) \times t \\ N = 0001 \mbox{H to FFFH} \end{array}$ 

#### 7.4.2 PPG output operations

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

In the PPG output operation, square waves are output from the TO0/TI00/P23 pin with the pulse width and the cycle that correspond to the count values set beforehand in 16-bit timer capture/compare register 01 (CR01) and in 16-bit timer capture/compare register 00 (CR00), respectively.

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

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



## (b) Capture/compare control register 0 (CRC0)



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



Cautions 1. Values in the following range should be set in CR00 and CR01: 0000H  $\leq$  CR01 < CR00  $\leq$  FFFFH

> The cycle of the pulse generated through PPG output (CR00 setting value + 1) has a duty of (CR01 setting value + 1)/(CR00 setting value + 1).

Remark ×: Don't care





Figure 7-12. PPG Output Operation Timing



#### Caution CR00 cannot be rewritten during TM0 operation.

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

- In the PPG output operation, change the pulse width (rewrite CR01) during TM0 operation using the following procedure.
  - <1> Disable the timer output inversion operation by match of TM0 and CR01 (TOC04 = 0)
  - <2> Disable the INTTM01 interrupt (TMMK01 = 1)
  - <3> Rewrite CR01
  - <4> Wait for 1 cycle of the TM0 count clock
  - <5> Enable the timer output inversion operation by match of TM0 and CR01 (TOC04 = 1)
  - <6> Clear the interrupt request flag of INTTM01 (TMIF01 = 0)
  - <7> Enable the INTTM01 interrupt (TMMK01 = 0)

#### 7.4.3 Pulse width measurement operations

It is possible to measure the pulse width of the signals input to the TI00/TO0/P23 pin and TI01/P24/INTP0 pin using 16-bit timer counter 0 (TM0).

There are two measurement methods: measuring with TMO used in free-running mode, and measuring by restarting the timer in synchronization with the edge of the signal input to the TI00/TO0/P23 pin.

#### (1) Pulse width measurement with free-running counter and one capture register

When 16-bit timer counter 0 (TM0) is operated in free-running mode, and the edge specified by prescaler mode register 0 (PRM0) is input to the TI00/TO0/P23 pin, the value of TM0 is taken into 16-bit timer capture/compare register 01 (CR01) and an external interrupt request signal (INTTM01) is set.

Any of three edges can be selected-rising, falling, or both edges-specified by bits 4 and 5 (ES00 and ES01) of PRM0.

Sampling is performed at the count clock selected by PRM0, and a capture operation is only performed when a valid level of the TI00/TO0/P23 pin is detected twice, thus eliminating noise with a short pulse width.

# Figure 7-13. Control Register Settings for Pulse Width Measurement with Free-Running Counter and One Capture Register

(a) 16-bit timer mode control register 0 (TMC0)



Free-running mode

#### (b) Capture/compare control register 0 (CRC0)



Remark 0/1: Setting 0 or 1 allows another function to be used simultaneously with pulse width measurement. See Figures 7-2 and 7-3.



Figure 7-14. Configuration Diagram for Pulse Width Measurement by Free-Running Counter

Figure 7-15. Timing of Pulse Width Measurement Operation by Free-Running Counter and One Capture Register (with Both Edges Specified)



**Note** Clear OVF0 by software.

## (2) Measurement of two pulse widths with free-running counter

When 16-bit timer counter 0 (TM0) is operated in free-running mode, it is possible to simultaneously measure the pulse widths of the two signals input to the TI00/TO0/P23 pin and the TI01/P24/INTP0 pin.

When the edge specified by bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0) is input to the TI00/TO0/P23 pin, the value of TM0 is taken into 16-bit timer capture/compare register 01 (CR01) and an interrupt request signal (INTTM01) is set.

Also, when the edge specified by bits 6 and 7 (ES10 and ES11) of PRM0 is input to the TI01/P24/INTP0 pin, the value of TM0 is taken into 16-bit timer capture/compare register 00 (CR00) and an interrupt request signal (INTTM00) is set.

Any of three edges can be selected–rising, falling, or both edges–as the valid edges for the TI00/TO0/P23 pin and the TI01/P24/INTP0 pin specified by bits 4 and 5 (ES00 and ES01) and bits 6 and 7 (ES10 and ES11) of PRM0, respectively.

Sampling is performed at the interval selected by prescaler mode register 0 (PRM0), and a capture operation is only performed when a valid level of the TI00/TO0/P23 pin or TI01/P24/INTP0 pin is detected twice, thus eliminating noise with a short pulse width.

## Figure 7-16. Control Register Settings for Measurement of Two Pulse Widths with Free-Running Counter



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

### (b) Capture/compare control register 0 (CRC0)



#### • Capture operation (free-running mode)

The capture register operation when the capture trigger is input is shown.











#### (3) Pulse width measurement with free-running counter and two capture registers

When 16-bit timer counter 0 (TM0) is operated in free-running mode, it is possible to measure the pulse width of the signal input to the TI00/TO0/P23 pin.

When the edge specified by bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0) is input to the TI00/TO0/P23 pin, the value of TM0 is taken into 16-bit timer capture/compare register 01 (CR01) and an interrupt request signal (INTTM01) is set.

Also, the value of TM0 is taken into 16-bit timer capture/compare register 00 (CR00) on the inverse edge to that input in the capture operation to CR01.

Either of two edges can be selected-rising or falling-as the valid edges for the TI00/TO0/P23 pin specified by bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0).

Sampling is performed at the interval selected by prescaler mode register 0 (PRM0), and a capture operation is only performed when a valid level of the TI00/TO0/P23 pin is detected twice, thus eliminating noise with a short pulse width.

# Figure 7-19. Control Register Settings for Pulse Width Measurement with Free-Running Counter and Two Capture Registers



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

#### (b) Capture/compare control register 0 (CRC0)







#### (4) Pulse width measurement by means of restart

When input of a valid edge to the TI00/TO0/P23 pin is detected, the count value of 16-bit timer counter 0 (TM0) is taken into 16-bit timer capture/compare register 01 (CR01), and then the pulse width of the signal input to the TI00/TO0/P23 pin is measured by clearing TM0 and restarting the count.

Either of two edges can be selected-rising or falling-as the valid edges by bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0).

Sampling is performed at the interval selected by prescaler mode register 0 (PRM0), and a capture operation is only performed when a valid level of the TI00/TO0/P23 pin is detected twice, thus eliminating noise with a short pulse width.

Note Clear OVF0 by software.

# Figure 7-21. Control Register Settings for Pulse Width Measurement by Means of Restart

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







#### 7.4.4 External event counter operation

The external event counter counts the number of external clock pulses to be input to the TI00/TO0/P23 pin with 16-bit timer counter 0 (TM0).

TM0 is incremented each time the valid edge specified with prescaler mode register 0 (PRM0) is input.

When the TM0 count value matches the 16-bit timer capture/compare register 00 (CR00) value, TM0 is cleared to 0 and an interrupt request signal (INTTM00) is generated.

Input a value other than 0000H to CR00 (a 1-pulse count operation cannot be carried out).

The rising edge, the falling edge, or both edges can be selected by bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0).

Sampling is performed with the internal clock  $(fx/2^3)$ , and an external event counter operation is only performed when a valid level of the TI00/TO0/P23 pin is detected twice, thus eliminating noise with a short pulse width.

# Caution When used as an external event counter, the P23/TI00/TO0 pin cannot be used as a timer output (TO0).

#### Figure 7-23. Control Register Settings in External Event Counter Mode

(a) 16-bit timer mode control register 0 (TMC0)



(b) Capture/compare control register 0 (CRC0)

|      |   | CRC02 CRC01 CRC00 |   |   |   |     |     |   |                          |  |  |
|------|---|-------------------|---|---|---|-----|-----|---|--------------------------|--|--|
| CRC0 | 0 | 0                 | 0 | 0 | 0 | 0/1 | 0/1 | 0 |                          |  |  |
|      |   |                   |   |   |   |     |     |   | CR00 as compare register |  |  |

**Remark** 0/1: Setting 0 or 1 allows another function to be used simultaneously with the external event counter. See Figures 7-2 and 7-3.



#### Figure 7-24. External Event Counter Configuration Diagram

Note OVF0 becomes 1 only when CR00 is set to FFFFH.



Caution When reading the external event counter count value, TM0 should be read.

# 7.4.5 Square-wave output operation

A square wave with any selected frequency can be output at intervals determined by the count value preset to 16bit timer capture/compare register 00 (CR00).

The TO0 pin output status is reversed at intervals determined by the count value preset to CR00 by setting bit 0 (TOE0) and bit 1 (TOC01) of 16-bit timer output control register 0 (TOC0) to 1. This enables a square wave with any selected frequency to be output.

# Figure 7-26. Control Register Settings in Square-Wave Output Mode







# Figure 7-27. Square-Wave Output Operation Timing

Figures 7-3 and 7-4.

# 7.5 Cautions on 16-Bit Timer/Event Counter 0

#### (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 16-bit timer counter 0 (TM0) is started asynchronously with the count clock.





 \* (2) Prohibition of compare register change during timer count operation Do not rewrite CR00 during TM0 operation.

# (3) Capture register data retention timing

INTTM01

Capture read signal

CR01 capture value

<1> If the valid edge of the TI00/TO0/P23 pin is input while 16-bit timer capture/compare register 01 (CR01) is being read, CR01 carries out the capture operation but the read value at this time is not guaranteed. However, the interrupt request signal (INTTM01) is generated upon detection of the valid edge.



Х

Figure 7-29. Capture Register Data Retention Timing

<2> The value of 16-bit timer capture/compare registers 00 and 01 (CR00 and CR01) is not guaranteed after 16-bit timer/event counter 0 is stopped.

Capture operation

N + 1

M + 1

Captured but read value not guaranteed

# (4) Valid edge setting

Set the valid edge of the TI00/TO0/P23 pin after setting bits 2 and 3 (TMC02 and TMC03) of 16-bit timer mode control register 0 (TMC0) to 0, 0, respectively, and then stopping timer operation. The valid edge is set with bits 4 and 5 (ES00 and ES01) of prescaler mode register 0 (PRM0).

#### (5) Operation of OVF0 flag

<1> The OVF0 flag is also set to 1 in the following case.

Either the clear & start mode entered on a match between TM0 and CR00, clear & start mode entered on the valid edge of TI00, or the free-running mode is selected.

```
\downarrow
CR00 is set to FFFFH.
\downarrow
```

When TM0 is counted up from FFFFH to 0000H.



<2> Even if the OVF0 flag is cleared before the next count clock is counted (TM0 becomes 0001H) after the occurrence of a TM0 overflow, the OVF0 flag is reset newly and the clear is disabled.

#### Figure 7-30. Operation Timing of OVF0 Flag

#### (6) Timer operation

- <1> Even if 16-bit timer counter 0 (TM0) is read, the value is not captured by 16-bit timer capture/compare register 01 (CR01).
- <2> Regardless of the CPU's operation mode, when the timer stops, the signals input to pins TI00/TI01 are not acknowledged.

#### (7) Capture operation

- <1> If TI00 is specified as the valid edge of the count clock, a capture operation by the capture register specified as the trigger for TI00 is not possible.
- <2> If both the rising and falling edges are selected as the valid edge of TI00, CR00 does not perform capture.
- <3> To ensure the reliability of the capture operation, the capture trigger requires a pulse two cycles longer than the count clock selected by prescaler mode register 0 (PRM0).
- <4> The capture operation is performed at the fall of the count clock. An interrupt request input (INTTMOn), however, is generated at the rise of the next count clock.

#### (8) Compare operation

A capture operation may not be performed for CR00/CR01 set in compare mode even if a capture trigger has been input.

# (9) Edge detection

- <1> If the TI00 pin or the TI01 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 for the TI00 pin or TI01 pin to enable the 16-bit timer counter 0 (TM0) operation, a rising edge is detected immediately. Be careful when pulling up the TI00 pin or the TI01 pin. However, the rising edge is not detected at restart after the operation has been stopped once.
- <2> The sampling clock used to eliminate noise differs when the TI00 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/2<sup>3</sup>, and in the latter case the count clock is selected by prescaler mode register 0 (PRM0). The capture operation is started when a valid edge is detected twice by sampling, thus eliminating noise with a short pulse width.

# CHAPTER 8 16-BIT TIMER D

# 8.1 Features

16-bit timer D functions as a 16-bit interval timer.

# 8.2 Function Overview

- 16-bit interval timer
- Compare registers: 1
- Interrupt request sources: 1 source
- Count clock selected from divisions of system clock

# 8.3 Basic Configuration of 16-Bit Timer D

# Table 8-1. Configuration of 16-Bit Timer D

| Timer          | Count Clock                                                                   | Register | Read/Write | Generated<br>Interrupt<br>Signal | Capture<br>Trigger | Timer Output<br>S/R | Other<br>Functions |
|----------------|-------------------------------------------------------------------------------|----------|------------|----------------------------------|--------------------|---------------------|--------------------|
| 16-bit timer D | fx/2, fx/2 <sup>2</sup> , fx/2 <sup>3</sup> , fx/2 <sup>4</sup> ,             | TMD      | Read       | -                                | -                  | -                   | -                  |
|                | fx/2 <sup>5</sup> , fx/2 <sup>6</sup> , fx/2 <sup>7</sup> , fx/2 <sup>8</sup> | CMD      | Read/write | INTCMD                           | -                  | -                   | -                  |

Remark fx: System clock

S/R: Set/reset

Figure 8-1. Block Diagram of 16-Bit Timer D



Remark fx: System clock

# 8.4 16-Bit Timer D

# (1) 16-bit timer counter D (TMD)

TMD is a 16-bit timer. It is mainly used as an interval timer for software. Starting and stopping TMD is controlled by the CE bit of timer mode control register D (TMCD). Division by the prescaler can be selected for the count clock from among fx/2,  $fx/2^2$ ,  $fx/2^3$ ,  $fx/2^4$ ,  $fx/2^5$ ,  $fx/2^6$ ,  $fx/2^7$ , and  $fx/2^8$  by the CS0 to CS2 bits of the TMCD register (fx: system clock). TMD is read-only in 16-bit units.

|     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---------|-------------|
| TMD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | FF18H   | 0000H       |

The conditions for which the TMD register becomes 0000H are shown below.

- RESET input
- CAE bit = 0
- CE bit = 0
- Match of TMD register and CMD register
- Overflow

Cautions 1. If the CAE bit of the TMCD register is cleared (0), a reset is performed asynchronously.

- 2. If the CE bit of the TMCD register is cleared (0), a reset is performed, in synchronization with the internal clock. Similarly, a synchronized reset is performed after a match with the CMD register and after an overflow.
- 3. The count clock must not be changed during a timer operation. If it is to be overwritten, it should be overwritten after the CE bit is cleared (0).
- 4. Up to 4 clocks are required after a value is set in the CE bit until the set value is transferred to internal units. When a count operation begins, the count cycle from 0000H to 0001H differs from subsequent cycles.
- 5. After a compare match is generated, the timer is cleared at the next count clock. Therefore, if the division ratio is large, the timer value may not be zero even if the timer value is read immediately after a match interrupt is generated.

#### (2) 16-bit compare register D (CMD)

The CMD and TMD register count values are compared, and an interrupt request signal (INTCMD) is generated when a match occurs. TMD is cleared in synchronization with this match. If the CAE bit of the TMCD register is set to 0, a reset is performed asynchronously, and the registers are initialized.

The CMD register is configured with a master/slave configuration. When the CMD register is written, data is first written to the master register and then the master register data is transferred to the slave register. In a compare operation, the slave register value is compared with the count value of the TMD register. When the CMD register is read, data in the master side is read out.

CMD can be read or written in 16-bit units.

- Cautions 1. A write operation to the CMD register requires 4 clocks until the value that was set in the CMD register is transferred to internal units. When writing continuously to the CMD register, be sure to secure a time interval of at least 4 clocks.
  - 2. The CMD register can be overwritten only once in a single TMD register cycle (from 0000H until an INTCMD interrupt is generated due to a match of the TMD register and CMD register). If this cannot be secured by the application, make sure that the CMD register is not overwritten during timer operation.
  - 3. Note that an INTCMD interrupt will be generated after an overflow if a value less than the counter value is written in the CMD register during TMD register operation (Figure 8-2).

|     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---------|-------------|
| CMD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | FF1AH   | 0000H       |





(a) When TMD < CMD

RemarkM = TMD value when overwrittenN = CMD value when overwrittenM > N

#### 8.5 16-Bit Timer D Control Register

#### (1) 16-bit timer mode control register D (TMCD)

The TMCD register controls the operation of 16-bit timer D. This register can be read or written in 8-bit or 1-bit units.

Caution The CAE and other bits cannot be set at the same time. The other bits and the registers of the other TMD units should always be set after the CAE bit has been set.

#### Figure 8-3. Format of 16-Bit Timer Mode Control Register D (TMCD)

| Address: | FF5CH | After r | eset: 00H | H R/W |   |   |     |     |
|----------|-------|---------|-----------|-------|---|---|-----|-----|
|          | 7     | <6>     | <5>       | <4>   | 3 | 2 | <1> | <0> |
| TMCD     | 0     | CS2     | CS1       | CS0   | 0 | 0 | CE  | CAE |

| CS2 | CS1 | CS0 | Count clock selection       |
|-----|-----|-----|-----------------------------|
| 0   | 0   | 0   | fx/2 (0.4 μs)               |
| 0   | 0   | 1   | fx/2 <sup>2</sup> (0.8 μs)  |
| 0   | 1   | 0   | fx/2 <sup>3</sup> (1.6 μs)  |
| 0   | 1   | 1   | fx/2 <sup>4</sup> (3.2 μs)  |
| 1   | 0   | 0   | fx/2 <sup>5</sup> (6.4 μs)  |
| 1   | 0   | 1   | fx/2 <sup>6</sup> (12.8 μs) |
| 1   | 1   | 0   | fx/2 <sup>7</sup> (25.6 μs) |
| 1   | 1   | 1   | fx/2 <sup>8</sup> (51.2 μs) |

| CE | TMD operation control                                        |
|----|--------------------------------------------------------------|
| 0  | Count operation disabled (stopped at 0000H and not operated) |
| 1  | Count operation enabled                                      |

| CAE | Count clock control                                                              |
|-----|----------------------------------------------------------------------------------|
| 0   | Entire TMD unit is asynchronously reset and clock supply to TMD unit is stopped. |
| 1   | Clock supplied to TMD unit.                                                      |

- Cautions 1. Do not change bits CS2 to CS0 during a timer operation. Before changing these bits, set the CE bit to 0. If these bits are changed during an operation, the operation is not guaranteed.
  - 2. The CE bit will not be cleared even if a mach is detected during a compare operation. To stop the count operation, clear the CE bit.
  - 3. When the CAE bit is 0, the TMD unit is in the reset status. Therefore, to operate TMD, set the CAE bit to 1.
  - 4. If the CAE bit is changed from 1 to 0, all the registers in the TMD unit will be initialized. To set the CAE bit to 1 again, all the registers in the TMD unit must be set again after CAE has been set to 1.
- **Remarks 1.** fx: System clock oscillation frequency
  - **2.** Figures in parentheses are for operation with fx = 5.0 MHz.

# 8.6 16-Bit Timer D Operation

#### (1) Compare operation

TMD can be used for a compare operation in which the value that was set in the compare register (CMD) is compared with the TMD count value.

If a match is detected by the compare operation, an interrupt (INTCMD) is generated. The generation of the interrupt causes TMD to be cleared (0) at the next count timing. This function enables 16-bit timer D to be used as an interval timer.

CMD can also be set to 0. In this case, when an overflow occurs and TMD becomes 0, a match is detected and INTCMD is generated. Although the TMD value is cleared (0) at the next count timing, INTCMD is not generated by this match.

# Figure 8-4. TMD Compare Operation Example (1/2)



#### (a) When CMD is set to n (except zero)

**Remark** Interval time =  $(n + 1) \times (Count clock cycle)$ n = 1 to 65,536 (FFFFH)





(b) When CMD is set to 0

**Remark** Interval time = (FFFFH + 2) × (Count clock cycle)

# 8.7 Application Examples

# (1) Interval timer

This section explains an example in which 16-bit timer D is used as an interval timer with 16-bit precision. An interrupt request (INTCMD) is output at equal intervals (see **Figure 8-4 TMD Compare Operation Example**). The setup procedure is shown below.

- <1> Set (1) the CAE bit.
- <2> Set each register.
  - Select the count clock using the CS0 to CS2 bits of the TMCD register.
  - Set the compare value in the CMD register.
- <3> Start counting by setting (1) the CE bit.
- <4> If the TMD register and CMD register values match, the INTCMD interrupt is generated.
- <5> The INTCMD interrupt is generated thereafter at equal intervals.

# 8.8 Cautions

Various cautions concerning 16-bit timer D are shown below.

- (1) To operate TMD, first set (1) the CAE bit.
- (2) Up to 4 clocks are required after a value is set in the CE bit until the set value is transferred to internal units. When a count operation begins, the count cycle from 0000H to 0001H differs from subsequent cycles.
- (3) To initialize the TMD register status and start counting again, clear (0) the CE bit and then set (1) the CE bit after an interval of 4 clocks has elapsed.
- (4) Up to 4 clocks are required until the value that was set in the CMD register is transferred to internal units. When writing continuously to the CMD register, be sure to secure a time interval of at least 4 clocks.
- (5) The CMD register can be overwritten only once during a timer/counter operation (from 0000H until the INTCMD interrupt is generated due to a match of the TMD register and CMD register). If this cannot be secured by the application, make sure that the CMD register is not overwritten during a timer/counter operation.
- (6) The count clock must not be changed during a timer operation. If it is to be overwritten, it should be overwritten after the CE bit is cleared (0). If the count clock is overwritten during a timer operation, operation cannot be guaranteed.
- (7) The INTCMD interrupt will occur after an overflow if a value less than the counter value is written in the CMD register during TMD register operation.

# CHAPTER 9 8-BIT TIMER/EVENT COUNTER 5

# 9.1 Functions of 8-Bit Timer/Event Counter 5

8-bit timer/event counter 5 has the following functions.

- Interval timer
- External event counter
- Square-wave output
- PWM output

Figure 9-1 shows the block diagram of 8-bit timer/event counter 5.



# Figure 9-1. Block Diagram of 8-Bit Timer/Event Counter 5

- Notes 1. Timer output F/F
  - 2. PWM output F/F

# 9.2 Configuration of 8-Bit Timer/Event Counter 5

8-bit timer/event counter 5 includes the following hardware.

# Table 9-1. Configuration of 8-Bit Timer/Event Counter 5

| Item              | Configuration                                                                                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer register    | 8-bit timer counter 5 (TM5)                                                                                                                                     |
| Register          | 8-bit timer compare register 5 (CR5)                                                                                                                            |
| Timer output      | 2 (TO5)                                                                                                                                                         |
| Control registers | Timer clock select register 5 (TCL5)<br>8-bit timer mode control register 5 (TMC5)<br>Port mode register 2 (PM2) <sup>Note</sup><br>Port 2 (P2) <sup>Note</sup> |

Note See Figure 5-5 Block Diagram of P22 and P23.

# (1) 8-bit timer counter 5 (TM5)

TM5 is an 8-bit read-only register which counts the count pulses.

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 set to 00H.

- <1> RESET input
- <2> When TCE5 is cleared
- <3> When TM5 and CR5 match in clear & start mode entered on a match between TM5 and CR5.

# (2) 8-bit timer compare register 5 (CR5)

CR5 is a register that can be read/written by 8-bit memory manipulation.

In other than the PWM mode, the value set in CR5 is constantly compared with the 8-bit timer counter 5 (TM5) count value, and an interrupt request (INTTM50) is generated if they match.

In the PWM mode, the TO50 pin is at an active level when TM5 overflows, while the TO50 pin is at an inactive level when the values of TM5 and CR5 match.

It is possible to rewrite the value of CR5 within 00H to FFH.

RESET input sets CR5 to 00H.

- Cautions 1. Do not write another value to CR5 during operation in the clear & start mode entered on a match between TM5 and CR5 (TMC56 = 0).
  - 2. In the PWM mode, set the interval between each write operation to CR5 to at least three times the count clock selected by TCL5.

# 9.3 Control Registers of 8-Bit Timer/Event Counter 5

The following four registers are used to control 8-bit timer/event counter 5.

- Timer clock select register 5 (TCL5)
- 8-bit timer mode control register 5 (TMC5)
- Port mode register 2 (PM2)
- Port 2 (P2)

#### (1) Timer clock select register 5 (TCL5)

This register sets the count clock of 8-bit timer/event counter 5 and the valid edge of TI50 input. TCL5 is set by an 8-bit memory manipulation instruction. RESET input sets TCL5 to 00H.

#### Figure 9-2. Format of Timer Clock Select Register 5 (TCL5)

Address: FF52H After reset: 00H R/W Symbol 7 6 2 1 0 5 4 3 TCL5 0 0 0 0 0 TCL52 TCL51 TCL50

| TCL52 | TCL51 | TCL50 | Count clock selection      |
|-------|-------|-------|----------------------------|
| 0     | 0     | 0     | TI50 falling edge          |
| 0     | 0     | 1     | TI50 rising edge           |
| 0     | 1     | 0     | fx (0.2 μs)                |
| 0     | 1     | 1     | fx/2 (0.4 μs)              |
| 1     | 0     | 0     | fx/2² (0.8 μs)             |
| 1     | 0     | 1     | fx/2³ (1.6 μs)             |
| 1     | 1     | 0     | fx/2 <sup>4</sup> (3.2 μs) |
| 1     | 1     | 1     | fx/2 <sup>5</sup> (6.4 μs) |

Cautions 1. When rewriting other data to TCL5, stop the timer operation beforehand.

2. Be sure to set bits 3 to 7 to 0.

Remarks 1. fx: System clock oscillation frequency

**2.** Figures in parentheses are for operation with fx = 5.0 MHz.

# (2) 8-bit timer mode control register 5 (TMC5)

TMC5 is a register that makes the following five types of settings.

- <1> 8-bit timer counter 5 (TM5) count operation control
- <2> 8-bit timer counter 5 (TM5) 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

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

RESET input sets TMC5 to 00H.

Figure 9-3 shows the TMC5 format.

# Figure 9-3. Format of 8-Bit Timer Mode Control Register 5 (TMC5)

Address: FF53H After reset: 00H R/W<sup>Note</sup>

| Symbol | <7>  | <6>   | 5 | 4 | <3>  | <2>  | <1>   | <0>  |
|--------|------|-------|---|---|------|------|-------|------|
| TMC5   | TCE5 | TMC56 | 0 | 0 | LVS5 | LVR5 | TMC51 | TOE5 |

| TCE5 | TM5 count operation control                                                 |
|------|-----------------------------------------------------------------------------|
| 0    | After clearing the counter to 0, count operation disabled (counter stopped) |
| 1    | Count operation starts                                                      |

| TMC56 | TM5 operating mode selection                    |
|-------|-------------------------------------------------|
| 0     | Clear and start mode by matching of TM5 and CR5 |
| 1     | PWM (free-running) mode                         |

| LVS5 | LVR5 | 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              |

| TMC51 | In other modes (TMC56 = 0)   | In PWM mode (TMC56 = 1) |  |
|-------|------------------------------|-------------------------|--|
|       | Timer F/F control            | Active level selection  |  |
| 0     | Inversion operation disabled | Active high             |  |
| 1     | Inversion operation enabled  | Active low              |  |

| TOE5 | Timer output control                     |  |
|------|------------------------------------------|--|
| 0    | Output disabled (TM50 outputs low level) |  |
| 1    | Output enabled                           |  |

Note Bits 2 and 3 are write only.

# Cautions 1. The settings of LVS5 and LVR5 are valid except in the PWM mode.

- 2. TMC51 and TOE5 must not be rewritten at the same time.
- 3. When switching to the PWM mode, TMC56, LVS5, and LVR5 must not be rewritten at the same time.
- 4. Before rewriting TMC56, the operation must be stopped.

**Remarks 1.** In PWM mode, PWM output will be inactive because of TCE5 = 0.

- 2. If LVS5 and LVR5 are read after data is set, 0 is read.
- **3.** The TO50 pin reflects each value of the TMC56, LVS5, LVR5, TMC51, and TOE5 bits regardless of the value of TCE5.

# (3) Port mode register 2 (PM2)

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

When using the P22/TO50/TI50 pin for timer output, set PM22 and the output latch of P22 to 0.

When using the P22/TO50/TI50 pin for timer input, set PM22 to 1. At this time, the output latch of P22 may be either 0 or 1.

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

RESET input sets PM2 to FFH.

#### Figure 9-4. Format of Port Mode Register 2 (PM2)

| Address: | FF22H | After reset: | FFH | R/W |
|----------|-------|--------------|-----|-----|
|          |       |              |     |     |

Symbol 2 0 7 6 5 4 3 1 PM2 PM24 PM23 PM22 PM21 PM20 1 1 1

| PM2n | P2n pin I/O mode selection (n = 0 to 4) |  |
|------|-----------------------------------------|--|
| 0    | Output mode (output buffer on)          |  |
| 1    | Input mode (output buffer off)          |  |

# 9.4 Operations of 8-Bit Timer/Event Counter 5

#### 9.4.1 Interval timer (8-bit) operation

The 8-bit timer/event counter operates as an interval timer that generates interrupt requests repeatedly at intervals of the count value preset to 8-bit timer compare register 5 (CR5).

When the count value of 8-bit timer counter 5 (TM5) matches the value set to CR5, counting continues with the TM5 value cleared to 0 and an interrupt request signal (INTTM50) is generated.

The count clock of TM5 can be selected with bits 0 to 2 (TCL50 to TCL52) of timer clock select register 5 (TCL5).

# [Setting]

<1> Set the registers.

- TCL5: Select count clock
- CR5: Compare value
- TMC5: Select count operation stop, clear and start mode by match of TM5 and CR5, and timer output disabled

 $(TMC5 = 0000 \times \times 0B \times = don't care)$ 

<2> After TCE5 = 1 is set, count operation starts.

- <3> If the values of TM5 and CR5 match, INTTM50 is generated (TM5 is cleared to 00H).
- <4> INTTM50 is generated repeatedly at the same interval. Set TCE5 to 0 to stop the count operation.

#### Caution Do not write another value to CR5 during operation.

# Figure 9-5. Interval Timer Operation Timing (1/2)



#### (a) Basic operation

**Remark** Interval time =  $(N + 1) \times t$ N = 00H to FFH









#### 9.4.2 External event counter operation

The external event counter counts the number of external clock pulses to be input to TI50 by 8-bit timer counter 5 (TM5).

TM5 is incremented each time the valid edge specified by timer clock select register 5 (TCL5) is input. Either the rising or falling edge can be selected.

When the TM5 count value matches the value of 8-bit timer compare register 5 (CR5), TM5 is cleared to 0 and an interrupt request signal (INTTM50) is generated.

INTTM50 is subsequently generated, whenever the TM5 count value matches the value of CR5.

# [Setting]

<1> Set the registers.

- TCL5: Select edge of TI50 input Fall of TI50  $\rightarrow$  TCL5 = 00H Rise of TI50  $\rightarrow$  TCL5 = 01H
- CR5: Compare value
- TMC5: Select count operation stop, clear and start mode by match of TM5 and CR5, timer F/F reverse operation disabled, and timer output disabled

 $(TMC5 = 0000 \times 00B \times = don't care)$ 

- <2> After TCE5 = 1 is set, an operation to count the number of pulses input by TI50 starts.
- <3> If the values of TM5 and CR5 match, INTTM50 is generated (TM5 is cleared to 00H).
- <4> After this, INTTM50 is generated each time the values of TM5 and CR5 match.

#### Figure 9-6. External Event Counter Operation Timing (with Rising Edge Specified)

| TI50            |                                 |                               |
|-----------------|---------------------------------|-------------------------------|
| TM5 count value | X 00 X 01 X 02 X 03 X 04 X 05 X | XN-1X N X 00 X 01 X 02 X 03 X |
| CR5             |                                 | N                             |
| INTTM50         |                                 | ′¬                            |

N = 00H to FFH

#### 9.4.3 Square-wave output (8-bit resolution) operation

A square wave with any selected frequency is output at intervals determined by the value preset to 8-bit timer compare register 5 (CR5).

The TO50 pin output status is reversed at intervals determined by the count value preset to CR5 by setting bit 0 (TOE5) of 8-bit timer mode control register 5 (TMC5) to 1. This enables a square wave with any selected frequency to be output (duty = 50%).

# [Setting]

<1> Set each register.

- Set port latch (P22) and port mode register (PM22) to 0
- TCL5: Select count clock
- CR5: Compare value
- TMC5: Count operation stopped, clear and start mode by match of TM5 and CR5

| LVS5 | LVR5 | Timer Output F/F Status Setting |
|------|------|---------------------------------|
| 1    | 0    | High-level output               |
| 0    | 1    | Low-level output                |

Timer output F/F reverse enable Timer output enable (TMC5 = 00001011B or 00000111B)

- <2> After TCE5 = 1 is set, count operation starts.
- <3> Timer output F/F is reversed by match of TM5 and CR5. After INTTM50 is generated, TM5 is cleared to 00H.
- <4> Timer output F/F is reversed at the same interval and square wave is output from TO50.

The frequency is as follows.

- Frequency = fcnt/2 (N + 1)
  - (N: 00 to FFH, fCNT: Count clock)

Caution Do not write another value to CR5 during operation.

|                         | Figure 9-7. S                      | quare-Wave Output Operation Timing |                      |
|-------------------------|------------------------------------|------------------------------------|----------------------|
| Count clock             |                                    |                                    |                      |
| TM5 count value<br>Stai | 00H X 01H X 02H X<br>△<br>rt count | <u>Х</u> N-1X N X00H X01H X02H X   | <u>Х</u> N-1X N X00Н |
| CR5 _                   | N                                  |                                    |                      |
| TO50 <sup>Note</sup>    |                                    |                                    |                      |

**Note** The TO50 output initial value can be set by bits 2 and 3 (LVR5, LVS5) of 8-bit timer mode control register 5 (TMC5).

# 9.4.4 PWM output operation

The 8-bit timer/event counter operates as PWM output when bit 6 (TMC56) of 8-bit timer mode control register 5 (TMC5) is set to 1.

The duty rate pulse determined by the value set to 8-bit timer compare register 5 (CR5) is output from TO50. Set the active level width of the PWM pulse to CR5, and select the active level using bit 1 of TMC5 (TMC51). The count clock can be selected with bits 0 to 2 (TCL50 to TCL52) of timer clock select register 5 (TCL5). PWM output enable/disable can be selected with bit 0 of TMC5 (TOE5).

# Caution In the PWM mode, set the rewrite interval of CR5 to 3 clocks or more of the count clock (clock selected by TCL5).

#### (1) PWM output basic operation

#### [Setting]

- <1> Set the registers.
  - Set the port latch (P22) and port mode register 2 (PM22) to 0.
  - TCL5: Select count clock
  - CR5: Compare value
  - TMC5: Count operation stopped, PWM mode selected, timer output F/F does not change

| TMC51 | Active Level Selection |  |
|-------|------------------------|--|
| 0     | Active high            |  |
| 1     | Active low             |  |

Timer output enable (TMC5 = 01000001B or 01000011B)

<2> When TCE5 is set to 1, the count operation starts. Set TCE5 to 0 to stop count operation.

#### [PWM output operation]

- <1> PWM output (output from TO50) outputs the inactive level from when the count operation starts until an overflow is generated.
- <2> When an overflow is generated, the active level is output. The active level is output until CR5 matches the count value of 8-bit timer counter 5 (TM5).
- <3> When CR5 matches the count value, the inactive level is output, and continues being output until an overflow is generated again.
- <4> Operations <2> and <3> are repeated until the count operation stops.
- <5> When the count operation is stopped with TCE5 = 0, PWM output changes to the inactive level.



(a) Basic operation (active level = H)





(2) Operation by CR5 transition

Figure 9-9. Timing of Operation by CR5 Transition

(a) When CR5 value changes from N to M before rising edge of FFH clock  $\rightarrow$  Value is reloaded to CR5 at next overflow



(b) When CR5 value changes from N to M after rising edge of FFH clock  $\rightarrow$  Value is reloaded to CR5 at second overflow



Caution If CR5 is read between <1> and <2> in Figure 9-9, the read value is different than the actual value during operation (read value: M, actual CR5 value: N).

# 9.5 Cautions on 8-Bit Timer/Event Counter 5

#### (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 8-bit timer counter 5 (TM5) is started asynchronously with the count pulse.



#### Figure 9-10. Start Timing of 8-Bit Timer Counter 5

# **CHAPTER 10 WATCHDOG TIMER**

# **10.1 Watchdog Timer Functions**

The watchdog timer has the following functions.

- Watchdog timer
- Interval timer

# Caution Select the watchdog timer mode or interval timer mode by using the watchdog timer mode register (WDTM).

#### (1) Watchdog timer

The watchdog timer is used to detect inadvertent program loops. When an inadvertent loop is detected, a non-maskable interrupt or the  $\overline{\text{RESET}}$  signal can be generated.

| Inadvertent Loop<br>Detection Time | At fx = 5.0 MHz |
|------------------------------------|-----------------|
| $2^{11} \times 1/f_X$              | 410 <i>μ</i> s  |
| $2^{13} \times 1/f_X$              | 1.64 ms         |
| $2^{15} \times 1/f_X$              | 6.55 ms         |
| $2^{17} \times 1/f_X$              | 26.2 ms         |

#### Table 10-1. Inadvertent Loop Detection Time of Watchdog Timer

fx: System clock oscillation frequency

# (2) Interval timer

The interval timer generates an interrupt at a given interval set in advance.

| Interval              | At fx = 5.0 MHz<br>410 μs<br>1.64 ms<br>6.55 ms |  |
|-----------------------|-------------------------------------------------|--|
| $2^{11} \times 1/f_X$ | 410 <i>µ</i> s                                  |  |
| $2^{13} \times 1/f_X$ | 1.64 ms                                         |  |
| $2^{15} \times 1/f_X$ | 6.55 ms                                         |  |
| $2^{17} \times 1/f_X$ | 26.2 ms                                         |  |

fx: System clock oscillation frequency

# **10.2 Watchdog Timer Configuration**

The watchdog timer includes the following hardware.

# Table 10-3. Configuration of Watchdog Timer

| Item             | Configuration                                                                      |  |  |  |  |
|------------------|------------------------------------------------------------------------------------|--|--|--|--|
| Control register | Watchdog timer clock select register (WDCS)<br>Watchdog timer mode register (WDTM) |  |  |  |  |





Remark fx: System clock oscillation frequency

# **10.3 Watchdog Timer Control Registers**

The following two registers are used to control the watchdog timer.

- Watchdog timer clock select register (WDCS)
- Watchdog timer mode register (WDTM)

# (1) Watchdog timer clock select register (WDCS)

This register sets the watchdog timer count clock. WDCS is set by an 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input clears WDCS to 00H.

# Figure 10-2. Format of Watchdog Timer Clock Select Register

| Symbol | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|-------|-------|-------|---------|-------------|-----|
| WDCS   | 0 | 0 | 0 | 0 | 0 | WDCS2 | WDCS1 | WDCS0 | FF42H   | 00H         | R/W |

| WDCS2 | WDCS1       | WDCS0 | Watchdog timer count clock selection | Interval Time                 |
|-------|-------------|-------|--------------------------------------|-------------------------------|
| 0     | 0           | 0     | fx/2 <sup>4</sup> (313 kHz)          | 2 <sup>11</sup> /fx (410 µs)  |
| 0     | 1           | 0     | fx/2 <sup>6</sup> (78.1 kHz)         | 2 <sup>13</sup> /fx (1.64 ms) |
| 1     | 0           | 0     | fx/2 <sup>8</sup> (19.5 kHz)         | 2 <sup>15</sup> /fx (6.55 ms) |
| 1     | 1           | 0     | fx/2 <sup>10</sup> (4.88 kHz)        | 2 <sup>17</sup> /fx (26.2 ms) |
| Oth   | ner than ab | ove   | Setting prohibited                   |                               |

Remarks 1. fx: System clock oscillation frequency

**2.** Figures in parentheses are for operation with fx = 5.0 MHz.

# (2) Watchdog timer mode register (WDTM)

This register sets the operation mode of the watchdog timer, and enables/disables counting of the watchdog timer.

WDTM is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears WDTM to 00H.

#### Figure 10-3. Format of Watchdog Timer Mode Register

| Symbol | <7> | 6 | 5 | 4     | 3     | 2 | 1 | 0 | Address | After reset | R/W |
|--------|-----|---|---|-------|-------|---|---|---|---------|-------------|-----|
| WDTM   | RUN | 0 | 0 | WDTM4 | WDTM3 | 0 | 0 | 0 | FFF9H   | 00H         | R/W |

| RL | UN | Watchdog timer operation selection <sup>Note 1</sup> |  |  |  |
|----|----|------------------------------------------------------|--|--|--|
| 0  | 0  | Stops counting                                       |  |  |  |
| 1  | 1  | Clears counter and starts counting.                  |  |  |  |

| WDTM4 | WDTM3 | Watchdog timer operation mode selection <sup>Note 2</sup>           |  |  |  |
|-------|-------|---------------------------------------------------------------------|--|--|--|
| 0     | 0     | Operation stopped                                                   |  |  |  |
| 0     | 1     | erval timer mode (overflow and maskable interrupt occur)Note 3      |  |  |  |
| 1     | 0     | Watchdog timer mode 1 (overflow and non-maskable interrupt occur)   |  |  |  |
| 1     | 1     | Watchdog timer mode 2 (overflow occurs and reset operation started) |  |  |  |

- Notes 1. Once RUN has been set to 1, it cannot be cleared to 0 by software. Therefore, when counting is started, it cannot be stopped by any means other than RESET input.
  - 2. Once WDTM3 and WDTM4 have been set to 1, they cannot be cleared to 0 by software.
  - 3. The watchdog timer starts operations as an interval timer when RUN is set to 1.
- Cautions 1. When the watchdog timer is cleared by setting RUN to 1, the actual overflow time is up to 0.8% shorter than the time set by the watchdog timer clock select register (WDCS).
  - 2. In watchdog timer mode 1 or 2, set WDTM4 to 1 after confirming that WDTIF (bit 0 of interrupt request flag register 0 (IF0)) is set to 0. When watchdog timer mode 1 or 2 is selected under the condition where WDTIF is 1, a non-maskable interrupt occurs at the completion of rewriting.

# 10.4 Operation of Watchdog Timer

#### 10.4.1 Operation as watchdog timer

The watchdog timer detects an inadvertent program loop when bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 1.

The count clock (inadvertent loop detection time interval) of the watchdog timer can be selected by bits 0 to 2 (WDCS0 to WDCS2) of the watchdog timer clock select register (WDCS). By setting bit 7 (RUN) of WDTM to 1, the watchdog timer is started. Set RUN to 1 within the set inadvertent loop detection time interval after the watchdog timer has been started. By setting RUN to 1, the watchdog timer can be cleared and start counting. If RUN is not set to 1, and the inadvertent loop detection time is exceeded, the system is reset or a non-maskable interrupt is generated, depending on value of bit 3 (WDTM3) of WDTM.

The watchdog timer continues operation in the HALT mode, but stops in the STOP mode. Therefore, set RUN to 1 before entering the STOP mode to clear the watchdog timer, and then execute the STOP instruction.

#### Caution The actual inadvertent loop detection time may be up to 0.8% shorter than the set time.

| WDCS2 | WDCS1 | WDCS0 | Inadvertent Loop Detection Time | At fx = 5.0 MHz |
|-------|-------|-------|---------------------------------|-----------------|
| 0     | 0     | 0     | $2^{11} \times 1/f_X$           | 410 <i>µ</i> s  |
| 0     | 1     | 0     | $2^{13} \times 1/f_X$           | 1.64 ms         |
| 1     | 0     | 0     | $2^{15} \times 1/f_X$           | 6.55 ms         |
| 1     | 1     | 0     | $2^{17} \times 1/f_X$           | 26.2 ms         |

#### Table 10-4. Inadvertent Loop Detection Time of Watchdog Timer

fx: System clock oscillation frequency

#### 10.4.2 Operation as interval timer

When bits 4 and 3 (WDTM4, WDTM3) of the watchdog timer mode register (WDTM) are set to 0 and 1 respectively, the watchdog timer also operates as an interval timer that repeatedly generates an interrupt at time intervals specified by a count value set in advance.

Select the count clock (or interval time) by setting bits 0 to 2 (WDCS0 to WDCS2) of the watchdog timer clock select register (WDCS). The watchdog timer starts operation as an interval timer when the RUN bit (bit 7 of WDTM) is set to 1.

In the interval timer mode, the interrupt mask flag (WDTMK) is valid, and a maskable interrupt (INTWDT) can be generated. The priority of INTWDT is set as the highest of all the maskable interrupts.

The interval timer continues operation in the HALT mode, but stops in the STOP mode. Therefore, set RUN to 1 before entering the STOP mode to clear the interval timer, and then execute the STOP instruction.

# Cautions 1. Once bit 4 (WDTM4) of WDTM is set to 1 (when the watchdog timer mode is selected), the interval timer mode is not set, unless the RESET signal is input.

2. The interval time immediately after the setting by WDTM may be up to 0.8% shorter than the set time.

| WDCS2 | WDCS1 | WDCS0 | Interval Time         | At fx = 5.0 MHz |
|-------|-------|-------|-----------------------|-----------------|
| 0     | 0     | 0     | $2^{11} \times 1/f_X$ | 410 <i>μ</i> s  |
| 0     | 1     | 0     | $2^{13} \times 1/f_X$ | 1.64 ms         |
| 1     | 0     | 0     | $2^{15} \times 1/f_X$ | 6.55 ms         |
| 1     | 1     | 0     | $2^{17} \times 1/f_X$ | 26.2 ms         |

Table 10-5. Interval Time of Interval Timer

fx: System clock oscillation frequency

# **CHAPTER 11 SERIAL INTERFACE 2**

# 11.1 Functions of Serial Interface 2

Serial interface 2 has the following three modes.

- Operation stopped mode
- Asynchronous serial interface (UART) mode
- 3-wire serial I/O mode

# (1) Operation stopped mode

This mode is used when serial transfer is not performed. Power consumption is minimized in this mode.

# (2) Asynchronous serial interface (UART) mode

This mode is used to send and receive the one byte of data that follows a start bit. It supports full-duplex communication.

Serial interface 2 contains a dedicated UART baud rate generator, enabling communication over a wide range of baud rates. It is also possible to define baud rates by dividing the frequency of the input clock pulse at the ASCK2 pin.

# (3) 3-wire serial I/O mode (switchable between MSB-first and LSB-first transmission)

This mode is used to transmit 8-bit data, using three lines: a serial clock ( $\overline{SCK2}$ ) line and two serial data lines (SI2 and SO2).

As it supports simultaneous transmission and reception, 3-wire serial I/O mode requires less processing time for data transmission than asynchronous serial interface mode.

Because, in 3-wire serial I/O mode, it is possible to select whether 8-bit data transmission begins with the MSB or LSB, serial interface 2 can be connected to any device regardless of whether that device is designed for MSB-first or LSB-first transmission.

3-wire serial I/O mode can be used to connect IC and display controllers having clock synchronous serial interfaces.

# 11.2 Configuration of Serial Interface 2

Serial interface 2 includes the following hardware.

# Table 11-1. Configuration of Serial Interface 2

| Item              | Configuration                                                                                                                                                                                                                                                                               |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | Transmit shift register 2 (TXS2)<br>Receive shift register 2 (RXS2)<br>Receive buffer register 2 (RXB2)                                                                                                                                                                                     |
| Control registers | Serial operating mode register 2 (CSIM2)<br>Asynchronous serial interface mode register 2 (ASIM2)<br>Asynchronous serial interface status register 2 (ASIS2)<br>Baud rate generator control register 2 (BRGC2)<br>Port mode register 3 (PM3) <sup>Note</sup><br>Port 3 (P3) <sup>Note</sup> |

Note See Figure 5-7 Block Diagram of P30, Figure 5-8 Block Diagram of P31, and Figure 5-9 Block Diagram of P32 and P33.



**Note** See **Figure 11-2** for the configuration of the baud rate generator.

User's Manual U15852EJ4V0UD

Figure 11-2. Block Diagram of Baud Rate Generator



#### (1) Transmit shift register 2 (TXS2)

TXS2 is a register in which transmit data is prepared. Data written to TXS2 is transmitted as serial data. When the data length is seven bits, bits 0 to 6 of the data in TXS2 will be transmit data. Writing data to TXS2 triggers transmission.

TXS2 can be written with an 8-bit memory manipulation instruction, but cannot be read. RESET input sets TXS2 to FFH.

## Caution Do not write to TXS2 during transmission.

TXS2 and receive buffer register 2 (RXB2) are mapped at the same address, so that any attempt to read from TXS2 results in a value being read from RXB2.

#### (2) Receive shift register 2 (RXS2)

RXS2 is a register in which serial data, received at the RxD2 pin, is converted to parallel data. Once one entire byte has been received, RXS2 transfers the receive data to receive buffer register 2 (RXB2). RXS2 cannot be manipulated directly by a program.

#### (3) Receive buffer register 2 (RXB2)

RXB2 holds receive data. New receive data is transferred from receive shift register 2 (RXS2) per byte of data received.

When the data length is specified as seven bits, the receive data is sent to bits 0 to 6 of RXB2, in which the MSB is always fixed to 0.

RXB2 can be read with an 8-bit memory manipulation instruction, but cannot be written to. RESET input makes RXB2 undefined.

# Caution RXB2 and transmit shift register 2 (TXS2) are mapped at the same address, so that any attempt to write to RXB2 results in a value being written to TXS2.

#### (4) Transmission controller

The transmission controller controls transmission. For example, it adds start, parity, and stop bits to the data in transmit shift register 2 (TXS2), according to the setting of asynchronous serial interface mode register 2 (ASIM2).

#### (5) Reception controller

The reception controller controls reception according to the setting of asynchronous serial interface mode register 2 (ASIM2). It also checks for errors, such as parity errors, during reception. If an error is detected, asynchronous serial interface status register 2 (ASIS2) is set according to the status of the error.

# 11.3 Control Registers of Serial Interface 2

Serial interface 2 is controlled by the following six registers.

- Serial operating mode register 2 (CSIM2)
- Asynchronous serial interface mode register 2 (ASIM2)
- Asynchronous serial interface status register 2 (ASIS2)
- Baud rate generator control register 2 (BRGC2)
- Port mode register 3 (PM3)
- Port 3 (P3)

# (1) Serial operating mode register 2 (CSIM2)

CSIM2 is used to make the settings related to 3-wire serial I/O mode. CSIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears CSIM2 to 00H.

#### Figure 11-3. Format of Serial Operating Mode Register 2

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2    | 1     | 0 | Address | After reset | R/W |
|--------|-------|---|---|---|---|------|-------|---|---------|-------------|-----|
| CSIM2  | CSIE2 | 0 | 0 | 0 | 0 | DIR2 | CSCK2 | 0 | FF72H   | 00H         | R/W |

| CSIE2 | 3-wire serial I/O mode operation control |
|-------|------------------------------------------|
| 0     | Operation disabled                       |
| 1     | Operation enabled                        |

| DIR2 | First-bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

| CSCK2 | 3-wire serial I/O mode clock selection                          |  |  |  |  |  |
|-------|-----------------------------------------------------------------|--|--|--|--|--|
| 0     | External clock pulse input to the $\overline{\text{SCK2}}$ pin. |  |  |  |  |  |
| 1     | Output of the dedicated baud rate generator                     |  |  |  |  |  |

#### Cautions 1. Bits 0 and 3 to 6 must be fixed to 0.

- 2. CSIM2 must be cleared to 00H, if UART mode is selected.
- 3. Switch operating modes after halting the serial transmit/receive operation.

# (2) Asynchronous serial interface mode register 2 (ASIM2)

ASIM2 is used to make the settings related to asynchronous serial interface mode. ASIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears ASIM2 to 00H.

# Figure 11-4. Format of Asynchronous Serial Interface Mode Register 2

| Symbol | <7>  | <6>  | 5    | 4    | 3   | 2   | 1 | 0 | Address | After reset | R/W |
|--------|------|------|------|------|-----|-----|---|---|---------|-------------|-----|
| ASIM2  | TXE2 | RXE2 | PS21 | PS20 | CL2 | SL2 | 0 | 0 | FF70H   | 00H         | R/W |

| Т | TXE2 | Transmit operation control |
|---|------|----------------------------|
|   | 0    | Transmit operation stopped |
|   | 1    | Transmit operation enabled |

| RXE2 | Receive operation control |
|------|---------------------------|
| 0    | Receive operation stopped |
| 1    | Receive operation enabled |

| PS21 | PS20 | Parity bit specification                                                                                     |
|------|------|--------------------------------------------------------------------------------------------------------------|
| 0    | 0    | No parity                                                                                                    |
| 0    | 1    | Always add 0 parity at transmission.<br>Parity check is not performed at reception (no parity error occurs). |
| 1    | 0    | Odd parity                                                                                                   |
| 1    | 1    | Even parity                                                                                                  |

| CL2 | Transmit data character length specification |
|-----|----------------------------------------------|
| 0   | 7 bits                                       |
| 1   | 8 bits                                       |

| SL2 | Transmit data stop bit length specification |
|-----|---------------------------------------------|
| 0   | 1 bit                                       |
| 1   | 2 bits                                      |

Cautions 1. Bits 0 and 1 must be fixed to 0.

- 2. If 3-wire serial I/O mode is selected, ASIM2 must be cleared to 00H.
- 3. Switch operating modes after halting the serial transmit/receive operation.

# Table 11-2. Operation Mode Settings for Serial Interface 2

# (1) Operation stopped mode

| AS       | IM2              |       | CSIM2 |       | PM32                   | P32                    | PM31                   | P31                    | PM30                   | P30                    | First<br>Bit | Shift<br>Clock | P32/SI2/RxD2<br>Pin Function |     | P30/SCK2/<br>ASCK2 Pin |
|----------|------------------|-------|-------|-------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|--------------|----------------|------------------------------|-----|------------------------|
| TXE2     | RXE2             | CSIE2 | DIR2  | CSCK2 |                        |                        |                        |                        |                        |                        | DIL          | CIUCK          |                              |     | Function               |
| 0        | 0                | 0     | ×     | ×     | $\times^{\rm Note  1}$ | -            | -              | P32                          | P31 | P30                    |
| Other th | Other than above |       |       |       |                        |                        |                        |                        |                        |                        | Setting      | prohibite      | ed                           |     |                        |

# (2) 3-wire serial I/O mode

| AS       | IM2              |       | CSIM2 |       | PM32                | P32                 | PM31 | P31 | PM30 | P30 | First              |                   |                       | P31/SO2/TxD2 |                       |
|----------|------------------|-------|-------|-------|---------------------|---------------------|------|-----|------|-----|--------------------|-------------------|-----------------------|--------------|-----------------------|
| TXE2     | RXE2             | CSIE2 | DIR2  | CSCK2 |                     |                     |      |     |      |     | Bit                | Clock             | Pin Function          | Pin Function | ASCK2 Pin<br>Function |
| 0        | 0                | 1     | 0     | 0     | 1 <sup>Note 2</sup> | × <sup>Note 2</sup> | 0    | 1   | 1    | ×   |                    | External<br>clock | SI2 <sup>Note 2</sup> | (CMOS        | SCK2 input            |
|          |                  |       |       | 1     |                     |                     |      |     | 0    | 1   |                    | Internal<br>clock |                       | output)      | SCK2 output           |
|          |                  | 1     | 1     | 0     |                     |                     |      |     | 1    | ×   |                    | External<br>clock |                       |              | SCK2 input            |
|          |                  |       |       | 1     |                     |                     |      |     | 0    | 1   |                    | Internal<br>clock |                       |              | SCK2 output           |
| Other th | Other than above |       |       |       |                     |                     |      |     |      |     | Setting prohibited |                   |                       |              |                       |

# (3) Asynchronous serial interface mode

| AS       | IM2              |       | CSIM2 |       | PM32                | P32                 | PM31                | P31                 | PM30                | P30                 | First |                   | P32/SI2/RxD2 |               |                       |
|----------|------------------|-------|-------|-------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|-------|-------------------|--------------|---------------|-----------------------|
| TXE2     | RXE2             | CSIE2 | DIR2  | CSCK2 |                     |                     |                     |                     |                     |                     | Bit   | Clock             | Pin Function | Pin Function  | ASCK2 Pin<br>Function |
| 1        | 0                | 0     | 0     | 0     | × <sup>Note 1</sup> | × <sup>Note 1</sup> | 0                   | 1                   | 1                   | ×                   | LSB   | External<br>clock | P32          | TxD2<br>(CMOS | ASCK2 input           |
|          |                  |       |       |       |                     |                     |                     |                     | × <sup>Note 1</sup> | × <sup>Note 1</sup> | ]     | Internal<br>clock |              | output)       | P30                   |
| 0        | 1                | 0     | 0     | 0     | 1                   | ×                   | × <sup>Note 1</sup> | × <sup>Note 1</sup> | 1                   | ×                   |       | External<br>clock | RxD2         | P31           | ASCK2 input           |
|          |                  |       |       |       |                     |                     |                     |                     | × <sup>Note 1</sup> | × <sup>Note 1</sup> | ]     | Internal<br>clock |              |               | P30                   |
| 1        | 1                | 0     | 0     | 0     | 1                   | ×                   | 0                   | 1                   | 1                   | ×                   | ]     | External clock    |              | TxD2<br>(CMOS | ASCK2 input           |
|          |                  |       |       |       |                     |                     |                     |                     | × <sup>Note 1</sup> | × <sup>Note 1</sup> |       | Internal<br>clock |              | output)       | P30                   |
| Other th | Dther than above |       |       |       |                     |                     |                     |                     |                     |                     |       | prohibit          | ed           | •             |                       |

Notes 1. These pins can be used for port functions.

2. When only transmission is used, this pin can be used as P32 (CMOS I/O).

Remark ×: Don't care

# (3) Asynchronous serial interface status register 2 (ASIS2)

ASIS2 is used to display the type of a reception error, if it occurs while asynchronous serial interface mode is set.

ASIS2 is read with a 1-bit or 8-bit memory manipulation instruction.

The contents of ASIS2 are undefined in 3-wire serial I/O mode.

RESET input clears ASIS2 to 00H.

#### Figure 11-5. Format of Asynchronous Serial Interface Status Register 2

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    | Address | After reset | R/W |
|--------|---|---|---|---|---|-----|-----|------|---------|-------------|-----|
| ASIS2  | 0 | 0 | 0 | 0 | 0 | PE2 | FE2 | OVE2 | FF71H   | 00H         | R   |

| PE2 | Parity error flag                                                   |  |  |  |  |  |
|-----|---------------------------------------------------------------------|--|--|--|--|--|
| 0   | No parity error has occurred.                                       |  |  |  |  |  |
| 1   | A parity error has occurred (parity mismatch in transmission data). |  |  |  |  |  |

| FE2 | Framing error flag                                                      |  |  |  |  |  |
|-----|-------------------------------------------------------------------------|--|--|--|--|--|
| 0   | No framing error has occurred.                                          |  |  |  |  |  |
| 1   | A framing error has occurred (no stop bit detected) <sup>Note 1</sup> . |  |  |  |  |  |

| OVE2 | Overrun error flag                                                                                                                                             |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | No overrun error has occurred.                                                                                                                                 |
| 1    | An overrun error has occurred <sup>Note 2</sup> .<br>(Before data was read from the receive buffer register, the subsequent reception sequence was completed.) |

**Notes 1.** Even when the stop bit length is set to 2 bits by setting bit 2 (SL2) of asynchronous serial interface mode register 2 (ASIM2), the stop bit detection in the case of reception is performed with 1 bit.

**2.** Be sure to read receive buffer register 2 (RXB2) when an overrun error occurs. If not, every time the data is received an overrun error occurs.

Figure 11-6. Format of Baud Rate Generator Control Register 2

# (4) Baud rate generator control register 2 (BRGC2)

BRGC2 is used to specify the serial clock for serial interface 2. BRGC2 is set by an 8-bit memory manipulation instruction.  $\overline{\mathsf{RESET}}$  input clears BRGC2 to 00H.

| Symbol | 7     | 6     | 5     | 4     | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|---|---|---|---|---------|-------------|-----|
| BRGC2  | TPS23 | TPS22 | TPS21 | TPS20 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS23 | TPS22                | TPS21 | TPS20 | 3-bit counter source clock selection                        | n |
|-------|----------------------|-------|-------|-------------------------------------------------------------|---|
| 0     | 0                    | 0     | 0     | fx/2 (2.5 MHz)                                              | 1 |
| 0     | 0                    | 0     | 1     | fx/2 <sup>2</sup> (1.25 MHz)                                | 2 |
| 0     | 0                    | 1     | 0     | fx/2 <sup>3</sup> (625 kHz)                                 | 3 |
| 0     | 0                    | 1     | 1     | fx/2 <sup>4</sup> (313 kHz)                                 | 4 |
| 0     | 1                    | 0     | 0     | fx/2 <sup>5</sup> (156 kHz)                                 | 5 |
| 0     | 1                    | 0     | 1     | fx/2 <sup>6</sup> (78.1 kHz)                                | 6 |
| 0     | 1                    | 1     | 0     | fx/2 <sup>7</sup> (39.1 kHz)                                | 7 |
| 0     | 1                    | 1     | 1     | fx/2 <sup>8</sup> (19.5 kHz)                                | 8 |
| 1     | 0                    | 0     | 0     | External clock pulse input at the ASCK2 pin <sup>Note</sup> | - |
|       | Other than above Set |       |       | Setting prohibited                                          |   |

**Note** An external clock can only be used in UART mode.

- Cautions 1. When writing to BRGC2 is performed during a communication operation, the output of baud rate generator is disrupted and communications cannot be performed normally. Be sure not to write to BRGC2 during communication operations.
  - 2. Do not select n = 1 during operation at  $f_x > 3$  MHz in the UART mode because n = 1 exceeds the baud rate limit.
  - 3. When the external input clock is selected, set port mode register 3 (PM3) to input mode.

**Remarks 1.** fx: System clock oscillation frequency

- **2.** n: Value specified by TPS20 to TPS23 ( $1 \le n \le 8$ )
- **3.** Figures in parentheses are for operation with fx = 5.0 MHz.

The baud rate transmit/receive clock to be generated is either a divided system clock signal, or a division of the clock input from the ASCK2 pin.

#### (a) Generation of baud rate transmit/receive clock by means of system clock

The transmit/receive clock is generated by dividing the system clock. The baud rate generated from the system clock is estimated by using the following expression.

[Baud rate] =  $\frac{f_X}{2^{n+1} \times 8}$  [Hz]

fx: System clock oscillation frequency

n: Values in Figure 11-6 specified by the setting in TPS20 to TPS23 ( $2 \le n \le 8$ )

#### Table 11-3. Example of Relationship Between System Clock and Baud Rate

| Baud Rate (bps) | n | BRGC2 Set Value | Erro         | r (%)           |
|-----------------|---|-----------------|--------------|-----------------|
|                 |   |                 | fx = 5.0 MHz | fx = 4.9152 MHz |
| 1,200           | 8 | 70H             | 1.73         | 0               |
| 2,400           | 7 | 60H             |              |                 |
| 4,800           | 6 | 50H             |              |                 |
| 9,600           | 5 | 40H             |              |                 |
| 19,200          | 4 | 30H             |              |                 |
| 38,400          | 3 | 20H             |              |                 |
| 76,800          | 2 | 10H             |              |                 |

Caution Do not select n = 1 during operation at fx > 3 MHz in the UART mode because n = 1 exceeds the baud rate limit.

(b) Generation of baud rate transmit/receive clock by means of external clock from ASCK2 pin The transmit/receive clock is generated by dividing the clock input from the ASCK2 pin. The baud rate generated from the clock input from the ASCK2 pin is estimated by using the following expression.

 $[\text{Baud rate}] = \frac{f_{\text{ASCK}}}{16} [\text{Hz}]$ 

fASCK: Frequency of clock input to the ASCK2 pin

#### Table 11-4. Relationship Between ASCK2 Pin Input Frequency and Baud Rate (When BRGC2 Is Set to 80H)

| Baud Rate (bps) | ASCK2 Pin Input Frequency (kHz) |
|-----------------|---------------------------------|
| 75              | 1.2                             |
| 150             | 2.4                             |
| 300             | 4.8                             |
| 600             | 9.6                             |
| 1,200           | 19.2                            |
| 2,400           | 38.4                            |
| 4,800           | 76.8                            |
| 9,600           | 153.6                           |
| 19,200          | 307.2                           |
| 31,250          | 500.0                           |
| 38,400          | 614.4                           |

### (c) Generation of serial clock from system clock in 3-wire serial I/O mode

The serial clock is generated by dividing the system clock. The serial clock frequency is estimated by using the following expression. BRGC2 does not need to be set when an external serial clock is input to the SCK2 pin.

Serial clock frequency =  $\frac{f_x}{2^{n+1}}$  [Hz]

- fx: System clock oscillation frequency
- n: Value (shown in Figure 11-6) determined by setting TPS20 to TPS23 ( $1 \le n \le 8$ )

# 11.4 Operation of Serial Interface 2

Serial interface 2 provides the following three modes.

- Operation stopped mode
- Asynchronous serial interface (UART) mode
- 3-wire serial I/O mode

# 11.4.1 Operation stopped mode

In the operation stopped mode, serial transfer is not executed, allowing a reduction in the power consumption. The P30/SCK2/ASCK2, P31/SO2/TxD2, and P32/SI2/RxD2 pins can be used as normal I/O ports.

# (1) Register setting

Operation stopped mode is set by serial operating mode register 2 (CSIM2) and asynchronous serial interface mode register 2 (ASIM2).

#### (a) Serial operating mode register 2 (CSIM2)

CSIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears CSIM2 to 00H.

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2    | 1     | 0 | Address | After reset | R/W |
|--------|-------|---|---|---|---|------|-------|---|---------|-------------|-----|
| CSIM2  | CSIE2 | 0 | 0 | 0 | 0 | DIR2 | CSCK2 | 0 | FF72H   | 00H         | R/W |

| CSIE2 | 3-wire serial I/O mode operation control |
|-------|------------------------------------------|
| 0     | Operation disabled                       |
| 1     | Operation enabled                        |

#### Caution Bits 0 and 3 to 6 must be fixed to 0.

# (b) Asynchronous serial interface mode register 2 (ASIM2)

ASIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears ASIM2 to 00H.

| Symbol | <7>  | <6>  | 5    | 4    | 3   | 2   | 1 | 0 | Address | After reset | R/W |
|--------|------|------|------|------|-----|-----|---|---|---------|-------------|-----|
| ASIM2  | TXE2 | RXE2 | PS21 | PS20 | CL2 | SL2 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE2 | Transmit operation control |  |  |  |  |
|------|----------------------------|--|--|--|--|
| 0    | Fransmit operation stopped |  |  |  |  |
| 1    | Transmit operation enabled |  |  |  |  |

| RXE2 | Receive operation control |
|------|---------------------------|
| 0    | Receive operation stopped |
| 1    | Receive operation enabled |

Caution Bits 0 and 1 must be fixed to 0.

#### 11.4.2 Asynchronous serial interface (UART) mode

In this mode, the one-byte data following the start bit is transmitted/received and thus full-duplex communication is possible.

This device incorporates a UART-dedicated baud rate generator that enables communication at a wide range of baud rates. In addition, the baud rate can also be defined by dividing the clock input to the ASCK2 pin.

The UART-dedicated baud rate generator can also output the 31.25 kbps baud rate that complies with the MIDI standard.

#### (1) Register setting

The UART mode is set by serial operating mode register 2 (CSIM2), asynchronous serial interface mode register 2 (ASIM2), asynchronous serial interface status register 2 (ASIS2), baud rate generator control register 2 (BRGC2), port mode register 3 (PM3), and port 3 (P3).

# (a) Serial operating mode register 2 (CSIM2)

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2    | 1     | 0 | Address | After reset | R/W |
|--------|-------|---|---|---|---|------|-------|---|---------|-------------|-----|
| CSIM2  | CSIE2 | 0 | 0 | 0 | 0 | DIR2 | CSCK2 | 0 | FF72H   | 00H         | R/W |

| CSIE2 | 3-wire serial I/O mode operation control |
|-------|------------------------------------------|
| 0     | Operation disabled                       |
| 1     | Operation enabled                        |

| DIR2 | First-bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

| CSCK2 | 3-wire serial I/O mode clock selection      |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|
| 0     | External clock pulse input to the SCK2 pin. |  |  |  |  |  |  |  |
| 1     | Output of the dedicated baud rate generator |  |  |  |  |  |  |  |

#### Cautions 1. Bits 0 and 3 to 6 must be fixed to 0.

2. Switch operating modes after halting the serial transmit/receive operation.

# (b) Asynchronous serial interface mode register 2 (ASIM2)

ASIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears ASIM2 to 00H.

| Symbol | <7>  | <6>  | 5    | 4    | 3   | 2   | 1 | 0 | Address | After reset | R/W |
|--------|------|------|------|------|-----|-----|---|---|---------|-------------|-----|
| ASIM2  | TXE2 | RXE2 | PS21 | PS20 | CL2 | SL2 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE2 | Transmit operation control |  |  |  |  |
|------|----------------------------|--|--|--|--|
| 0    | Transmit operation stopped |  |  |  |  |
| 1    | Transmit operation enabled |  |  |  |  |

| RXE2 | Receive operation control |
|------|---------------------------|
| 0    | Receive operation stopped |
| 1    | Receive operation enabled |

| PS21 | PS20 | Parity bit specification                                                                                     |
|------|------|--------------------------------------------------------------------------------------------------------------|
| 0    | 0    | No parity                                                                                                    |
| 0    | 1    | Always add 0 parity at transmission.<br>Parity check is not performed at reception (no parity error occurs). |
| 1    | 0    | Odd parity                                                                                                   |
| 1    | 1    | Even parity                                                                                                  |

| CL2 | Character length specification |
|-----|--------------------------------|
| 0   | 7 bits                         |
| 1   | 8 bits                         |

| SL2 | Transmit data stop bit length specification |
|-----|---------------------------------------------|
| 0   | 1 bit                                       |
| 1   | 2 bits                                      |

Cautions 1. Bits 0 and 1 must be fixed to 0.

2. Switch operating modes after halting the serial transmit/receive operation.

# (c) Asynchronous serial interface status register 2 (ASIS2)

ASIS2 is read with a 1-bit or 8-bit memory manipulation instruction. RESET input clears ASIS2 to 00H.

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    | Address | After reset | R/W |
|--------|---|---|---|---|---|-----|-----|------|---------|-------------|-----|
| ASIS2  | 0 | 0 | 0 | 0 | 0 | PE2 | FE2 | OVE2 | FF71H   | 00H         | R   |

| PE2 | Parity error flag                                                   |  |  |  |  |
|-----|---------------------------------------------------------------------|--|--|--|--|
| 0   | lo parity error has occurred.                                       |  |  |  |  |
| 1   | A parity error has occurred (parity mismatch in transmission data). |  |  |  |  |

| FE2 | 2 Framing error flag                                                    |  |  |  |  |  |
|-----|-------------------------------------------------------------------------|--|--|--|--|--|
| 0   | No framing error has occurred.                                          |  |  |  |  |  |
| 1   | A framing error has occurred (no stop bit detected) <sup>Note 1</sup> . |  |  |  |  |  |

| OVE2 | Overrun error flag                                                                                                                                             |  |  |  |  |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | lo overrun error has occurred.                                                                                                                                 |  |  |  |  |  |  |  |
| 1    | An overrun error has occurred <sup>Note 2</sup> .<br>(Before data was read from the receive buffer register, the subsequent reception sequence was completed.) |  |  |  |  |  |  |  |

- **Notes 1.** Even when the stop bit length is set to 2 bits by setting bit 2 (SL2) of asynchronous serial interface mode register 2 (ASIM2), the stop bit detection in the case of reception is performed with 1 bit.
  - **2.** Be sure to read receive buffer register 2 (RXB2) when an overrun error occurs. If not, every time the data is received an overrun error occurs.

# (d) Baud rate generator control register 2 (BRGC2)

BRGC2 is set by an 8-bit memory manipulation instruction. RESET input clears BRGC2 to 00H.

| Symbol | 7     | 6     | 5     | 4     | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|---|---|---|---|---------|-------------|-----|
| BRGC2  | TPS23 | TPS22 | TPS21 | TPS20 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS23 | TPS22            | TPS21 | TPS20 | 3-bit counter source clock selection    | n |
|-------|------------------|-------|-------|-----------------------------------------|---|
| 0     | 0                | 0     | 0     | fx/2 (2.5 MHz)                          | 1 |
| 0     | 0                | 0     | 1     | fx/2 <sup>2</sup> (1.25 MHz)            | 2 |
| 0     | 0                | 1     | 0     | fx/2 <sup>3</sup> (625 kHz)             | 3 |
| 0     | 0                | 1     | 1     | fx/2 <sup>4</sup> (313 kHz)             | 4 |
| 0     | 1                | 0     | 0     | fx/2 <sup>5</sup> (156 kHz)             | 5 |
| 0     | 1                | 0     | 1     | fx/2 <sup>6</sup> (78.1 kHz)            | 6 |
| 0     | 1                | 1     | 0     | fx/2 <sup>7</sup> (39.1 kHz)            | 7 |
| 0     | 1                | 1     | 1     | fx/2 <sup>8</sup> (19.5 kHz)            | 8 |
| 1     | 0                | 0     | 0     | Input clock from external to ASCK2 pin. | - |
| С     | Other than above |       | re    | Setting prohibited                      |   |

- Cautions 1. When writing to BRGC2 is performed during a communication operation, the output of baud rate generator is disrupted and communications cannot be performed normally. Be sure not to write to BRGC2 during a communication operation.
  - 2. Do not select n = 1 because the operation is performed at  $fx \ge 3$  MHz and n = 1 exceeds the baud rate limit.
  - 3. When the external input clock is selected, set port mode register 3 (PM3) to input mode.

## **Remarks 1.** fx: System clock oscillation frequency

- **2.** n: Value specified by TPS20 to TPS23 ( $1 \le n \le 8$ )
- **3.** Figures in parentheses are for operation with fx = 5.0 MHz.

The baud rate transmit/receive clock to be generated is either a divided system clock signal, or a division of the clock input from the ASCK2 pin.

#### (i) Generation of baud rate transmit/receive clock by means of system clock

The transmit/receive clock is generated by dividing the system clock. The baud rate generated from the system clock is estimated by using the following expression.

[Baud rate] = 
$$\frac{f_X}{2^{n+1} \times 8}$$
 [Hz]

fx: System clock oscillation frequency

n: Values in the above table specified by the setting in TPS20 to TPS23 ( $2 \le n \le 8$ )

#### Table 11-5. Example of Relationship Between System Clock and Baud Rate

| Baud Rate (bps) | n | BRGC2 Set Value | Error (%)    |                 |  |  |
|-----------------|---|-----------------|--------------|-----------------|--|--|
|                 |   |                 | fx = 5.0 MHz | fx = 4.9152 MHz |  |  |
| 1,200           | 8 | 70H             | 1.73         | 0               |  |  |
| 2,400           | 7 | 60H             |              |                 |  |  |
| 4,800           | 6 | 50H             |              |                 |  |  |
| 9,600           | 5 | 40H             |              |                 |  |  |
| 19,200          | 4 | 30H             |              |                 |  |  |
| 38,400          | 3 | 20H             |              |                 |  |  |
| 76,800          | 2 | 10H             |              |                 |  |  |

# Caution Do not select n = 1 because the operation is performed at $fx \ge 3$ MHz and n = 1 exceeds the baud rate limit.

(ii) Generation of baud rate transmit/receive clock by means of external clock from ASCK2 pin The transmit/receive clock is generated by dividing the clock input from the ASCK2 pin. The baud rate generated from the clock input from the ASCK2 pin is estimated by using the following expression.

 $[\text{Baud rate}] = \frac{f_{\text{ASCK}}}{16} [\text{Hz}]$ 

fasck: Frequency of clock input to the ASCK2 pin

#### Table 11-6. Relationship Between ASCK2 Pin Input Frequency and Baud Rate (When BRGC2 Is Set to 80H)

| Baud Rate (bps) | ASCK2 Pin Input Frequency (kHz) |
|-----------------|---------------------------------|
| 75              | 1.2                             |
| 150             | 2.4                             |
| 300             | 4.8                             |
| 600             | 9.6                             |
| 1,200           | 19.2                            |
| 2,400           | 38.4                            |
| 4,800           | 76.8                            |
| 9,600           | 153.6                           |
| 19,200          | 307.2                           |
| 31,250          | 500.0                           |
| 38,400          | 614.4                           |

# (e) Port mode register 3 (PM3)

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

When using the P31/TxD2/SO2 pin for serial interface data output, set PM31 to 0 and the output latch of P31 to 1.

When using the P32/RxD2/SI2 pin for serial interface data input, set PM32 to 1. At this time, the output latch of P32 may be either 0 or 1.

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

RESET input sets PM3 to FFH.

| Address: | FF23H | After reset | : FFH | R/W |      |      |      |      |
|----------|-------|-------------|-------|-----|------|------|------|------|
| Symbol   | 7     | 6           | 5     | 4   | 3    | 2    | 1    | 0    |
| PM3      | 1     | 1           | 1     | 1   | PM33 | PM32 | PM31 | PM30 |

| PM3n | P3n pin I/O mode selection (n = 0 to 3) |  |  |  |  |  |
|------|-----------------------------------------|--|--|--|--|--|
| 0    | Output mode (output buffer on)          |  |  |  |  |  |
| 1    | Input mode (output buffer off)          |  |  |  |  |  |

#### (2) Communication operation

### (a) Data format

The transmit/receive data format is as shown in Figure 11-7. One data frame consists of a start bit, character bits, parity bit and stop bit(s).

The specification of character bit length, the parity selection, and the specification of stop bit length for each data frame is carried out using asynchronous serial interface mode register 2 (ASIM2).



| •            |    |    |    | - 0 | ne dat | a fram | ne — |    |               |          |  |
|--------------|----|----|----|-----|--------|--------|------|----|---------------|----------|--|
| Start<br>bit | D0 | D1 | D2 | D3  | D4     | D5     | D6   | D7 | Parity<br>bit | Stop bit |  |

- Start bit ..... 1 bit
- Character bits ...... 7 bits/8 bits
- Parity bits ..... Even parity/odd parity/0 parity/no parity
- Stop bits ..... 1 bit/2 bits

When 7 bits are selected as the number of character bits, only the lower 7 bits (bits 0 to 6) are valid; in transmission the most significant bit (bit 7) is ignored, and in reception the most significant bit (bit 7) is always "0".

The serial transfer rate is selected by means of baud rate generator control register 2 (BRGC2).

If a serial data receive error occurs, the receive error contents can be determined by reading the status of asynchronous serial interface status register 2 (ASIS2).

#### (b) Parity types and operation

The parity bit is used to detect a bit error in the communication data. Normally, the same kind of parity bit is used on the transmitting side and the receiving side. With even parity and odd parity, a "1" bit (odd number) error can be detected. With 0 parity and no parity, an error cannot be detected.

#### (i) Even parity

#### • Transmission

The transmission operation is controlled so that the number of bits with a value of "1" in the transmit data including parity bit may be even. The parity bit value should be as follows.

The number of bits with a value of "1" is an odd number in transmit data: 1 The number of bits with a value of "1" is an even number in transmit data: 0

#### • Reception

The number of bits with a value of "1" in the receive data including parity bit is counted, and if the number is odd, a parity error occurs.

#### (ii) Odd parity

# Transmission

Conversely to even parity, the transmission operation is controlled so that the number of bits with a value of "1" in the transmit data including parity bit may be odd. The parity bit value should be as follows.

The number of bits with a value of "1" is an odd number in transmit data: 0 The number of bits with a value of "1" is an even number in transmit data: 1

#### • Reception

The number of bits with a value of "1" in the receive data including parity bit is counted, and if the number is even, a parity error occurs.

#### (iii) 0 parity

When transmitting, the parity bit is set to "0" irrespective of the transmit data. At reception, a parity bit check is not performed. Therefore, a parity error does not occur, irrespective of whether the parity bit is set to "0" or "1".

#### (iv) No parity

A parity bit is not added to the transmit data.

At reception, data is received assuming that there is no parity bit. Since there is no parity bit, a parity error does not occur.

#### (c) Transmission

A transmit operation is started by writing transmit data to transmit shift register 2 (TXS2). The start bit, parity bit and stop bit(s) are added automatically.

When the transmit operation starts, the data in TXS2 is shifted out, and when TXS2 is empty, a transmission completion interrupt (INTST20) is generated.





- Caution Do not rewrite asynchronous serial interface mode register 2 (ASIM2) during a transmit operation. If ASIM2 register is rewritten during transmission, subsequent transmission may not be performed (the normal state is restored by RESET input). It is possible to determine whether transmission is in progress by software by using a
  - transmission completion interrupt (INTST20) or the interrupt request flag (STIF20) set by INTST20.

### (d) Reception

When bit 6 (RXE2) of asynchronous serial interface mode register 2 (ASIM2) is set (1), a receive operation is enabled and sampling of the RxD2 pin input is performed.

RxD2 pin input sampling is performed using the serial clock specified by BRGC2.

When the RxD2 pin input becomes low, the 3-bit counter starts counting, and when half the time determined by the specified baud rate has passed, the data sampling start timing signal is output. If the RxD2 pin input sampled again as a result of this start timing signal is low, it is identified as a start bit, the 3-bit counter is initialized and starts counting, and data sampling is performed. When character data, a parity bit and one stop bit are detected after the start bit, reception of one frame of data ends.

When one frame of data has been received, the receive data in the shift register is transferred to receive buffer register 2 (RXB2), and a reception completion interrupt (INTSR20) is generated.

If an error occurs, the receive data in which the error occurred is still transferred to RXB2, and INTSR20 is generated.

If the RXE2 bit is reset (0) during the receive operation, the receive operation is stopped immediately. In this case, the contents of RXB2 and asynchronous serial interface status register 2 (ASIS2) are not changed, and INTSR20 is not generated.



Figure 11-9. Asynchronous Serial Interface Reception Completion Interrupt Timing

Caution Be sure to read receive buffer register 2 (RXB2) even if a receive error occurs. If RXB2 is not read, an overrun error will occur when the next data is received, and the receive error state will continue indefinitely.

#### (e) Receive errors

The following three errors may occur during a receive operation: a parity error, framing error, or overrun error. The data reception result error flag is set in asynchronous serial interface status register 2 (ASIS2). Receive error causes are shown in Table 11-7.

It is possible to determine what kind of error occurred during reception by reading the contents of ASIS2 in the reception error interrupt servicing (see **Figures 11-9** and **11-10**).

The contents of ASIS2 are reset (0) by reading receive buffer register 2 (RXB2) or receiving the next data (if there is an error in the next data, the corresponding error flag is set).

| Table 11-7. | Receive | Error | Causes |
|-------------|---------|-------|--------|
|-------------|---------|-------|--------|

| Receive Errors | Cause                                                                                |
|----------------|--------------------------------------------------------------------------------------|
| Parity error   | Transmission-time parity specification and reception data parity do not match        |
| Framing error  | Stop bit not detected                                                                |
| Overrun error  | Reception of next data is completed before data is read from receive buffer register |

Figure 11-10. Receive Error Timing

#### (a) Parity error occurs



- Cautions 1. The contents of the ASIS2 register are reset (0) by reading receive buffer register 2 (RXB2) or receiving the next data. To ascertain the error contents, read ASIS2 before reading RXB2.
  - 2. Be sure to read receive buffer register 2 (RXB2) even if a receive error occurs. If RXB2 is not read, an overrun error will occur when the next data is received, and the receive error state will continue indefinitely.

# (f) Reading receive data

If a reception completion interrupt (INTSR20) is generated, read the receive data by reading the values of receive buffer register 2 (RXB2).

Read the receive data stored in receive buffer register 2 (RXB2) while reception is enabled (RXE2 = 1).

- **Remark** If it is necessary to read the receive data while reception is disabled (RXE2 = 0), read the data using either method below.
  - (a) Wait one cycle or more of the source clock selected by BRGC2 and set RXE2 to 0, then read the data.
  - (b) Set bit 2 (DIR2) of serial operating mode register 2 (CSIM2) to 1, and then read the data.

| Programming e | example for (a) ( | (BRGC2 = 00H (source clock = fx/2))                             |
|---------------|-------------------|-----------------------------------------------------------------|
| INTRXE:       |                   | ; <reception completion="" interrupt="" routine=""></reception> |
| NOP           |                   | ;2 clocks                                                       |
| CLR1          | RXE2              | ; Reception operation stopped                                   |
| MOV           | A, RXB2           | ; Read receive data                                             |
|               |                   |                                                                 |

#### Programming example for (b)

| INTRXE: |         | ; <reception completion="" interrupt="" routine=""></reception> |
|---------|---------|-----------------------------------------------------------------|
| SET1    | CSIM2.2 | ; Set DIR2 flag to LSB first                                    |
| CLR1    | RXE2    | ; Reception operation stopped                                   |
| MOV     | A, RXB2 | ; Read receive data                                             |

#### (3) UART mode cautions

- (a) When bit 7 (TXE2) of asynchronous serial interface mode register 2 (ASIM2) is cleared during transmission, be sure to set transmit shift register 2 (TXS2) to FFH, then set TXE2 to 1 before executing the next transmission.
- (b) When bit 6 (RXE2) of asynchronous serial interface mode register 2 (ASIM2) is cleared during reception, receive buffer register 2 (RXB2) and receive completion interrupt 20 (INTSR20) are as follows.



When RXE2 is set to 0 at the time indicated by <1>, RXB2 holds the previous data and does not generate INTSR20.

When RXE2 is set to 0 at the time indicated by **<2>**, RXB2 renews the data and does not generate INTSR20. When RXE2 is set to 0 at the time indicated by **<3>**, RXB2 renews the data and generates INTSR20.

#### 11.4.3 3-wire serial I/O mode

The 3-wire serial I/O mode can be used to connect peripheral IC and display controllers, etc. that incorporate a synchronous clocked serial interface.

Communication is performed using three lines: the serial clock (SCK2), serial output (SO2), and serial input (SI2).

#### (1) Register setting

3-wire serial I/O mode settings are performed using serial operating mode register 2 (CSIM2), asynchronous serial interface mode register 2 (ASIM2), baud rate generator control register 2 (BRGC2), port mode register 3 (PM3), and port 3 (P3).

#### (a) Serial operating mode register 2 (CSIM2)

CSIM2 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input clears CSIM2 to 00H.

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2    | 1     | 0 | Address | After reset | R/W |
|--------|-------|---|---|---|---|------|-------|---|---------|-------------|-----|
| CSIM2  | CSIE2 | 0 | 0 | 0 | 0 | DIR2 | CSCK2 | 0 | FF72H   | 00H         | R/W |

| CSIE2 | 3-wire serial I/O mode operation control |  |  |  |  |  |  |
|-------|------------------------------------------|--|--|--|--|--|--|
| 0     | Operation disabled                       |  |  |  |  |  |  |
| 1     | Operation enabled                        |  |  |  |  |  |  |

| DIR2 | First-bit specification |
|------|-------------------------|
| 0    | MSB                     |
| 1    | LSB                     |

| CSCK2 | 3-wire serial I/O mode clock selection      |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|
| 0     | External clock pulse input to the SCK2 pin. |  |  |  |  |  |  |  |
| 1     | Putput of the dedicated baud rate generator |  |  |  |  |  |  |  |

Cautions 1. Bits 0 and 3 to 6 must be fixed to 0.

2. Switch operating modes after halting the serial transmit/receive operation.

# (b) Asynchronous serial interface mode register 2 (ASIM2)

ASIM2 is set by a 1-bit or 8-bit memory manipulation instruction.  $\overline{\text{RESET}}$  input clears ASIM2 to 00H. When the 3-wire serial I/O mode is selected, ASIM2 must be set to 00H.

| ,     |      |      |      |      |     |     |   |   | Address |     | R/W |
|-------|------|------|------|------|-----|-----|---|---|---------|-----|-----|
| ASIM2 | TXE2 | RXE2 | PS21 | PS20 | CL2 | SL2 | 0 | 0 | FF70H   | 00H | R/W |

| TXE2 | Transmit operation control |  |  |  |
|------|----------------------------|--|--|--|
| 0    | Transmit operation stopped |  |  |  |
| 1    | Transmit operation enabled |  |  |  |

| RXE2 | Receive operation control |
|------|---------------------------|
| 0    | Receive operation stopped |
| 1    | Receive operation enabled |

| PS21 | PS20 | Parity bit specification                                                                                     |  |  |  |  |  |
|------|------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0    | 0    | No parity                                                                                                    |  |  |  |  |  |
| 0    | 1    | Always add 0 parity at transmission.<br>Parity check is not performed at reception (no parity error occurs). |  |  |  |  |  |
| 1    | 0    | Odd parity                                                                                                   |  |  |  |  |  |
| 1    | 1    | Even parity                                                                                                  |  |  |  |  |  |

| CL2 | Character length specification |
|-----|--------------------------------|
| 0   | 7 bits                         |
| 1   | 8 bits                         |

| SL2 | Transmit data stop bit length specification |
|-----|---------------------------------------------|
| 0   | 1 bit                                       |
| 1   | 2 bits                                      |

Cautions 1. Bits 0 and 1 must be fixed to 0.

2. Switch operating modes after halting the serial transmit/receive operation.

# (c) Baud rate generator control register 2 (BRGC2)

BRGC2 is set by an 8-bit memory manipulation instruction. RESET input clears BRGC2 to 00H.

| Symbol | 7     | 6     | 5     | 4     | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|---|---|---|---|---------|-------------|-----|
| BRGC2  | TPS23 | TPS22 | TPS21 | TPS20 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS23 | TPS22            | TPS21 | TPS20 | 3-bit counter source clock selection | n |
|-------|------------------|-------|-------|--------------------------------------|---|
| 0     | 0                | 0     | 0     | fx/2 (2.5 MHz)                       | 1 |
| 0     | 0                | 0     | 1     | fx/2 <sup>2</sup> (1.25 MHz)         | 2 |
| 0     | 0                | 1     | 0     | fx/2 <sup>3</sup> (625 kHz)          | 3 |
| 0     | 0                | 1     | 1     | fx/2 <sup>4</sup> (313 kHz)          | 4 |
| 0     | 1                | 0     | 0     | fx/2 <sup>5</sup> (156 kHz)          | 5 |
| 0     | 1                | 0     | 1     | fx/2 <sup>6</sup> (78.1 kHz)         | 6 |
| 0     | 1                | 1     | 0     | fx/2 <sup>7</sup> (39.1 kHz)         | 7 |
| 0     | 1                | 1     | 1     | fx/2 <sup>8</sup> (19.5 kHz)         | 8 |
| C     | Other than above |       |       | Setting prohibited                   |   |

- Cautions 1. When writing to BRGC2 is performed during a communication operation, the baud rate generator output is disrupted and communication cannot be performed normally. Be sure not to write to BRGC2 during communication operation.
  - 2. When the external input clock is selected, set port mode register 3 (PM3) to input mode.

#### Remarks 1. fx: System clock oscillation frequency

- **2.** n: Values specified by TPS20 to TPS23 ( $1 \le n \le 8$ )
- **3.** Figures in parentheses are for operation with fx = 5.0 MHz.

If the internal clock is used as the serial clock for the 3-wire serial I/O mode, set the TPS20 to TPS23 bits to set the frequency of the serial clock. To obtain the frequency to be set, use the following formula. When the serial clock is input from off-chip, setting BRGC2 is not necessary.

Serial clock frequency = 
$$\frac{fx}{2^{n+1}}$$
 [Hz]

fx: System clock oscillation frequency

n: Values in the above table specified by the setting in TPS20 to TPS23 ( $1 \le n \le 8$ )

# (d) Port mode register 3 (PM3)

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

When using the P30/SCK2/ASCK2 pin for clock output and the P31/TxD2/SO2 pin for serial interface data output, set PM30 and PM31 to 0 and the output latch of P30 and P31 to 1.

When using the P30/SCK2/ASCK2 pin for clock input and the P32/RxD2/SI2 pin for serial interface data input, set PM30 and PM32 to 1. At this time, the output latch of P30 and P32 may be either 0 or 1.

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

RESET input sets PM3 to FFH.

| Address: FF23H |   | After reset | : FFH | R/W |      |      |      |      |  |
|----------------|---|-------------|-------|-----|------|------|------|------|--|
| Symbol         | 7 | 6           | 5     | 4   | 3    | 2    | 1    | 0    |  |
| PM3            | 1 | 1           | 1     | 1   | PM33 | PM32 | PM31 | PM30 |  |

| PM3n | P3n pin I/O mode selection (n = 0 to 3) |  |  |  |  |  |  |
|------|-----------------------------------------|--|--|--|--|--|--|
| 0    | Output mode (output buffer on)          |  |  |  |  |  |  |
| 1    | Input mode (output buffer off)          |  |  |  |  |  |  |

# (2) Communication operation

In the 3-wire serial I/O mode, data transmission/reception is performed in 8-bit units. Data is transmitted/received bit by bit in synchronization with the serial clock.

The transmit shift register (TXS2/SIO2) and receive shift register (RXS2) shift operations are performed in synchronization with the fall of the serial clock ( $\overline{SCK2}$ ). Then transmit data is held in the SO2 latch and output from the SO2 pin. Also, receive data input to the SI pin is latched in the receive buffer register (RXB2/SIO2) on the rise of  $\overline{SCK2}$ .

At the end of an 8-bit transfer, the operation of TXS2/SIO2 or RXS2 stops automatically, and an interrupt request signal (INTCSI20) is generated.



# (i) Master operation timing

Figure 11-11. 3-Wire Serial I/O Mode Timing

Note The value of the last bit output previously is output.







# (3) Transfer start

Serial transfer is started by setting transfer data to the transmit shift register (TXS2/SIO2) when the following two conditions are satisfied.

- Serial operating mode register 2 (CSIM2) bit 7 (CSIE2) = 1
- Internal serial clock is stopped or SCK2 is a high level after 8-bit serial transfer.

# Caution If CSIE2 is set to 1 after data is written to TXS2/SIO2, transfer does not start.

Termination of 8-bit transfer stops the serial transfer automatically and generates an interrupt request signal (INTCSI20).

# CHAPTER 12 POWER-ON-CLEAR CIRCUITS

# **12.1 Power-on-Clear Circuit Functions**

The power-on-clear circuits include the following two circuits, which have the following functions.

# (1) Power-on-clear (POC) circuit

- Compares the detection voltage (VPOC) with the power supply voltage (VDD) and generates an internal reset signal if VDD < VPOC.</li>
- The mask ROM versions can select a POC switching circuit, normally operating POC circuit, or normally halted POC circuit by using a mask option. When a POC switching circuit is selected, POC operation can be controlled by software (refer to **CHAPTER 19 MASK OPTIONS**).
- This circuit can operate even in STOP mode.

# (2) Low-voltage detection (LVI) circuit

- Compares the detection voltage (VLVI) with the power supply voltage (VDD) and generates an interrupt request signal (INTLVI1) if VDD < VLVI.
- Eight levels of detection voltage can be selected using software.
- This circuit stops operation in STOP mode.

# 12.2 Configuration of Power-on-Clear Circuit

Figures 12-1 and 12-2 show the block diagrams of the power-on-clear circuits.





Figure 12-2. Block Diagram of Low-Voltage Detector



# 12.3 Power-on-Clear Circuit Control Registers

The following three registers control the power-on-clear circuits.

- Power-on-clear register (POCF)
- Low-voltage detection register (LVIF)
- Low-voltage detection level selection register (LVIS)

## (1) Power-on-clear register (POCF)

This register controls POC circuit operation.

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

#### Figure 12-3. Format of Power-on-Clear Register

| Symbol | 7 | 6 | 5 | 4 | 3 | <2>   | <1>    | <0>    | Address | After reset         | R/W |
|--------|---|---|---|---|---|-------|--------|--------|---------|---------------------|-----|
| POCF   | 0 | 0 | 0 | 0 | 0 | POCOF | POCMK1 | POCMK0 | FF80H   | 00H <sup>Note</sup> | R/W |

| POCOF | POC output detection flag                                                                  |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | Non-generation of reset signal by POC or in cleared state due to a write operation to POCF |  |  |  |  |  |
| 1     | Generation of reset signal by POC                                                          |  |  |  |  |  |

| I | POCMK1 | POC reset control                          |  |  |  |  |
|---|--------|--------------------------------------------|--|--|--|--|
| I | 0      | Generation of reset signal by POC enabled  |  |  |  |  |
| I | 1      | Generation of reset signal by POC disabled |  |  |  |  |

| POCMK0 | POC operation control |
|--------|-----------------------|
| 0      | POC operating         |
| 1      | POC halted            |

Note This value is 04H only after a power-on-clear reset.

Caution The POCMK0 and POCMK1 in the mask ROM version are only valid when a POC switching circuit has been selected using a mask option.

## (2) Low-voltage detection register (LVIF)

This register controls the operation of the LVI circuit. LVIF is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

#### Figure 12-4. Format of Low-Voltage Detection Register



| LVION | LVI operation enable flag |  |  |  |  |  |
|-------|---------------------------|--|--|--|--|--|
| 0     | LVI disabled              |  |  |  |  |  |
| 1     | LVI enabled               |  |  |  |  |  |

| LVF10 | LVI output detection flag                                                                     |  |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | Power supply voltage ( $V_{DD}$ ) > LVI detection voltage ( $V_{LVI}$ ) or operation disabled |  |  |  |  |  |
| 1     | V <sub>DD</sub> < V <sub>LVI</sub>                                                            |  |  |  |  |  |

**Note** Bit 0 is read only.

#### (3) Low-voltage detection level selection register (LVIS)

This register selects the level of the detection voltage (VLVI). LVIS is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

#### Figure 12-5. Format of Low-Voltage Detection Level Selection Register

| Symbol | 7 | 6 | 5 | 4 | 3 | <2>   | <1>   | <0>   | Address After reset | R/W |
|--------|---|---|---|---|---|-------|-------|-------|---------------------|-----|
| LVIS   | 0 | 0 | 0 | 0 | 0 | LVS12 | LVS11 | LVS10 | FF82H 00H           | R/W |

| LVS12 | LVS11 | LVS10 | Selection of detection voltage (VLVI) level <sup>Note</sup> |
|-------|-------|-------|-------------------------------------------------------------|
| 0     | 0     | 0     | VLVIO                                                       |
| 0     | 0     | 1     | VLVI1                                                       |
| 0     | 1     | 0     | VLVI2                                                       |
| 0     | 1     | 1     | Vlvis                                                       |
| 1     | 0     | 0     | V <sub>LVI4</sub>                                           |
| 1     | 0     | 1     | Vlvis                                                       |
| 1     | 1     | 0     | VLVI6                                                       |
| 1     | 1     | 1     | Vlvi7                                                       |

**Note** Refer to each chapter of electrical specifications for detection voltage specifications.

Caution When changing the detection voltage level (VLVI), an operation stabilization time of about 2 ms is required in order for the LVI output to stabilize. Do not, therefore, set the LVI circuit to operation-enabled until the operation has stabilized.

## 12.4 Power-on-Clear Circuit Operation

## 12.4.1 Power-on-clear (POC) circuit operation

The POC circuit compares the detection voltage (VPoc) with the power supply voltage (VDD) and generates an internal reset signal if VDD < VPOC.

For mask ROM versions, it is possible to select a POC switching circuit, normally operating POC circuit, or normally halted POC circuit by using a mask option. When a POC switching circuit is selected, POC operation can be controlled by software. In the  $\mu$ PD78E9862, only the POC switching circuit is available (circuits cannot be selected by a mask option).

Observe the following procedure when switching POC operation using the POC switching circuit.

## (1) Switching from POC stopped to POC operating

- <1> Check that POCMK1 = 1
- <2> Set POCMK0 to 0 to put the POC circuit into the operating state
- <3> Wait until the operation stabilization time has elapsed (because the output signal is unstable, generation of the reset signal via the POC circuit is set to disabled)
- <4> Set POCMK1 to 0 to enable generation of the reset signal via the POC circuit

#### (2) Switching from POC operating to POC stopped

- <1> Set POCMK1 to 1 to disable generation of the reset signal via the POC circuit
- <2> Set POCMK0 to 1 to put the POC circuit into the operation stopped state

Generation of the reset signal via the POC circuit can be determined by reading the POCOF flag. When the reset signal is generated via the POC circuit, POCOF is set to 1. POCOF is cleared to 0 by writing to POCF<sup>Note</sup>. When using the POC circuit, clear POCOF beforehand.

★ Note POCOF is cleared by writing to one of bits 0 to 2.

Figures 12-6 to 12-8 show the timing of reset signal generation via the POC circuit.



Figure 12-6. Timing of Internal Reset Signal Generation When POC Circuit Normally Operating

Figure 12-7. Timing of Internal Reset Signal Generation When POC Circuit Normally Halted





Figure 12-8. Timing of Internal Reset Signal Generation in POC Switching Circuit

#### 12.4.2 Operation of low-voltage detector (LVI)

The LVI circuit compares the detection voltage ( $V_{LVI}$ ) with the power supply voltage ( $V_{DD}$ ) and generates an interrupt request signal (INTLVI1) if  $V_{DD} < V_{LVI}$  (LVI circuit operating).

As shown in **Figure 12-2 Block Diagram of Low-Voltage Detector**, the divided resistors and comparators of the LVI circuit turn OFF when the reset signal is generated or in STOP mode. After reset is released, LVI operation starts when LVION (bit 7 of the low-voltage detection register (LVIF)) is set. At this time, approximately 2 ms are required until the LVI circuit operation is stabilized.

Once the LVI operation is started, divided resistors and comparators cannot be turned OFF unless the STOP instruction or reset signal is generated, even if LVION is cleared. Low-voltage detection is enabled immediately after LVION is set again.

#### ★ Caution The divided resistors and comparators of the LVI circuit are turned ON after reset is released.

Use one of the following methods to constantly monitor low voltage.

- <1> Low-voltage monitoring by LVF10 (bit 0 of the low-voltage detection register (LVIF)) without using the LVI detection interrupt.
- <2> Low-voltage monitoring using the LVI detection interrupt. In this case, disable the LVI operation once, and then enable it (LVION =  $0 \rightarrow 1$ ) before enabling interrupts (LVIMK1 = 0).

An example of a program in which low voltage is constantly monitored using the LVI detection interrupt is shown below.

#### (a) Processing when reset mode is released

DI

| MOV  | LVIS, #xxH | ; Setting LVI detection voltage |
|------|------------|---------------------------------|
| SET1 | LVIMK1     | ; LVI interrupt disabled        |
| SET1 | LVION      | ; LVI operation enabled         |
| CALL | !WAIT_2ms  | ; 2 ms wait                     |
| CLR1 | LVIIF1     |                                 |
| CLR1 | LVION      | ; LVI operation disabled        |
| SET1 | LVION      | ; LVI operation enabled         |
| CLR1 | LVIMK1     | ; LVI interrupt enabled         |
| EI   |            |                                 |

## (b) Processing when STOP mode is released

| SET1 | LVIMK1 | ; LVI interrupt disabled                                        |
|------|--------|-----------------------------------------------------------------|
| STOP |        |                                                                 |
| CALL | !WAIT  | ; Total 2 ms wait, combined with oscillation stabilization time |
| CLR1 | LVIIF1 |                                                                 |
| CLR1 | LVION  | ; LVI operation disabled                                        |
| SET1 | LVION  | ; LVI operation enabled                                         |
| CLR1 | LVIMK1 | ; LVI interrupt enabled                                         |
| EI   |        |                                                                 |

(c) Processing to enable LVI interrupt again after LVI interrupt servicing

| SET1 | LVIMK1 | ; LVI interrupt disabled |
|------|--------|--------------------------|
| CLR1 | LVION  | ; LVI operation disabled |
| SET1 | LVION  | ; LVI operation enabled  |
| CLR1 | LVIMK1 | ; LVI interrupt enabled  |
| EI   |        |                          |

Figure 12-9 shows the LVI circuit operation timing.

\*





Caution The low-voltage detection interrupt request flag (LVIIF1) is set at the rising edge of the LVI circuit comparator output signal (INTLVI1). Therefore, the power supply voltage (V<sub>DD</sub>) becomes lower than the detection voltage (V<sub>LVI</sub>) during LVI operation, and if that state continues after INTLVI1 generation, LVIIF1 is not set. After low-voltage detection, when set as V<sub>DD</sub> > V<sub>LVI</sub> and then V<sub>DD</sub> < V<sub>LVI</sub> again, LVIIF1 is set.

# CHAPTER 13 BIT SEQUENTIAL BUFFER

## **13.1 Bit Sequential Buffer Functions**

The  $\mu$ PD789862 Subseries has an on-chip bit sequential buffer of 8 bits + 8 bits = 16 bits. The functions of the bit sequential buffer are shown below.

- If the value of the bit sequential buffer 1 data register (BSFRL10, BSFRH10) is shifted 1 bit to the lower side, the LSB can be output to the port at the same time.
- It is possible to write to BSFRL10 and BSFRH10 using an 8-bit or 16-bit memory manipulation instruction (reading is not possible).
- Overwriting is enabled during a shift operation on the higher 8 bits (BSFRH10) only (the period in which the shift clock is low level).

# 13.2 Bit Sequential Buffer Configuration

The bit sequential buffer includes the following hardware.

| Table 13-1. | Configuration of Bi | t Sequential Buffer |
|-------------|---------------------|---------------------|
|-------------|---------------------|---------------------|

| Item              | Configuration                                                                                        |  |  |  |  |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Data register     | Bit sequential buffer: 8 bits $\times$ 8 bits = 16 bits                                              |  |  |  |  |  |  |  |
| Control registers | Bit sequential buffer 1 output control register (BSF1C)<br>Port mode register 2 (PM2)<br>Port 2 (P2) |  |  |  |  |  |  |  |





# 13.3 Bit Sequential Buffer Control Registers

The following registers control the bit sequential buffer.

- Bit sequential buffer 1 output control register (BSF1C)
- Port mode register 2 (PM2)
- Port 2 (P2)

# (1) Bit sequential buffer 1 output control register (BSF1C)

This register controls the operation of the bit sequential buffer. BSF1C is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets this register to 00H.

## Figure 13-2. Format of Bit Sequential Buffer 1 Output Control Register



## (2) Port mode register 2 (PM2)

This register sets port 2 input/output in 1-bit units. When using the P20/BSFO0 and P21/BSFO1 pins for data output of the bit sequential buffer, set PM20 and PM21 and the output latches of P20 and P21 to 0.

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

RESET input sets PM2 value to FFH.

#### Figure 13-3. Format of Port Mode Register 2 (PM2)



| 0 | Output mode (output buffer on) |
|---|--------------------------------|
| 1 | Input mode (output buffer off) |

# 13.4 Bit Sequential Buffer Operation

Set as follows to operate the bit sequential buffer.

- <1> Set values to bit sequential buffer 1 data registers L and H (BSFRL10, BSFRH10)
- <2> Set the bit sequential buffer to operation enabled (BSFE1 = 1)

If the LSB of BSFRL10 is being output at P20/BSFO0, set P20 to output mode (PM20 = 0) and the output latch of P20 to 0

If the LSB of BSFRL10 is being output at P21/BSFO1, set P21 to output mode (PM21 = 0) and the output latch of P21 to 0

<3> Start the clock operation

If the clock is input before the bit sequential buffer starts operation, the output time of the start bit may be shorter than one cycle of the clock when output commences, as shown in the figure below.



Remark x: Undefined

Figure 13-4 shows the operation timing of the bit sequential buffer.



## Figure 13-4. Operation Timing of Bit Sequential Buffer

- Cautions 1. The higher 8 bits (BSFRH10) of the data register can be overwritten while the bit sequential buffer is operating. Even if data is written to the data register, the shift clock will not stop. Write data to the data register when the shift clock (match signal of 16-bit timer D) is low level (refer to 13.5 Notes).
  - 2. The value of the data register is undefined after a shift.

Remark x: Undefined

# 13.5 Notes

When overwriting the higher 8 bits (BSFRH10) of the data register while the bit sequential buffer is operating, data must be written when the shift clock (match signal of 16-bit timer D) is low level.

The match signal of 16-bit timer D is high level during one cycle of the count clock selected by setting bits 6 to 4 (CS2 to CS0) of 16-bit timer mode control register D (TMCD).

| Bits | s 6 to 4 of TN | ICD | Count Clock       | Match Signal High Level Width |  |  |
|------|----------------|-----|-------------------|-------------------------------|--|--|
| CS2  | CS1            | CS0 |                   |                               |  |  |
| 0    | 0              | 0   | fx/2              | fx/2                          |  |  |
| 0    | 0              | 1   | fx/2 <sup>2</sup> | fx/2 <sup>2</sup>             |  |  |
| 0    | 1              | 0   | fx/2 <sup>3</sup> | fx/2 <sup>3</sup>             |  |  |
| 0    | 1              | 1   | fx/2 <sup>4</sup> | fx/2 <sup>4</sup>             |  |  |
| 1    | 0              | 0   | fx/2 <sup>5</sup> | fx/2 <sup>5</sup>             |  |  |
| 1    | 0              | 1   | f×/2 <sup>6</sup> | fx/2 <sup>6</sup>             |  |  |
| 1    | 1              | 0   | fx/2 <sup>7</sup> | fx/2 <sup>7</sup>             |  |  |
| 1    | 1              | 1   | fx/2 <sup>8</sup> | fx/2 <sup>8</sup>             |  |  |

Table 13-2. Count Clock and Match Signal High Level Width of 16-Bit Timer D

Figure 13-5. Match Signal of 16-Bit Timer D



# CHAPTER 14 KEY RETURN CIRCUIT

# 14.1 Key Return Circuit Function

Either of the following two operations can be selected.

<1> When KRREN pin = High level

This circuit generates an internal non-maskable interrupt based on KR0 to KR5 falling edge input.

- KR0: The falling edge can be independently detected regardless of the status of KR1 to KR5.
- KR1 to KR4: The falling edge is detected by ORing the input of four pins.
- KR5: The rising/falling edge can be selected by setting the EDG register.
   The edge can be independently detected regardless of the status of KR0 to KR4.
- <2> When KRREN pin = Low level

In STOP mode, this circuit generates an internal reset signal based on KR0 to KR5 falling edge input.

- KR0: The falling edge can be independently detected regardless of the status of KR1 to KR5.
- KR1 to KR4: The falling edge is detected by ORing the input of four pins.
- KR5: The rising/falling edge can be selected by setting the EDG register.
   The edge can be independently detected regardless of the status of KR0 to KR4.
- Caution If the KRREN pin is used at low level, an internal reset signal is generated when a key return occurs in the STOP mode. If a key return occurs in other than STOP mode, a non-maskable interrupt (NMI) is generated and the program branches to the vector address. If an NMI is not used, execute the following routine in the NMI vector routine.

(INTNMI: NMI vector processing of key return) INTNMI: RETI

# 14.2 Key Return Circuit Configuration and Operation

Figures 14-1 and 14-2 show the block diagram of the key return circuit and the format of the key return edge detection register, respectively.





## Figure 14-2. Format of Key Return Edge Detection Register

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2 | 1 | <0>  | Address | After reset | R/W |
|--------|-------|---|---|---|---|---|---|------|---------|-------------|-----|
| EDG    | KRRES | 0 | 0 | 0 | 0 | 0 | 0 | EDG0 | FF90H   | Note        | R/W |

| EDG0 | Switching edge detection of KR5 pin |
|------|-------------------------------------|
| 0    | Falling edge detected               |
| 1    | Rising edge detected                |

| KRRES | Reset output type                                   |  |  |  |  |  |  |
|-------|-----------------------------------------------------|--|--|--|--|--|--|
| 0     | eset output by source other than key return circuit |  |  |  |  |  |  |
| 1     | Reset output by key return circuit                  |  |  |  |  |  |  |

- **Note** The value after the key return reset is 1000000×B (bit 0 retains the value before the key return reset is input), and in other cases, the value is 00H.
- Caution When switching the edge detection, change the input waveform after manipulating the EDG0 bit.

# **CHAPTER 15 INTERRUPT FUNCTIONS**

# **15.1 Interrupt Function Types**

The following two types of interrupt functions are used.

## (1) Non-maskable interrupt

This interrupt is acknowledged unconditionally. It does not undergo interrupt priority control and is given top priority over all other interrupt requests.

A standby release signal is generated.

The non-maskable interrupt has one external interrupt source and one internal interrupt source.

#### (2) Maskable interrupt

These interrupts undergo mask control. If two or more interrupts with the same priority are generated, each interrupt has a predetermined priority as shown in Table 15-1.

A standby release signal is generated.

The maskable interrupt has two external interrupt sources and nine internal interrupt sources.

## **15.2 Interrupt Sources and Configuration**

There are total of 13 non-maskable and maskable interrupt sources (see Table 15-1).

| Interrupt        | Priority <sup>Note 1</sup> |          | Interrupt Source                                                                                                                                       | Internal  | Vector           | Basic                                   |
|------------------|----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------|-----------------------------------------|
| Туре             |                            | Name     | Trigger                                                                                                                                                | /External | Table<br>Address | Configuration<br>Type <sup>Note 2</sup> |
| Non-<br>maskable | _                          | INTKR00  | Key return input falling edge detection (KR5 can detect both the rising and falling edges)                                                             | External  | 0002H            | (A)                                     |
|                  |                            | INTWDT   | Watchdog timer overflow (with watchdog timer mode 1 selected)                                                                                          | Internal  | 0004H            |                                         |
| Maskable         | 0                          | INTWDT   | Watchdog timer overflow (with interval timer mode selected)                                                                                            |           |                  | (B)                                     |
|                  | 1                          | INTP0    | Pin input edge detection                                                                                                                               | External  | 0006H            | (C)                                     |
|                  | 2                          | INTP1    |                                                                                                                                                        |           | 0008H            |                                         |
|                  | 3                          | INTCMD   | Match of TMD and CMD                                                                                                                                   | Internal  | 000AH            | (B)                                     |
|                  | 4                          | INTTMOO  | Match of TM0 and CR00 (when CR00 is<br>specified as compare register)<br>TI01 pin valid edge detection (when CR00 is<br>specified as capture register) |           | 000CH            |                                         |
|                  | 5                          | INTTM01  | Match of TM0 and CR01 (when CR01 is<br>specified as compare register)<br>TI00 pin valid edge detection (when CR01 is<br>specified as capture register) |           | 000EH            |                                         |
|                  | 6                          | INTTM50  | Match of TM5 and CR5                                                                                                                                   |           | 0010H            |                                         |
|                  | 7                          | INTSR20  | End of serial interface 2 UART reception                                                                                                               | 1         | 0012H            |                                         |
|                  |                            | INTCSI20 | End of serial interface 2 3-wire transfer                                                                                                              |           |                  |                                         |
|                  | 8                          | INTST20  | End of serial interface 2 UART transmission                                                                                                            | ]         | 0014H            |                                         |
|                  | 9                          | INTLVI1  | LVI interrupt detection                                                                                                                                |           | 0016H            | 1                                       |
|                  | 10                         | INTEE0   | EEPROM write completion signal                                                                                                                         |           | 0018H            |                                         |

## Table 15-1. Interrupt Source List

- **Notes 1.** Priority is the priority applicable when two or more maskable interrupts are simultaneously generated. 0 is the highest priority and 10 is the lowest priority.
  - 2. Basic configuration types A to C correspond to A to C in Figure 15-1.
- **Remark** Either a non-maskable interrupt or a maskable interrupt (internal) can be selected as the interrupt source of the watchdog timer (INTWDT).

## Figure 15-1. Basic Configuration of Interrupt Function

# (A) External/internal non-maskable interrupt



## (B) Internal maskable interrupt



#### (C) External maskable interrupt



IF: Interrupt request flag

IE: Interrupt enable flag

MK: Interrupt mask flag

# **15.3 Interrupt Function Control Registers**

The following four registers are used to control the interrupt functions.

- Interrupt request flag registers (IF0, IF1)
- Interrupt mask flag registers (MK0, MK1)
- External interrupt mode register (INTM0)
- Program status word (PSW)

Table 15-2 gives a listing of interrupt request flag and interrupt mask flag names corresponding to interrupt requests.

| Interrupt Request Signal Name | Interrupt Request Flag | Interrupt Mask Flag |
|-------------------------------|------------------------|---------------------|
| INTWDT                        | WDTIF                  | WDTMK               |
| INTP0                         | PIF0                   | РМКО                |
| INTP1                         | PIF1                   | PMK1                |
| INTCMD                        | TMIFD                  | ТММКD               |
| INTTM00                       | TMIF00                 | ТММК00              |
| INTTM01                       | TMIF01                 | TMMK01              |
| INTTM50                       | TMIF50                 | TMMK50              |
| INTSR20/INTCSI20              | SRIF20                 | SRMK20              |
| INTST20                       | STIF20                 | STMK20              |
| INTLVI1                       | LVIIF1                 | LVIMK1              |
| INTEE0                        | EEIFO                  | EEMKO               |

## Table 15-2. Flags Corresponding to Interrupt Request Signal

## (1) Interrupt request flag registers (IF0, IF1)

The interrupt request flag is set to 1 when the corresponding interrupt request is generated or an instruction is executed. It is cleared to 0 when an instruction is executed upon acknowledgement of an interrupt request or upon RESET input.

IF0 and IF1 are set by a 1-bit or 8-bit memory manipulation instruction.

RESET input clears these registers to 00H.

## Figure 15-2. Format of Interrupt Request Flag Register

| Symbol | <7>    | <6>    | <5>    | <4>    | <3>   | <2>   | <1>    | <0>    | Address | After reset | R/W |
|--------|--------|--------|--------|--------|-------|-------|--------|--------|---------|-------------|-----|
| IF0    | SRIF20 | TMIF50 | TMIF01 | TMIF00 | TMIFD | PIF1  | PIF0   | WDTIF  | FFE0H   | 00H         | R/W |
|        |        |        |        |        |       |       |        |        |         |             |     |
| Symbol | 7      | 6      | 5      | 4      | 3     | <2>   | <1>    | <0>    | Address | After reset | R/W |
| IF1    | 0      | 0      | 0      | 0      | 0     | EEIF0 | LVIIF1 | STIF20 | FFE1H   | 00H         | R/W |

| ××IF× | Interrupt request flag                                         |  |  |  |  |  |  |  |
|-------|----------------------------------------------------------------|--|--|--|--|--|--|--|
| 0     | No interrupt request signal is generated                       |  |  |  |  |  |  |  |
| 1     | Interrupt request signal is generated; Interrupt request state |  |  |  |  |  |  |  |

Cautions 1. WDTIF flag is R/W enabled only when the watchdog timer is used as an interval timer. If the watchdog timer mode 1 and 2 are used, set the WDTIF flag to 0.

- 2. Because ports 2 and 3 have an alternate function as the external interrupt input, when the output level is changed by specifying the output mode of the port function, an interrupt request flag is set. Therefore, the interrupt mask flag should be set to 1 before using the output mode.
- 3. When an interrupt is acknowledged, the interrupt request flag is automatically cleared and then the interrupt routine is entered.

# (2) Interrupt mask flag registers (MK0, MK1)

The interrupt mask flag is used to enable/disable the corresponding maskable interrupt service. MK0 and MK1 are set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets these registers to FFH.

## Figure 15-3. Format of Interrupt Mask Flag Register

| <7>    | <6>    | <5>                  | <4>                  | <3>                                    | <2>                                            | <1>                                                                                                                                            | <0>                                                                                                                                                                     | Address               | After reset                                                                                                                                                                                                            | R/W                                                                                                                                                                                                   |
|--------|--------|----------------------|----------------------|----------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRMK20 | TMMK50 | TMMK01               | ТММК00               | TMMKD                                  | PMK1                                           | PMK0                                                                                                                                           | WDTMK                                                                                                                                                                   | FFE4H                 | FFH                                                                                                                                                                                                                    | R/W                                                                                                                                                                                                   |
|        |        |                      |                      |                                        |                                                |                                                                                                                                                |                                                                                                                                                                         |                       |                                                                                                                                                                                                                        |                                                                                                                                                                                                       |
| 7      | 6      | 5                    | 4                    | 3                                      | <2>                                            | <1>                                                                                                                                            | <0>                                                                                                                                                                     | Address               | After reset                                                                                                                                                                                                            | R/W                                                                                                                                                                                                   |
| 1      | 1      | 1                    | 1                    | 1                                      | EEMK0                                          | LVIMK1                                                                                                                                         | STMK20                                                                                                                                                                  | FFE5H                 | FFH                                                                                                                                                                                                                    | R/W                                                                                                                                                                                                   |
|        | SRMK20 | SRMK20 TMMK50<br>7 6 | SRMK20 TMMK50 TMMK01 | SRMK20 TMMK50 TMMK01 TMMK00<br>7 6 5 4 | SRMK20 TMMK50 TMMK01 TMMK00 TMMKD<br>7 6 5 4 3 | SRMK20         TMMK50         TMMK01         TMMK00         TMMKD         PMK1           7         6         5         4         3         <2> | SRMK20         TMMK50         TMMK01         TMMK00         TMMKD         PMK1         PMK0           7         6         5         4         3         <2>         <1> | 7 6 5 4 3 <2> <1> <0> | SRMK20         TMMK50         TMMK01         TMMK00         TMMK0         PMK1         PMK0         WDTMK         FFE4H           7         6         5         4         3         <2>         <1><0>         Address | SRMK20       TMMK01       TMMK00       TMMKD       PMK1       PMK0       WDTMK       FFE4H       FFH         7       6       5       4       3       <2>       <1><0>       Address       After reset |

| ××МК× | Interrupt servicing control  |
|-------|------------------------------|
| 0     | Interrupt servicing enabled  |
| 1     | Interrupt servicing disabled |

- Cautions 1. If the WDTMK flag is read when the watchdog timer is used in watchdog timer mode 1 and 2, its value becomes undefined.
  - 2. Because ports 2 and 3 have an alternate function as the external interrupt input, when the output level is changed by specifying the output mode of the port function, an interrupt request flag is set. Therefore, the interrupt mask flag should be set to 1 before using the output mode.

# (3) External interrupt mode register 0 (INTM0)

This register is used to set the valid edge of INTP0 and INTP1. INTM0 is set by an 8-bit memory manipulation instruction. RESET input clears INTM0 to 00H.

## Figure 15-4. Format of External Interrupt Mode Register 0

| Symbol | 7 | 6 | 5    | 4    | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|---|---|------|------|------|------|---|---|---------|-------------|-----|
| INTM0  | 0 | 0 | ES11 | ES10 | ES01 | ES00 | 0 | 0 | FFECH   | 00H         | R/W |

| ES11 | ES10 | INTP1 valid edge selection    |
|------|------|-------------------------------|
| 0    | 0    | Falling edge                  |
| 0    | 1    | Rising edge                   |
| 1    | 0    | Setting prohibited            |
| 1    | 1    | Both rising and falling edges |

| ES01 | ES00 | INTP0 valid edge selection    |
|------|------|-------------------------------|
| 0    | 0    | Falling edge                  |
| 0    | 1    | Rising edge                   |
| 1    | 0    | Setting prohibited            |
| 1    | 1    | Both rising and falling edges |

Cautions 1. Be sure to set bits 0, 1, 6, and 7 to 0.

2. Before setting the INTM0 register, be sure to set the corresponding interrupt mask flag ( $\times\times MK \times = 1$ ) to disable interrupts. After setting the INTM0 register, clear the interrupt request flag ( $\times\times IF \times = 0$ ), then clear the interrupt mask flag ( $\times\times MK \times = 0$ ), which will enable interrupts.

## (4) Program status word (PSW)

The program status word is a register used to hold the instruction execution result and the current status for interrupt requests. The IE flag to set maskable interrupt enable/disable is mapped.

This register can be read/written in 8-bit units and can carry out operations using a bit manipulation and dedicated instructions (EI, DI). When a vectored interrupt request is acknowledged, PSW is automatically saved into a stack, and the IE flag is reset to 0. It is reset from the stack by the RETI and POP PSW instructions.

RESET input sets PSW to 02H.

1

Enable

#### Figure 15-5. Program Status Word Configuration

| Symbol | 7  | 6     | 5  | 4  | 3 | 2  | 1        | 0      | After reset                                                  |
|--------|----|-------|----|----|---|----|----------|--------|--------------------------------------------------------------|
| PSW    | IE | Z     | 0  | AC | 0 | 0  | 1        | CY     | 02H                                                          |
|        |    |       |    |    |   |    |          |        | <ul> <li>Used when normal instruction is executed</li> </ul> |
|        | IE |       |    |    |   | In | nterrupt | acknov | vledge enable/disable                                        |
|        | 0  | Disab | le |    |   |    |          |        |                                                              |

## 15.4 Interrupt Servicing Operation

#### 15.4.1 Non-maskable interrupt request acknowledgement operation

A non-maskable interrupt request is unconditionally acknowledged even when interrupts are disabled. It is not subject to interrupt priority control and takes precedence over all other interrupts.

When a non-maskable interrupt request is acknowledged, the PSW and PC are saved to the stack in that order, the IE flag is reset to 0, the contents of the vector table are loaded to the PC, and then program execution branches.

Figure 15-6 shows the flowchart from non-maskable interrupt request generation to acknowledgement. Figure 15-7 shows the timing of non-maskable interrupt request acknowledgement. Figure 15-8 shows the acknowledgement operation if multiple non-maskable interrupts are generated.

Caution The  $\mu$ PD789862 Subseries has two non-maskable interrupt sources. Therefore, during execution of a non-maskable interrupt servicing program, a new non-maskable interrupt request is not acknowledged until the RETI instruction is executed. Be sure to execute the RETI instruction after the interrupt servicing program has been executed.

When using the watchdog timer as a non-maskable interrupt, push the address of the restore destination before executing the RETI instruction. If the RETI instruction is executed without pushing the restore destination, the program will jump to an illegal address. A program example is shown below.

<Example> Program example in which watchdog timer is used as non-maskable interrupt and program branches to reset vector when interrupt occurs

| XVECT   |         | CSEG         | AT    | 0000H |           |
|---------|---------|--------------|-------|-------|-----------|
| DW      | IRESET  |              | ;(00) |       | RESET     |
| DW      | IKR     |              | ;(02) |       | KeyReturn |
| DW      | IWDT    |              | ;(04) |       | INTWDT    |
| :       |         |              |       |       |           |
| XRST    |         | CSEG         | AT    | 0080H |           |
| IRESET: | DI      |              |       |       |           |
|         | MOVW    | AX, #0FE     | FFH   |       |           |
|         | MOVW    | SP, AX       |       |       |           |
| :       |         |              |       |       |           |
| :       |         |              |       |       |           |
| IWDT:   |         |              |       |       |           |
|         | (Interr | upt servicir | ng)   |       |           |
| :       |         |              |       |       |           |
|         | MOVW    | AX, #0080    | ЭН    |       |           |
|         | PUSH    | AX           |       |       |           |
|         | RETI    |              |       |       |           |





WDTM: Watchdog timer mode register WDT: Watchdog timer









## 15.4.2 Maskable interrupt request acknowledgement operation

A maskable interrupt request can be acknowledged when the interrupt request flag is set to 1 and the corresponding interrupt mask flag is cleared to 0. A vectored interrupt request is acknowledged in the interrupt enabled status (when the IE flag is set to 1).

The time required to start the interrupt servicing after a maskable interrupt request has been generated is shown in Table 15-3.

See Figures 15-10 and 15-11 for the interrupt request acknowledgement timing.

Table 15-3. Time from Generation of Maskable Interrupt Request to Servicing

| Minimum Time | Maximum Time <sup>™ote</sup> |  |  |
|--------------|------------------------------|--|--|
| 9 clocks     | 19 clocks                    |  |  |

**Note** The wait time is maximum when an interrupt request is generated immediately before the BT and BF instructions.

Remark 1 clock:  $\frac{1}{f_{CPU}}$  (f\_CPU: CPU clock)

When two or more maskable interrupt requests are generated at the same time, they are acknowledged starting from the interrupt request assigned the highest priority.

A pending interrupt is acknowledged when a status in which it can be acknowledged is set.

Figure 15-9 shows the algorithm of interrupt request acknowledgement.

When a maskable interrupt request is acknowledged, the contents of the PSW and PC are saved to the stack in that order, the IE flag is reset to 0, and the data in the vector table determined for each interrupt request is loaded to the PC, and execution branches.

To return from interrupt servicing, use the RETI instruction.



Figure 15-9. Interrupt Request Acknowledgement Processing Algorithm

- ××IF: Interrupt request flag
- ××MK: Interrupt mask flag

IE: Flag to control maskable interrupt request acknowledgement (1 = enable, 0 = disable)





If an interrupt request flag ( $\times$ IF) is set before instruction clock n (n = 4 to 10) under execution becomes n – 1, the interrupt is acknowledged after the instruction under execution is complete. Figure 15-10 shows an example of the interrupt request acknowledgement timing for an 8-bit data transfer instruction MOV A, r. Since this instruction is executed for 4 clocks, if an interrupt occurs for 3 clocks after the execution starts, the interrupt acknowledgement processing is performed after the MOV A, r instruction is executed.





If an interrupt request flag (××IF) is set at the last clock of the instruction, the interrupt acknowledgement processing starts after the next instruction is executed.

Figure 15-11 shows an example of the interrupt acknowledgement timing for an interrupt request flag that is set at the second clock of NOP (2-clock instruction). In this case, the MOV A, r instruction after the NOP instruction is executed, and then the interrupt acknowledgement processing is performed.

# Caution Interrupt requests will be held pending while interrupt request flag registers (IF0, IF1) or interrupt mask flag registers (MK0, MK1) are being accessed.

#### 15.4.3 Multiple interrupt servicing

Multiple interrupt servicing in which another interrupt is acknowledged while an interrupt is being serviced can be performed using a priority order system. When two or more interrupts are generated at once, interrupt servicing is performed according to the priority assigned to each interrupt request in advance (see **Table 15-1**).



## Example 1. Multiple interrupts are acknowledged



During interrupt INTxx servicing, interrupt request INTyy is acknowledged, and multiple interrupts are generated. The EI instruction is issued before each interrupt request acknowledgement, and the interrupt request acknowledgement enable state is set.



#### Example 2. Multiple interrupts are not generated because interrupts are not enabled

Because interrupts are not enabled in interrupt INTxx servicing (the EI instruction is not issued), interrupt request INTyy is not acknowledged, and multiple interrupts are not generated. The INTyy request is held pending and acknowledged after the INTxx servicing is performed.

IE = 0: Interrupt request acknowledgement disabled

## 15.4.4 Interrupt request pending

Some instructions may hold pending the acknowledgement of an interrupt request until the completion of the execution of the next instruction even if the interrupt request (maskable interrupt, non-maskable interrupt, and external interrupt) is generated during the execution. The following shows such instructions (interrupt request pending instruction).

- Manipulation instruction for interrupt request flag registers (IF0, IF1)
- Manipulation instruction for interrupt mask flag registers (MK0, MK1)

# **CHAPTER 16 STANDBY FUNCTION**

## 16.1 Standby Function and Configuration

#### 16.1.1 Standby function

The standby function is used to reduce the power consumption of the system and can be effected in the following two modes.

## (1) HALT mode

This mode is set when the HALT instruction is executed. HALT mode stops the operation clock of the CPU. The system clock oscillator continues oscillating. This mode does not reduce the current consumption as much as STOP mode, but is useful for resuming processing immediately when an interrupt request is generated, or for intermittent operations.

## (2) STOP mode

This mode is set when the STOP instruction is executed. STOP mode stops the main system clock oscillator and stops the entire system. The current consumption of the CPU can be substantially reduced in this mode.

The data memory can be retained at a low voltage ( $V_{DD} = 1.8 V \text{ max.}$ ). Therefore, this mode is useful for retaining the contents of the data memory at an extremely low current consumption.

STOP mode can be released by an interrupt request, so that this mode can be used for intermittent operations. However, some time is required until the system clock oscillator stabilizes after STOP mode has been released. If processing must be resumed immediately by using an interrupt request, therefore, use the HALT mode.

In both modes, the previous contents of the registers, flags, and data memory before setting standby mode are all retained. In addition, the statuses of the output latches of the I/O ports and output buffers are also retained.

# Caution To set STOP mode, be sure to stop the operations of the peripheral hardware, and then execute the STOP instruction.

## 16.1.2 Standby function control register

The wait time after STOP mode is released upon interrupt request until the oscillation stabilizes is controlled with the oscillation stabilization time selection register (OSTS).

OSTS is set by an 8-bit memory manipulation instruction.

RESET input sets OSTS to 04H. However, the oscillation stabilization time after RESET release is  $2^{12}/f_x$ , independent of OSTS.



| Symbol | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|-------|-------|-------|---------|-------------|-----|
| OSTS   | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 | FFFAH   | 04H         | R/W |

| OSTS2     | OSTS1   | OSTS0 | Oscillation stabilization time selection  |
|-----------|---------|-------|-------------------------------------------|
| 0         | 0       | 0     | 2 <sup>12</sup> /f <sub>x</sub> (819 μs)  |
| 0         | 1       | 0     | 2 <sup>15</sup> /f <sub>x</sub> (6.55 ms) |
| 1         | 0       | 0     | 2 <sup>17</sup> /f <sub>x</sub> (26.2 ms) |
| Other tha | n above |       | Setting prohibited                        |

Caution The wait time after STOP mode is released does not include the time from STOP mode release to clock oscillation start ("a" in the figure below), regardless of release by **RESET** input or by interrupt generation.



- **Remarks 1.** fx: System clock oscillation frequency (ceramic/crystal oscillation)
  - **2.** Figures in parentheses are for operation with fx = 5.0 MHz.

# 16.2 Standby Function Operation

# 16.2.1 HALT mode

\*

## (1) HALT mode

HALT mode is set by executing the HALT instruction. The operation statuses in HALT mode are shown in the following table.

| Table 16-1. | Operation | Statuses | in HALT | Mode |
|-------------|-----------|----------|---------|------|
|-------------|-----------|----------|---------|------|

| Item                  |           | HALT Mode Operation Status                                  |  |  |  |  |
|-----------------------|-----------|-------------------------------------------------------------|--|--|--|--|
| System clock          |           | System clock oscillation enabled                            |  |  |  |  |
|                       |           | Clock supply to CPU stopped                                 |  |  |  |  |
| CPU                   |           | Operation stopped                                           |  |  |  |  |
| EEPROM                |           | Operation enabled <sup>Note 1</sup>                         |  |  |  |  |
| Port (output latch    | )         | Remains in the state existing before HALT mode has been set |  |  |  |  |
| 16-bit timer/event    | counter 0 | Operation enabled                                           |  |  |  |  |
| 16-bit timer D        |           | Operation enabled                                           |  |  |  |  |
| 8-bit timer/event     | counter 5 | Operation enabled                                           |  |  |  |  |
| 8-bit timer 80        |           | Operation enabled                                           |  |  |  |  |
| Watchdog timer        |           | Operation enabled                                           |  |  |  |  |
| Serial interface 2    |           | Operation enabled                                           |  |  |  |  |
| Power-on-clear        | POC       | Operation enabled <sup>Note 2</sup>                         |  |  |  |  |
| circuit LVI           |           | Operation enabled                                           |  |  |  |  |
| Bit sequential buffer |           | Operation enabled                                           |  |  |  |  |
| Key return circuit    |           | Operation enabled                                           |  |  |  |  |
| External interrupt    |           | Operation enabled <sup>Note 3</sup>                         |  |  |  |  |

- **Notes 1.** HALT mode can be set after executing a write instruction. During writing, wait is possible in the HALT mode. To release standby by an interrupt request signal (INTEE0) on detection of write completion, set EEMK0 to 0.
  - If a POC switching circuit is selected by a mask option and the POC circuit is set to operation enabled by software or if POC circuit normally operating is selected by a mask option (refer to CHAPTER 19 MASK OPTIONS regarding mask options).
  - 3. A maskable interrupt that is not masked

# (2) Releasing HALT mode

HALT mode can be released by the following three sources.

#### (a) Releasing by unmasked interrupt request

HALT mode is released by an unmasked interrupt request. In this case, if interrupt request acknowledgement is enabled, vectored interrupt servicing is performed. If interrupt acknowledgement is disabled, the instruction at the next address is executed.





- **Remarks 1.** The broken lines indicate the case where the interrupt request that has released standby mode is acknowledged.
  - 2. The wait time is as follows:
    - When vectored interrupt servicing is performed: 9 to 10 clocks
    - When vectored interrupt servicing is not performed: 1 to 2 clocks

## (b) Releasing by non-maskable interrupt request

HALT mode is released regardless of whether interrupts are enabled or disabled, and vectored interrupt servicing is performed.

# (c) Releasing by RESET input

When HALT mode is released by the RESET signal, execution branches to the reset vector address in the same manner as the ordinary reset operation, and program execution starts.



Figure 16-3. Releasing HALT Mode by RESET Input



| Table 16-2. | Operation | After Relea | sing HALT Mode |
|-------------|-----------|-------------|----------------|
|-------------|-----------|-------------|----------------|

| Releasing Source               | MK×× | IE | Operation                          |
|--------------------------------|------|----|------------------------------------|
| Maskable interrupt request     | 0    | 0  | Executes next address instruction. |
|                                | 0    | 1  | Executes interrupt servicing.      |
|                                | 1    | ×  | Retains HALT mode.                 |
| Non-maskable interrupt request | _    | ×  | Executes interrupt servicing.      |
| RESET input                    | -    | -  | Reset processing                   |

×: Don't care

## 16.2.2 STOP mode

## (1) Setting and operation status of STOP mode

STOP mode is set by executing the STOP instruction.

Caution Because standby mode can be released by an interrupt request signal, standby mode is released as soon as it is set if there is an interrupt source whose interrupt request flag is set and interrupt mask flag is reset. Thus, the STOP mode is reset to the HALT mode immediately after execution of the STOP instruction and the operation mode is set after the wait for the oscillation stabilization time elapses.

The operation statuses in STOP mode are shown in the following table.

| ltem                         |     | STOP Mode Operation Status                                      |  |  |
|------------------------------|-----|-----------------------------------------------------------------|--|--|
| System clock                 |     | System clock oscillation stopped<br>Clock supply to CPU stopped |  |  |
| CPU                          |     | Operation stopped                                               |  |  |
| EEPROM                       |     | Operation stopped                                               |  |  |
| Port (output latch)          |     | Remains in the state existing before STOP mode has been set     |  |  |
| 16-bit timer/event counter 0 |     | Operation stopped                                               |  |  |
| 16-bit timer D               |     | Operation stopped                                               |  |  |
| 8-bit timer/event counter 5  |     | Operation enabled <sup>Note 1</sup>                             |  |  |
| 8-bit timer 80               |     | Operation stopped                                               |  |  |
| Watchdog timer               |     | Operation stopped                                               |  |  |
| Serial interface 2           |     | Operation enabled <sup>Note 2</sup>                             |  |  |
| Power-on-clear<br>circuit    | POC | Operation enabled <sup>Note 3</sup>                             |  |  |
|                              | LVI | Operation stopped                                               |  |  |
| Bit sequential buffer        |     | Operation stopped                                               |  |  |
| Key return circuit           |     | Operation enabled                                               |  |  |
| External interrupt           |     | Operation enabled <sup>Note 4</sup>                             |  |  |

| Table 16-3.         Operation Statuses in STOP Mode | Table 16-3. | Operation | Statuses in | n STOP Mode |
|-----------------------------------------------------|-------------|-----------|-------------|-------------|
|-----------------------------------------------------|-------------|-----------|-------------|-------------|

Notes 1. Operation enabled only when external clock is selected for count clock

- 2. Operation enabled in both 3-wire serial I/O mode and UART mode when an external clock is selected.
- If a POC switching circuit is selected by the mask option and the POC circuit is set to operation enabled by software or if POC circuit normally operating is selected by the mask option (refer to CHAPTER 19 MASK OPTIONS regarding mask options).
- 4. A maskable interrupt that is not masked

### (2) Releasing STOP mode

\*

STOP mode can be released by the following two sources.

#### (a) Releasing by unmasked interrupt request

STOP mode is released by an unmasked interrupt request. In this case, vectored interrupt servicing is performed if interrupt acknowledgement is enabled after the oscillation stabilization time has elapsed. If interrupt acknowledgement is disabled, the instruction at the next address is executed.





**Remark** The broken lines indicate the case where the interrupt request that has released standby mode is acknowledged.

#### (b) Releasing by non-maskable interrupt request

STOP mode is released regardless of whether interrupts are enabled or disabled, and vectored interrupt servicing is performed.

## (c) Releasing by RESET input

When STOP mode is released by the RESET signal, the reset operation is performed after the oscillation stabilization time has elapsed.



Figure 16-5. Releasing STOP Mode by RESET Input



| Table 16-4. | Operation After Releasing STOP Mode |
|-------------|-------------------------------------|
|-------------|-------------------------------------|

|   | Releasing Source               | MK×× | IE | Operation                          |
|---|--------------------------------|------|----|------------------------------------|
|   | Maskable interrupt request     | 0    | 0  | Executes next address instruction. |
|   |                                | 0    | 1  | Executes interrupt servicing.      |
|   |                                | 1    | ×  | Retains STOP mode.                 |
| * | Non-maskable interrupt request | -    | ×  | Executes interrupt servicing.      |
|   | RESET input                    | _    | _  | Reset processing                   |

×: Don't care

### **CHAPTER 17 RESET FUNCTION**

The following four operations are available to generate reset signals.

- (1) External reset input by RESET signal input
- (2) Internal reset by watchdog timer inadvertent program loop time detection
- (3) Internal reset by comparison of POC circuit power supply voltage and detection voltage
- (4) Internal reset by key input

External reset and internal reset have no functional differences. In both cases, program execution starts at the address at 0000H and 0001H by reset signal input.

When a low level is input to the RESET pin, the watchdog timer overflows, the POC circuit voltage is detected, or the KRREN pin is low level and a valid edge of any key input is detected in STOP mode, a reset is applied and each hardware item is set to the status shown in Table 17-1. Each pin is high impedance during reset input or during the oscillation stabilization time just after reset release.

When a high level is input to the RESET pin, the reset is released and program execution is started after the oscillation stabilization time has elapsed. The reset applied by the watchdog timer overflow is automatically released after reset, and program execution is started after the oscillation stabilization time has elapsed (see **Figures 17-2** through **17-4**).

### Cautions 1. For an external reset, input a low level of 10 $\mu$ s or more to the RESET pin.

2. When STOP mode is released by reset, the STOP mode contents are held during reset input. However, the port pins become high impedance.



Stop

#### Figure 17-1. Block Diagram of Reset Function



Figure 17-2. Reset Timing by RESET Input

|                                        | Hardware                                                      | Status After Reset          |
|----------------------------------------|---------------------------------------------------------------|-----------------------------|
| Program counter (PC) <sup>Note 1</sup> | The contents of the reset vector table (0000H, 0001H) are set |                             |
| Stack pointer (SP)                     |                                                               | Undefined                   |
| Program status word (PSW)              |                                                               | 02H                         |
| EEPROM                                 | Write control register (EEWC10)                               | 08H <sup>Note 2</sup>       |
| RAM                                    | Data memory                                                   | Undefined <sup>Note 3</sup> |
|                                        | General-purpose registers                                     | Undefined <sup>Note 3</sup> |
| Ports (P0 to P3, P7) (output late      | h)                                                            | 00H                         |
| Port mode registers (PM0 to PM         | 3)                                                            | FFH                         |
| Pull-up resistor option registers      | (PUB0 to PUB3)                                                | 00H                         |
| Processor clock control register       | (PCC)                                                         | 02H                         |
| Oscillation stabilization time sele    | ection register (OSTS)                                        | 04H                         |
| 16-bit timer/event counter 0           | Timer counter (TM0)                                           | 0000H                       |
|                                        | Capture/compare registers (CR00, CR01)                        | 0000H                       |
|                                        | Prescaler mode register (PRM0)                                | 00H                         |
|                                        | Mode control register (TMC0)                                  | 00H                         |
|                                        | Output control register (TOC0)                                | 00H                         |
| 16-bit timer D                         | Timer counter (TMD)                                           | 0000H                       |
|                                        | Compare register (CMD)                                        | 0000H                       |
|                                        | Mode control register (TMCD)                                  | 00H                         |
| 8-bit timer/event counter 5            | Timer counter (TM5)                                           | 00H                         |
|                                        | Compare register (CR5)                                        | 00H                         |
|                                        | Timer clock selection register (TCL5)                         | 00H                         |
|                                        | Mode control register (TMC5)                                  | 00H                         |
| 8-bit timer 80                         | Timer counter (TM80)                                          | 00H                         |
|                                        | Compare register (CR80)                                       | Undefined                   |
|                                        | Mode control register (TMC80)                                 | 00H                         |
| Watchdog timer                         | Timer clock selection register (WDCS)                         | 00H                         |
|                                        | Mode register (WDTM)                                          | 00H                         |
| Serial interface 2                     | Mode register (CSIM2)                                         | 00H                         |
|                                        | Asynchronous serial interface mode register (ASIM2)           | 00H                         |
|                                        | Asynchronous serial interface status register (ASIS2)         | 00H                         |
|                                        | Baud rate generator control register (BRGC2)                  | 00H                         |
|                                        | Transmit shift register (TXS2)                                | FFH                         |
|                                        | Receive buffer register (RXB2)                                | Undefined                   |

| Table 17-1. Status of Hardware After Reset (1/ | 2) |
|------------------------------------------------|----|
|------------------------------------------------|----|

**Notes 1.** While a reset signal is being input, and during the oscillation stabilization time wait, the contents of the PC will be undefined, while the remainder of the hardware will be the same as after the reset.

2. The initial value of bit 7 (EEWEM10) varies depending on the status of the EEWE pin.

3. In standby mode, the RAM enters the hold state after a reset.

|                                             | Status After Reset                                    |                       |
|---------------------------------------------|-------------------------------------------------------|-----------------------|
| Power-on-clear circuit                      | Power-on-clear register (POCF)                        | 00H <sup>Note 1</sup> |
|                                             | Low-voltage detection register (LVIF)                 | 00H                   |
|                                             | Low-voltage detection level selection register (LVIS) | 00H                   |
| Bit sequential buffer                       | Data registers (BSFRL10, BSFRH10)                     | Undefined             |
|                                             | Output control register (BSF1C) 00H                   |                       |
| Key return circuit                          | Key return edge detection register (EDG) Note 2       |                       |
| Interrupt Request flag registers (IF0, IF1) |                                                       | 00H                   |
| Mask flag registers (MK0, MK1)              |                                                       | FFH                   |
|                                             | External interrupt mode register (INTM0)              | 00H                   |

 Table 17-1.
 Status of Hardware After Reset (2/2)

**Notes 1.** This value is 04H only after a power-on-clear reset.

2. The value after the key return reset is 1000000×B (bit 0 retains the value before the key return reset is input), and in other cases, the value is 00H.

## CHAPTER 18 μPD78E9862

The  $\mu$ PD78E9862 is the EEPROM version in the  $\mu$ PD789862 Subseries.

\*

The  $\mu$ PD78E9862 replaces the internal ROM of the  $\mu$ PD789862 with EEPROM. The differences between the  $\mu$ PD78E9862 and the mask ROM version are shown in Table 18-1.

|                     |                                      | Part Number       | EEPROM Version                                  | Mask ROM Version |  |
|---------------------|--------------------------------------|-------------------|-------------------------------------------------|------------------|--|
| Item                | Item                                 |                   | μPD78E9862 <sup>Note 1</sup>                    | μPD789862        |  |
| Internal<br>memory  | Program<br>memory                    | ROM<br>structure  | EEPROM Mask ROM                                 |                  |  |
|                     |                                      | ROM<br>capacity   | 16 KB                                           |                  |  |
|                     | Data<br>memory                       | High-speed<br>RAM | 512 bytes                                       |                  |  |
|                     |                                      | EEPROM            | 256 bytes                                       |                  |  |
| System cl           | ock                                  |                   | Ceramic/crystal oscillation                     |                  |  |
| IC pin              |                                      |                   | Not provided                                    | Provided         |  |
| V <sub>PP</sub> pin | VPP pin                              |                   | Provided Not provided                           |                  |  |
| POC circu           | POC circuit selection by mask option |                   | Not provided <sup>Note 2</sup> Provided         |                  |  |
| Electrical          | specifications                       |                   | Varies depending on EEPROM or mask ROM version. |                  |  |

Table 18-1. Differences Between  $\mu$ PD78E9862 and Mask ROM Version

- **Notes 1.** The  $\mu$ PD78E9862 is provided exclusively for program development; the product life and reliability are not guaranteed. Use the  $\mu$ PD789862 for reliability testing and mass production.
  - 2. The POC circuit can be switched (operation of the POC circuit can be controlled by software).
- Caution There are differences in noise immunity and noise radiation between the EEPROM and mask ROM versions. When pre-producing an application set with the EEPROM 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 version.

### 18.1 Features of EEPROM (Program Memory)

The on-chip program memory in the  $\mu$ PD78E9862 is EEPROM.

This chapter describes the functions of the EEPROM incorporated in the program memory area. For the EEPROM incorporated in data memory, refer to **CHAPTER 4 EEPROM (DATA MEMORY)**.

EEPROM can be written with the  $\mu$ PD78E9862 mounted on the target system (on-board write). Connect the dedicated flash programmer (Flashpro III (part no. FL-PR3, PG-FP3), Flashpro IV (part no. FL-PR4, PG-FP4)) to the host machine and target system to write to EEPROM.

Remark FL-PR3 and FL-PR4 are products of Naito Densei Machida Mfg. Co., Ltd (TEL +81-45-475-4191).

Programming using EEPROM has the following advantages.

- Software can be modified after the microcontroller is solder-mounted on the target system.
- · Distinguishing software facilities small-quantity, varied model production
- · Easy data adjustment when starting mass production

#### 18.1.1 Programming environment

The following shows the environment required for  $\mu$ PD78E9862 EEPROM programming.

When Flashpro III (part no. FL-PR3, PG-FP3) or Flashpro IV (part no. FL-PR4, PG-FP4) is used as a dedicated flash programmer, a host machine is required to control the dedicated flash programmer. Communication between the host machine and flash programmer is performed via RS-232C/USB (Rev. 1.1).

For details, refer to the manuals for Flashpro III/Flashpro IV.

**Remark** USB is supported by Flashpro IV only.





### 18.1.2 Communication mode

Use the communication mode shown in Table 18-2 to perform communication between the dedicated flash programmer and  $\mu$ PD78E9862.

| × |
|---|
|   |
|   |

| Table 18-2.         Communication Mode List |
|---------------------------------------------|
| TVPE Setting <sup>Note 1</sup>              |

| Communication        |                                |                       | TYPE Setting <sup>™</sup>            | Pins Used         | Number of |                                                                                 |            |
|----------------------|--------------------------------|-----------------------|--------------------------------------|-------------------|-----------|---------------------------------------------------------------------------------|------------|
| Mode                 | COMM                           | SIO Clock             | CPU CLOCK                            |                   | Multiple  |                                                                                 | VPP Pulses |
|                      | PORT                           |                       | In Flashpro                          | On Target Board   | Rate      |                                                                                 |            |
| 3-wire serial<br>I/O | SIO ch-0<br>(3-wire,<br>sync.) | 100 Hz to<br>1.25 MHz | 4 MHz and<br>5 MHz <sup>Note 2</sup> | 3 to 5 MHz        | 1.0       | SI2/RxD2/P32<br>SO2/TxD2/P31<br>SCK2/ASCK2/P30                                  | 0          |
| UART                 | UART ch-0<br>(Async.)          | 4800 to<br>76800 bps  | 5 MHz <sup>Note 3</sup>              | 4.91 and<br>5 MHz | 1.0       | RxD2/SI2/P32<br>TxD2/SO2/P31                                                    | 8          |
| Pseudo 3-wire        | Port A<br>(Pseudo-3<br>wire)   | 100 Hz to<br>1 kHz    | 4 MHz and<br>5 MHz <sup>№te 2</sup>  | 3 to 5 MHz        | 1.0       | P02 (serial data input)<br>P01 (serial data output)<br>P00 (serial clock input) | 12         |

- Notes 1. Selection items for TYPE settings on the dedicated flash programmer (Flashpro III (part no. FL-PR3, PG-FP3)/Flashpro IV (part no. FL-PR4, PG-FP4)).
  - 2. Only 4 MHz for Flashpro III.
  - 3. Selectable only for Flashpro IV.

### Figure 18-2. Communication Mode Selection Format



#### Figure 18-3. Example of Connection with Dedicated Flash Programmer



#### (a) 3-wire serial I/O





#### (c) Pseudo 3-wire



- **Notes 1.** Connect this pin when the system clock is supplied from the dedicated flash programmer. If a resonator is already connected to the X1 pin, the CLK pin does not need to be connected.
  - 2. When using UART with Flashpro III, the clock of the resonator connected to the X1 pin must be used, so connection to the CLK pin is not necessary.
- Caution The V<sub>DD</sub> pin, if already connected to the power supply, must be connected to the VDD pin of the dedicated flash programmer. When using the power supply connected to the VDD pin, supply voltage before starting programming.

If Flashpro III (part no. FL-PR3, PG-FP3)/Flashpro IV (part no. FL-PR4, PG-FP4) is used as a dedicated flash programmer, the following signals are generated for the  $\mu$ PD78E9862. For details, refer to the manual of Flashpro III/Flashpro IV.

| Signal Name | I/O    | Pin Function                                    | Pin Name       | 3-Wire Serial I/O  | UART              | Pseudo 3-Wire     |
|-------------|--------|-------------------------------------------------|----------------|--------------------|-------------------|-------------------|
| VPP1        | Output | Write voltage                                   | Vpp            | 0                  | O                 | Ø                 |
| VPP2        | -      | _                                               | _              | ×                  | ×                 | ×                 |
| VDD         | I/O    | VDD voltage<br>generation/voltage<br>monitoring | Vdd            | (© <sup>Note</sup> | O <sup>Note</sup> | ⊚ <sup>Note</sup> |
| GND         | -      | Ground                                          | Vss            | 0                  | 0                 | Ø                 |
| CLK         | Output | Clock output                                    | X1             | 0                  | 0                 | 0                 |
| RESET       | Output | Reset signal                                    | RESET          | 0                  | O                 | 0                 |
| SI          | Input  | Receive signal                                  | SO2/TxD2 (P01) | 0                  | O                 | 0                 |
| SO          | Output | Transmit signal                                 | SI2/RxD2 (P02) | 0                  | O                 | 0                 |
| SCK         | Output | Transfer clock                                  | SCK2 (P00)     | O                  | ×                 | O                 |
| HS          | Input  | Handshake signal                                | -              | ×                  | ×                 | ×                 |

| Table 18-3   | Pin   | <b>Connection List</b> |
|--------------|-------|------------------------|
| 1 abie 10-5. | E 111 | CONNECTION FIST        |

**Note** VDD voltage must be supplied before programming is started.

**Remark** ©: Pin must be connected.

- $\bigcirc$ : If the signal is supplied on the target board, pin does not need to be connected.
- $\times$ : Pin does not need to be connected.

Pin names in parentheses are for pseudo 3-wire.

### 18.1.3 On-board pin processing

When performing programming on the target system, provide a connector on the target system to connect the dedicated flash programmer.

An on-board function that allows switching between normal operation mode and EEPROM programming mode may be required in some cases.

#### <VPP pin>

In normal operation mode, input 0 V to the VPP pin. In EEPROM programming mode, a write voltage of 10.0 V (TYP.) is supplied to the VPP pin, so perform either of the following.

- (1) Connect a pull-down resistor  $RV_{PP} = 10 k\Omega$  to the VPP pin.
- (2) Use the jumper on the board to switch the VPP pin input to either the programmer or directly to GND.

A VPP pin connection example is shown below.



### Figure 18-4. VPP Pin Connection Example

#### <Serial interface pins>

The following shows the pins used by the serial interface.

| Serial Interface  | Pins Used      |
|-------------------|----------------|
| 3-wire serial I/O | SI2, SO2, SCK2 |
| UART              | RxD2, TxD2     |
| Pseudo 3-wire     | P02, P01, P00  |

When connecting the dedicated flash programmer to a serial interface pin that is connected to another device onboard, signal conflict or abnormal operation of the other device may occur. Care must therefore be taken with such connections.

#### (1) Signal conflict

If the dedicated flash programmer (output) is connected to a serial interface pin (input) that is connected to another device (output), a signal conflict occurs. To prevent this, isolate the connection with the other device or set the other device to the output high impedance status.



#### Figure 18-5. Signal Conflict (Input Pin of Serial Interface)

In the EEPROM programming mode, the signal output by another device and the signal sent by the dedicated flash programmer conflict; therefore, isolate the signal of the other device.

#### (2) Abnormal operation of other device

If the dedicated flash programmer (output or input) is connected to a serial interface pin (input or output) that is connected to another device (input), a signal is output to the device, and this may cause an abnormal operation. To prevent this abnormal operation, isolate the connection with the other device or set so that the signals input to the other device are ignored.





If the signal output by the  $\mu$ PD78E9862 affects another device in the EEPROM programming mode, isolate the signals of the other device.



If the signal output by the dedicated flash programmer affects another device in the EEPROM programming mode, isolate the signals of the other device.

### <RESET pin>

If the reset signal of the dedicated flash programmer is connected to the RESET pin connected to the reset signal generator on-board, a signal conflict occurs. To prevent this, isolate the connection with the reset signal generator.

If the reset signal is input from the user system in the EEPROM programming mode, a normal programming operation cannot be performed. Therefore, do not input other than reset signals from the dedicated flash programmer.



Figure 18-7. Signal Conflict (RESET Pin)

The signal output by the reset signal generator and the signal output from the dedicated flash programmer conflict in the EEPROM programming mode, so isolate the signal of the reset signal generator.

#### <Port pins>

When the  $\mu$ PD78E9862 enters the EEPROM programming mode, all the pins other than those that communicate with the flash programmer are in the same status as immediately after reset.

If the external device does not recognize initial statuses such as the output high impedance status, therefore, connect the external device to V<sub>DD</sub> or V<sub>SS</sub> via a resistor.

#### <Oscillation pins>

When using the on-board clock, connect X1 and X2 as required in the normal operation mode.

When using the clock output of the flash programmer, connect it directly to X1, disconnecting the resonator onboard, and leave the X2 pin open.

#### <Power supply>

To use the power output from the flash programmer, connect the V<sub>DD</sub> pin to VDD of the flash programmer, and the V<sub>ss</sub> pin to GND of the flash programmer.

To use the on-board power supply, make connections that accord with the normal operation mode. However, because the voltage is monitored by the flash programmer, be sure to connect VDD of the flash programmer.

## 18.1.4 Connection on EEPROM writing adapter

The following shows examples of the recommended connection when using the EEPROM writing adapter.







Figure 18-9. Wiring Example for EEPROM Writing Adapter in UART Mode



Figure 18-10. Wiring Example for EEPROM Writing Adapter in Pseudo 3-Wire Mode

## **CHAPTER 19 MASK OPTIONS**

The  $\mu$ PD789862 has the following mask options.

- POC circuit mask options
  - The POC circuit can be selected.
  - <1> Select POC switching circuit (POC circuit operation control by software is possible)
  - <2> Select POC circuit normally operating
  - <3> Select POC circuit normally halted

### CHAPTER 20 INSTRUCTION SET OVERVIEW

This chapter lists the instruction set of the  $\mu$ PD789862 Subseries. For details of the operation and machine language (instruction code) of each instruction, refer to **78K/0S Series Instructions User's Manual (U11047E)**.

### 20.1 Operation

#### 20.1.1 Operand identifiers and description methods

Operands are described in "Operand" column of each instruction in accordance with the description method of the instruction operand identifier (refer to the assembler specifications for details). When there are two or more description methods, select one of them. Uppercase letters and the symbols #, !, \$, and [] are key words and are described 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 describe 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 description.

| Identifier | Description 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                                                                    |
| saddr      | FE20H to FF1FH Immediate data or labels                                                             |
| saddrp     | FE20H to FF1FH Immediate data or labels (even addresses only)                                       |
| addr16     | 0000H to FFFFH Immediate data or labels (only even addresses for 16-bit data transfer instructions) |
| addr5      | 0040H to 007FH Immediate data or labels (even addresses only)                                       |
| word       | 16-bit immediate data or label                                                                      |
| byte       | 8-bit immediate data or label                                                                       |
| bit        | 3-bit immediate data or label                                                                       |

Table 20-1. Operand Identifiers and Description Methods

Remark For symbols of special function registers, see Table 3-3 Special Function Registers.

## 20.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                                                                |
| IE:        | Interrupt request enable flag                                            |
| NMIS:      | Flag indicating non-maskable interrupt servicing in progress             |
| ():        | Memory contents indicated by address or register contents in parentheses |
| ×н, ×L:    | Higher 8 bits and lower 8 bits of 16-bit register                        |
| ∧:         | Logical product (AND)                                                    |
| ∨:         | Logical sum (OR)                                                         |
| ∀:         | Exclusive logical sum (exclusive OR)                                     |
| — <u>:</u> | Inverted data                                                            |
| addr16:    | 16-bit immediate data or label                                           |
| jdisp8:    | Signed 8-bit data (displacement value)                                   |

### 20.1.3 Description of "Flag" column

| (Blank): | Unchanged                           |
|----------|-------------------------------------|
| 0:       | Cleared to 0                        |
| 1:       | Set to 1                            |
| ×:       | Set/cleared according to the result |
| R:       | Previously saved value is stored    |

## 20.2 Operation List

| Mnemonic | Operand        | Bytes | Clocks | Operation                       |   | Flag | 3  |
|----------|----------------|-------|--------|---------------------------------|---|------|----|
|          |                |       |        |                                 | Z | AC   | CY |
| MOV      | r, #byte       | 3     | 6      | $r \leftarrow byte$             |   |      |    |
|          | saddr, #byte   | 3     | 6      | $(saddr) \leftarrow byte$       |   |      |    |
|          | sfr, #byte     | 3     | 6      | $sfr \leftarrow byte$           |   |      |    |
|          | A, r           | 2     | 4      | $A \leftarrow r$                |   |      |    |
|          | r, A Note 1    | 2     | 4      | $r \leftarrow A$                |   |      |    |
|          | A, saddr       | 2     | 4      | $A \leftarrow (saddr)$          |   |      |    |
|          | saddr, A       | 2     | 4      | $(saddr) \gets A$               |   |      |    |
|          | A, sfr         | 2     | 4      | $A \leftarrow sfr$              |   |      |    |
|          | sfr, A         | 2     | 4      | $sfr \leftarrow A$              |   |      |    |
|          | A, !addr16     | 3     | 8      | $A \leftarrow (addr16)$         |   |      |    |
|          | !addr16, A     | 3     | 8      | $(addr16) \leftarrow A$         |   |      |    |
|          | PSW, #byte     | 3     | 6      | $PSW \leftarrow byte$           | × | ×    | ×  |
|          | A, PSW         | 2     | 4      | $A \leftarrow PSW$              |   |      |    |
|          | PSW, A         | 2     | 4      | $PSW \leftarrow A$              | × | ×    | ×  |
|          | A, [DE]        | 1     | 6      | $A \leftarrow (DE)$             |   |      |    |
|          | [DE], A        | 1     | 6      | $(DE) \leftarrow A$             |   |      |    |
|          | A, [HL]        | 1     | 6      | $A \leftarrow (HL)$             |   |      |    |
|          | [HL], A        | 1     | 6      | $(HL) \gets A$                  |   |      |    |
|          | A, [HL + byte] | 2     | 6      | $A \leftarrow (HL + byte)$      |   |      |    |
|          | [HL + byte], A | 2     | 6      | $(HL + byte) \leftarrow A$      |   |      |    |
| XCH      | Α, Χ           | 1     | 4      | $A \leftrightarrow X$           |   |      |    |
|          | A, r Note 2    | 2     | 6      | $A \leftrightarrow r$           |   |      |    |
|          | A, saddr       | 2     | 6      | $A \leftrightarrow (saddr)$     |   |      |    |
|          | A, sfr         | 2     | 6      | $A \leftrightarrow sfr$         |   |      |    |
|          | A, [DE]        | 1     | 8      | $A \leftrightarrow (DE)$        |   |      |    |
|          | A, [HL]        | 1     | 8      | $A \leftrightarrow (HL)$        |   |      |    |
|          | A, [HL, byte]  | 2     | 8      | $A \leftrightarrow (HL + byte)$ |   |      |    |

Notes 1. Except r = A.

**2.** Except r = A, X.

| Mnemonic | Operand        |      | Bytes | Clocks | Operation                                    |   | Flag | 9  |
|----------|----------------|------|-------|--------|----------------------------------------------|---|------|----|
|          |                |      |       |        |                                              | Z | AC   | CY |
| MOVW     | rp, #word      |      | 3     | 6      | $rp \leftarrow word$                         |   |      |    |
|          | AX, saddrp     |      | 2     | 6      | $AX \leftarrow (saddrp)$                     |   |      |    |
|          | saddrp, AX     |      | 2     | 8      | $(saddrp) \leftarrow AX$                     |   |      |    |
|          | AX, rp         | Note | 1     | 4      | $AX \gets rp$                                |   |      |    |
|          | rp, AX         | Note | 1     | 4      | $rp \leftarrow AX$                           |   |      |    |
| XCHW     | AX, rp         | Note | 1     | 8      | $AX \leftrightarrow rp$                      |   |      |    |
| ADD      | A, #byte       |      | 2     | 4      | A, CY $\leftarrow$ A + byte                  | × | ×    | ×  |
|          | saddr, #byte   |      | 3     | 6      | (saddr), CY $\leftarrow$ (saddr) + byte      | × | ×    | ×  |
|          | A, r           |      | 2     | 4      | A, CY $\leftarrow$ A + r                     | × | ×    | ×  |
|          | A, saddr       |      | 2     | 4      | A, CY $\leftarrow$ A + (saddr)               | × | ×    | ×  |
|          | A, !addr16     |      | 3     | 8      | A, CY $\leftarrow$ A + (addr16)              | × | ×    | ×  |
|          | A, [HL]        |      | 1     | 6      | A, CY $\leftarrow$ A + (HL)                  | × | ×    | ×  |
|          | A, [HL + byte] |      | 2     | 6      | A, CY $\leftarrow$ A + (HL + byte)           | × | ×    | ×  |
| ADDC     | A, #byte       |      | 2     | 4      | A, CY $\leftarrow$ A + byte + CY             | × | ×    | ×  |
|          | saddr, #byte   |      | 3     | 6      | (saddr), CY $\leftarrow$ (saddr) + byte + CY | × | ×    | ×  |
|          | A, r           |      | 2     | 4      | $A, CY \gets A + r + CY$                     | × | ×    | ×  |
|          | A, saddr       |      | 2     | 4      | A, CY $\leftarrow$ A + (saddr) + CY          | × | ×    | ×  |
|          | A, !addr16     |      | 3     | 8      | A, CY $\leftarrow$ A + (addr16) + CY         | × | ×    | ×  |
|          | A, [HL]        |      | 1     | 6      | $A, CY \gets A + (HL) + CY$                  | × | ×    | ×  |
|          | A, [HL + byte] |      | 2     | 6      | A, CY $\leftarrow$ A + (HL + byte) + CY      | × | ×    | ×  |
| SUB      | A, #byte       |      | 2     | 4      | A, CY $\leftarrow$ A – byte                  | × | ×    | ×  |
|          | saddr, #byte   |      | 3     | 6      | (saddr), CY $\leftarrow$ (saddr) – byte      | × | ×    | ×  |
|          | A, r           |      | 2     | 4      | A, CY $\leftarrow$ A – r                     | × | ×    | ×  |
|          | A, saddr       |      | 2     | 4      | A, CY $\leftarrow$ A – (saddr)               | × | ×    | ×  |
|          | A, !addr16     |      | 3     | 8      | A, CY $\leftarrow$ A – (addr16)              | × | ×    | ×  |
|          | A, [HL]        |      | 1     | 6      | A, CY $\leftarrow$ A – (HL)                  | × | ×    | ×  |
|          | A, [HL + byte] |      | 2     | 6      | A, CY $\leftarrow$ A – (HL + byte)           | × | ×    | ×  |

**Note** Only when rp = BC, DE, or HL.

| Mnemonic | Operand        | Bytes | Clocks | Operation                                     |   | Flag | g  |
|----------|----------------|-------|--------|-----------------------------------------------|---|------|----|
|          |                |       |        |                                               | Z | AC   | CY |
| SUBC     | A, #byte       | 2     | 4      | A, CY $\leftarrow$ A – byte – CY              | × | Х    | ×  |
|          | saddr, #byte   | 3     | 6      | (saddr), CY $\leftarrow$ (saddr) – byte – CY  | × | ×    | ×  |
|          | A, r           | 2     | 4      | A, $CY \leftarrow A - r - CY$                 | × | ×    | ×  |
|          | A, saddr       | 2     | 4      | A, CY $\leftarrow$ A – (saddr) – CY           | × | ×    | ×  |
|          | A, !addr16     | 3     | 8      | A, CY $\leftarrow$ A – (addr16) – CY          | × | ×    | ×  |
|          | A, [HL]        | 1     | 6      | $A,CY \leftarrow A - (HL) - CY$               | × | ×    | ×  |
|          | A, [HL + byte] | 2     | 6      | A, CY $\leftarrow$ A – (HL + byte) – CY       | × | ×    | ×  |
| AND      | A, #byte       | 2     | 4      | $A \leftarrow A \land byte$                   | × |      |    |
|          | saddr, #byte   | 3     | 6      | $(saddr) \leftarrow (saddr) \land byte$       | × |      |    |
|          | A, r           | 2     | 4      | $A \leftarrow A \wedge r$                     | × |      |    |
|          | A, saddr       | 2     | 4      | $A \leftarrow A \land (saddr)$                | × |      |    |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \land (addr16)$               | × |      |    |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \land (HL)$                   | × |      |    |
|          | A, [HL + byte] | 2     | 6      | $A \leftarrow A \land (HL + byte)$            | × |      |    |
| OR       | A, #byte       | 2     | 4      | $A \leftarrow A \lor byte$                    | × |      |    |
|          | saddr, #byte   | 3     | 6      | $(saddr) \leftarrow (saddr) \lor byte$        | × |      |    |
|          | A, r           | 2     | 4      | $A \leftarrow A \lor r$                       | × |      |    |
|          | A, saddr       | 2     | 4      | $A \leftarrow A \lor (saddr)$                 | × |      |    |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \lor (addr16)$                | × |      |    |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \lor (HL)$                    | × |      |    |
|          | A, [HL + byte] | 2     | 6      | $A \leftarrow A \lor (HL + byte)$             | × |      |    |
| XOR      | A, #byte       | 2     | 4      | $A \leftarrow A \lor byte$                    | × |      |    |
|          | saddr, #byte   | 3     | 6      | $(saddr) \leftarrow (saddr) \lor byte$        |   |      |    |
|          | A, r           | 2     | 4      | $A \leftarrow A \lor r$                       |   |      |    |
|          | A, saddr       | 2     | 4      | $A \leftarrow A \lor (saddr)$                 |   |      |    |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \lor (addr16)$                | × |      |    |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \lor (HL)$                    | × |      |    |
|          | A, [HL + byte] | 2     | 6      | $A \leftarrow A \bigtriangledown (HL + byte)$ | × |      |    |

| Mnemonic | Operand        | Bytes | Clocks | Operation                                                                   |   | Fla | g  |
|----------|----------------|-------|--------|-----------------------------------------------------------------------------|---|-----|----|
|          |                |       |        |                                                                             | Z | AC  | CY |
| CMP      | A, #byte       | 2     | 4      | A – byte                                                                    | × | ×   | ×  |
|          | saddr, #byte   | 3     | 6      | (saddr) – byte                                                              | × | ×   | ×  |
|          | A, r           | 2     | 4      | A – r                                                                       | × | ×   | ×  |
|          | A, saddr       | 2     | 4      | A – (saddr)                                                                 | × | ×   | ×  |
|          | A, !addr16     | 3     | 8      | A – (addr16)                                                                | × | ×   | ×  |
|          | A, [HL]        | 1     | 6      | A – (HL)                                                                    | × | ×   | ×  |
|          | A, [HL + byte] | 2     | 6      | A – (HL + byte)                                                             | × | ×   | ×  |
| ADDW     | AX, #word      | 3     | 6      | AX, CY $\leftarrow$ AX + word                                               | × | ×   | ×  |
| SUBW     | AX, #word      | 3     | 6      | $AX,CY \gets AX - word$                                                     | × | ×   | ×  |
| CMPW     | AX, #word      | 3     | 6      | AX – word                                                                   | × | ×   | ×  |
| INC      | r              | 2     | 4      | r ← r + 1                                                                   | × | ×   |    |
|          | saddr          | 2     | 4      | $(saddr) \leftarrow (saddr) + 1$                                            | × | ×   |    |
| DEC      | r              | 2     | 4      | $r \leftarrow r - 1$                                                        | × | ×   |    |
|          | saddr          | 2     | 4      | $(saddr) \leftarrow (saddr) - 1$                                            | × | ×   |    |
| INCW     | rp             | 1     | 4      | $rp \leftarrow rp + 1$                                                      |   |     |    |
| DECW     | rp             | 1     | 4      | $rp \leftarrow rp - 1$                                                      |   |     |    |
| ROR      | A, 1           | 1     | 2      | $(CY,A_7 \leftarrow A_0,A_{m-1} \leftarrow A_m) \times 1$                   |   |     | ×  |
| ROL      | A, 1           | 1     | 2      | $(CY,A_0 \leftarrow A_7,A_{m+1} \leftarrow A_m) \times 1$                   |   |     | ×  |
| RORC     | A, 1           | 1     | 2      | $(CY \leftarrow A_0,  A_7 \leftarrow CY,  A_{m-1} \leftarrow A_m) \times 1$ |   |     | ×  |
| ROLC     | A, 1           | 1     | 2      | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$   |   |     | ×  |
| SET1     | saddr.bit      | 3     | 6      | $(saddr.bit) \leftarrow 1$                                                  |   |     |    |
|          | sfr.bit        | 3     | 6      | sfr.bit ← 1                                                                 |   |     |    |
|          | A.bit          | 2     | 4      | A.bit ← 1                                                                   |   |     |    |
|          | PSW.bit        | 3     | 6      | PSW.bit ← 1                                                                 | × | ×   | ×  |
|          | [HL].bit       | 2     | 10     | (HL).bit $\leftarrow$ 1                                                     |   |     |    |
| CLR1     | saddr.bit      | 3     | 6      | $(saddr.bit) \leftarrow 0$                                                  |   |     |    |
|          | sfr.bit        | 3     | 6      | $sfr.bit \leftarrow 0$                                                      |   | _   |    |
|          | A.bit          | 2     | 4      | A.bit ← 0                                                                   |   |     |    |
|          | PSW.bit        | 3     | 6      | PSW.bit ← 0                                                                 | × | ×   | ×  |
|          | [HL].bit       | 2     | 10     | (HL).bit $\leftarrow 0$                                                     |   |     |    |
| SET1     | СҮ             | 1     | 2      | CY ← 1                                                                      |   |     | 1  |
| CLR1     | СҮ             | 1     | 2      | $CY \leftarrow 0$                                                           |   |     | 0  |
| NOT1     | CY             | 1     | 2      | $CY \leftarrow \overline{CY}$                                               |   |     | ×  |

| Mnemonic | Operand                                                   | Bytes | Clocks | Operation                                                                                                                                           |   | Flag | ļ  |
|----------|-----------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
|          |                                                           |       |        |                                                                                                                                                     | Z | AC   | C١ |
| CALL     | !addr16                                                   | 3     | 6      | $(SP - 1) \leftarrow (PC + 3)_{H}, (SP - 2) \leftarrow (PC + 3)_{L},$<br>$PC \leftarrow addr16, SP \leftarrow SP - 2$                               |   |      |    |
| CALLT    | $ \begin{tabular}{ l l l l l l l l l l l l l l l l l l l$ |       |        |                                                                                                                                                     |   |      |    |
| RET      |                                                           | 1     | 6      | $PC_{H} \leftarrow (SP+1),  PC_{L} \leftarrow (SP),  SP \leftarrow SP+2$                                                                            |   |      |    |
| RETI     |                                                           | 1     | 8      | $\begin{array}{l} PC_{H} \leftarrow (SP+1),  PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2),  SP \leftarrow SP+3,  NMIS \leftarrow 0 \end{array}$ | R | R    | R  |
| PUSH     | PSW                                                       | 1     | 2      | $(SP - 1) \leftarrow PSW, SP \leftarrow SP - 1$                                                                                                     |   |      |    |
|          | rp                                                        | 1     | 4      | $(SP-1) \gets rp_{H},(SP-2) \gets rp_{L},SP \gets SP-2$                                                                                             |   |      |    |
| POP      | PSW                                                       | 1     | 4      | $PSW \gets (SP),  SP \gets SP + 1$                                                                                                                  | R | R    | R  |
|          | rp                                                        | 1     | 6      | $rp_{H} \leftarrow (SP + 1),  rp_{L} \leftarrow (SP),  SP \leftarrow SP + 2$                                                                        |   |      |    |
| MOVW     | SP, AX                                                    | 2     | 8      | $SP \leftarrow AX$                                                                                                                                  |   |      |    |
|          | AX, SP                                                    | 2     | 6      | $AX \leftarrow SP$                                                                                                                                  |   |      |    |
| BR       | !addr16                                                   | 3     | 6      | $PC \leftarrow addr16$                                                                                                                              |   |      |    |
|          | \$addr16                                                  | 2     | 6      | $PC \gets PC + 2 + jdisp8$                                                                                                                          |   |      |    |
|          | AX                                                        | 1     | 6      | $PC_{H} \leftarrow A,  PC_{L} \leftarrow X$                                                                                                         |   |      |    |
| BC       | \$saddr16                                                 | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 1$                                                                                                         |   |      |    |
| BNC      | \$saddr16                                                 | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 0$                                                                                                         |   |      |    |
| BZ       | \$saddr16                                                 | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 1$                                                                                                          |   |      |    |
| BNZ      | \$saddr16                                                 | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 0$                                                                                                          |   |      |    |
| BT       | saddr.bit, \$addr16                                       | 4     | 10     | $PC \leftarrow PC + 4 + jdisp8 \text{ if } (saddr.bit) = 1$                                                                                         |   |      |    |
|          | sfr.bit, \$addr16                                         | 4     | 10     | $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                                         | 4     | 10     | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1                                                                                                      |   |      |    |
| BF       | saddr.bit, \$addr16                                       | 4     | 10     | $PC \leftarrow PC + 4 + jdisp8 \text{ if } (saddr.bit) = 0$                                                                                         |   |      |    |
|          | sfr.bit, \$addr16                                         | 4     | 10     | $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     | 10     | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 0                                                                                                      |   |      |    |
| DBNZ     | B, \$addr16                                               | 2     | 6      | $B \leftarrow B - 1$ , then PC $\leftarrow$ PC + 2 + jdisp8 if $B \neq 0$                                                                           |   |      |    |
|          | C, \$addr16                                               | 2     | 6      | $C \leftarrow C - 1$ , then $PC \leftarrow PC + 2 + jdisp8$ if $C \neq 0$                                                                           |   |      |    |
|          | saddr, \$addr16                                           | 3     | 8      | 8 (saddr) $\leftarrow$ (saddr) – 1, then<br>PC $\leftarrow$ PC + 3 + jdisp8 if (saddr) $\neq$ 0                                                     |   |      |    |
| NOP      |                                                           | 1     | 2      | No Operation                                                                                                                                        |   |      |    |
| EI       |                                                           | 3     | 6      | $IE \leftarrow 1$ (Enable Interrupt)                                                                                                                |   |      |    |
| DI       |                                                           | 3     | 6      | $IE \leftarrow 0$ (Disable Interrupt)                                                                                                               |   |      |    |
| HALT     |                                                           | 1     | 2      | Set HALT Mode                                                                                                                                       |   |      |    |
| STOP     | OP 1 2 Set STOP Mode                                      |       |        | Set STOP Mode                                                                                                                                       |   |      |    |

## 20.3 Instructions Listed by Addressing Type

### (1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, INC, DEC, ROR, ROL, RORC, ROLC, PUSH, POP, DBNZ

| 2nd Operand | #byte | А   | r                   | sfr | saddr | !addr16 | PSW | [DE] | [HL] | [HL + byte] | \$addr16 | 1    | None |
|-------------|-------|-----|---------------------|-----|-------|---------|-----|------|------|-------------|----------|------|------|
| 1st Operand |       |     |                     |     |       |         |     |      |      |             |          |      |      |
| A           | ADD   |     | MOV <sup>Note</sup> | MOV | MOV   | MOV     | MOV | MOV  | MOV  | MOV         |          | ROR  |      |
|             | ADDC  |     | XCH <sup>Note</sup> | ХСН | ХСН   |         |     | ХСН  | ХСН  | ХСН         |          | ROL  |      |
|             | SUB   |     | ADD                 |     | ADD   | ADD     |     |      | ADD  | ADD         |          | RORC |      |
|             | SUBC  |     | ADDC                |     | ADDC  | ADDC    |     |      | ADDC | ADDC        |          | ROLC |      |
|             | AND   |     | SUB                 |     | SUB   | SUB     |     |      | SUB  | SUB         |          |      |      |
|             | OR    |     | SUBC                |     | SUBC  | SUBC    |     |      | SUBC | SUBC        |          |      |      |
|             | XOR   |     | AND                 |     | AND   | AND     |     |      | AND  | AND         |          |      |      |
|             | CMP   |     | OR                  |     | OR    | OR      |     |      | OR   | OR          |          |      |      |
|             |       |     | XOR                 |     | XOR   | XOR     |     |      | XOR  | XOR         |          |      |      |
|             |       |     | CMP                 |     | CMP   | CMP     |     |      | CMP  | CMP         |          |      |      |
| r           | MOV   | MOV |                     |     |       |         |     |      |      |             |          |      | INC  |
|             |       |     |                     |     |       |         |     |      |      |             |          |      | DEC  |
| B, C        |       |     |                     |     |       |         |     |      |      |             | DBNZ     |      |      |
| sfr         | MOV   | MOV |                     |     |       |         |     |      |      |             |          |      |      |
| saddr       | MOV   | MOV |                     |     |       |         |     |      |      |             | DBNZ     |      | INC  |
|             | ADD   |     |                     |     |       |         |     |      |      |             |          |      | DEC  |
|             | ADDC  |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | SUB   |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | SUBC  |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | AND   |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | OR    |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | XOR   |     |                     |     |       |         |     |      |      |             |          |      |      |
|             | CMP   |     |                     |     |       |         |     |      |      |             |          |      |      |
| !addr16     |       | MOV |                     |     |       |         |     |      |      |             |          |      |      |
| PSW         | MOV   | MOV |                     |     |       |         |     |      |      |             |          |      | PUSH |
|             |       |     |                     |     |       |         |     |      |      |             |          |      | POP  |
| [DE]        |       | MOV |                     |     |       |         |     |      |      |             |          |      |      |
| [HL]        |       | MOV |                     |     |       |         |     |      |      |             |          |      |      |
| [HL + byte] |       | MOV |                     |     |       |         |     |      |      |             |          |      |      |

**Note** Except r = A.

### (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 2nd Operand | #word                | AX                   | rp <sup>Note</sup> | saddrp | SP   | None                        |
|-------------|----------------------|----------------------|--------------------|--------|------|-----------------------------|
| 1st Operand |                      |                      |                    |        |      |                             |
| AX          | ADDW<br>SUBW<br>CMPW |                      | MOVW<br>XCHW       | MOVW   | MOVW |                             |
| rp          | MOVW                 | MOVW <sup>Note</sup> |                    |        |      | INCW<br>DECW<br>PUSH<br>POP |
| saddrp      |                      | MOVW                 |                    |        |      |                             |
| sp          |                      | MOVW                 |                    |        |      |                             |

**Note** Only when rp = BC, DE, or HL.

## (3) Bit manipulation instructions

SET1, CLR1, NOT1, BT, BF

| 2nd Operand | \$addr16 | None                 |
|-------------|----------|----------------------|
| 1st Operand |          |                      |
| A.bit       | BT<br>BF | SET1<br>CLR1         |
| sfr.bit     | BT<br>BF | SET1<br>CLR1         |
| saddr.bit   | BT<br>BF | SET1<br>CLR1         |
| PSW.bit     | BT<br>BF | SET1<br>CLR1         |
| [HL].bit    |          | SET1<br>CLR1         |
| CY          |          | SET1<br>CLR1<br>NOT1 |

## (4) Call instructions/branch instructions

CALL, CALLT, BR, BC, BNC, BZ, BNZ, DBNZ

| 2nd Operand<br>1st Operand | AX | !addr16    | [addr5] | \$addr16                     |
|----------------------------|----|------------|---------|------------------------------|
| Basic instructions         | BR | CALL<br>BR | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| Compound instructions      |    |            |         | DBNZ                         |

## (5) Other instructions

RET, RETI, NOP, EI, DI, HALT, STOP

## CHAPTER 21 ELECTRICAL SPECIFICATIONS (µPD789862)

| Parameter                     | Symbol | Conditions         | Ratings                      | Unit |
|-------------------------------|--------|--------------------|------------------------------|------|
| Supply voltage                | Vdd    |                    | -0.3 to +6.5                 | V    |
| Input voltage                 | Vı     |                    | $-0.3$ to VDD + $0.3^{Note}$ | V    |
| Output voltage                | Vo     |                    | $-0.3$ to VDD + $0.3^{Note}$ | V    |
| Output current, high          | Іон    | Per pin            | -10                          | mA   |
|                               |        | Total for all pins | -30                          | mA   |
| Output current, low           | lol    | Per pin            | 30                           | mA   |
|                               |        | Total for all pins | 80                           | mA   |
| Operating ambient temperature | TA     |                    | -40 to +85                   | °C   |
| Storage temperature           | Tstg   |                    | -40 to +125                  | °C   |

#### Absolute Maximum Ratings (T<sub>A</sub> = 25°C)

Note 6.5 V or less

- 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                                                    | Conditions                                                   | MIN. | TYP. | MAX. | Unit |
|----------------------|---------------------|--------------------------------------------------------------|--------------------------------------------------------------|------|------|------|------|
| Ceramic<br>resonator |                     | Oscillation frequency<br>(f <sub>x</sub> ) <sup>Note 1</sup> | V <sub>DD</sub> = oscillation voltage<br>range               | 3    |      | 5    | MHz  |
|                      |                     | Oscillation stabilization<br>time <sup>Note 2</sup>          | After VDD reaches oscillation voltage range MIN.             |      | 80   |      | μs   |
| Crystal resonator    |                     | Oscillation frequency<br>(fx) <sup>Note 1</sup>              | V <sub>DD</sub> = oscillation voltage range                  | 3    |      | 5    | MHz  |
|                      |                     | Oscillation stabilization<br>time <sup>Note 2</sup>          | After V <sub>DD</sub> reaches oscillation voltage range MIN. |      | 8    |      | ms   |

### System Clock Oscillator Characteristics (T<sub>A</sub> = -40 to +85°C, V<sub>DD</sub> = 1.8 to 5.5 V)

- Notes 1. Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.
  - **2.** Time required to stabilize oscillation after reset or STOP mode release. Use the resonator that stabilizes oscillation within the oscillation wait time.
- Caution When using the system 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.

#### **Recommended Oscillator Constant**

| Manufacturer     | Part Number     | Frequency<br>(MHz) | Recommended Circuit<br>Constant (pF) |    | Oscillation Voltage<br>Range (Vbb) |      | Remarks           |
|------------------|-----------------|--------------------|--------------------------------------|----|------------------------------------|------|-------------------|
|                  |                 |                    | C1                                   | C2 | MIN.                               | MAX. |                   |
| Murata Mfg. Co., | CSTCR4M00G53-R0 | 4.000              | -                                    | -  | 1.8                                | 5.5  | On-chip capacitor |
| Ltd.             | CSTLS4M00G53-B0 |                    |                                      |    |                                    |      |                   |
|                  | CSTCR4M19G53-R0 | 4.195              |                                      |    |                                    |      |                   |
|                  | CSTLS4M19G53-B0 |                    |                                      |    |                                    |      |                   |
|                  | CSTCR5M00G53-R0 | 5.000              |                                      |    |                                    |      |                   |
|                  | CSTLS5M00G53-B0 |                    |                                      |    |                                    |      |                   |

## Ceramic resonator ( $T_A = -40$ to +85°C)

Caution The oscillator constant is a reference value based on evaluation in specific environments by the resonator manufacturer. If the oscillator characteristics need to be optimized in the actual application, request the resonator manufacturer for evaluation on the implementation circuit. Note that the oscillation voltage and oscillation frequency merely indicate the characteristics of the oscillator. Use the internal operation conditions of the  $\mu$ PD789862 within the specifications of the DC and AC characteristics.

| Parameter                      | Symbol | Condition                                                                    | s                                                     | MIN.                  | TYP. | MAX.        | Unit |
|--------------------------------|--------|------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------|------|-------------|------|
| Output current, low            | Iol    | Per pin                                                                      |                                                       |                       |      | 2.5         | mA   |
|                                |        | Total for all pins                                                           |                                                       |                       |      | 80.0        | mA   |
| Output current, high           | Іон    | Per pin                                                                      |                                                       |                       |      | -0.5        | mA   |
|                                |        | Total for all pins                                                           |                                                       |                       |      | 2.5<br>80.0 | mA   |
| Input voltage, high            | VIH1   | P22 to P24, P30, P32,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0.8Vdd                |      | Vdd         | V    |
|                                |        | P33, P40 to P45, RESET,<br>KRREN                                             | $1.8~V \leq V_{DD} < 2.7~V$                           | 0.9Vdd                |      | Vdd         | V    |
|                                | VIH2   | P00 to P03, P10, P11,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0.7Vdd                |      | Vdd         | V    |
|                                |        | P20, P21, P31                                                                | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$ | 0.9Vdd                |      | Vdd         | V    |
|                                | Vінз   | X1, X2                                                                       |                                                       | Vdd - 0.1             |      | Vdd         | V    |
|                                | VIH4   | EEWE                                                                         |                                                       | 0.9Vdd                |      | Vdd         | V    |
| Input voltage, low             |        | P22 to P24, P30, P32,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0                     |      | 0.2Vdd      | V    |
|                                |        | P33, P40 to P45, RESET,<br>KRREN, EEWE                                       | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$ | 0                     |      | 0.1Vdd      | V    |
|                                | VIL2   | P00 to P03, P10, P11,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0                     |      | 0.3Vdd      | V    |
|                                |        | P20, P21, P31                                                                | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$ | 0                     |      | 0.1Vdd      | V    |
|                                | VIL3   | X1, X2                                                                       |                                                       | 0                     |      | 0.1         | V    |
| Output voltage, high           | Voh1   | Іон = –100 <i>μ</i> А                                                        |                                                       | $V_{\text{DD}} - 0.5$ |      |             | V    |
|                                | Voh2   | Іон = –500 <i>μ</i> А                                                        |                                                       | $V_{\text{DD}} - 0.7$ |      |             | V    |
| Output voltage, low            | Vol1   | P00 to P03, P10, P11, P22<br>to P24, P30 to P33, P70                         | lol = 400 μA                                          |                       |      | 0.5         | V    |
|                                | Vol2   | P00 to P03, P10, P11, P22<br>to P24, P30 to P33, P70                         | IoL = 2 mA                                            |                       |      | 0.7         | V    |
|                                | Vol3   | P20, P21                                                                     | loL = 2.5 mA                                          |                       |      | 0.5         | V    |
| Input leakage<br>current, high | Ішні   | P00 to P03, P10, P11, P20<br>to P24, P30 to P33, P40 to<br>P45, RESET, KRREN | Vi = Vdd                                              |                       |      | 3           | μA   |
|                                | ILIH2  | X1, X2                                                                       | Vi = Vdd                                              |                       |      | 20          | μA   |
| Input leakage<br>current, low  | Ilil1  | P00 to P03, P10, P11, P20<br>to P24, P30 to P33,<br>KRREN, EEWE              | V1 = 0 V                                              |                       |      | -3          | μA   |
|                                |        | X1, X2                                                                       | $V_{I} = 0 V$                                         |                       |      | -20         | μA   |
| Pull-up resistance             | R1     | Other than P20, P21                                                          | V1 = 0 V                                              | 50                    | 100  | 200         | kΩ   |
|                                | R3     | P20, P21                                                                     | V1 = 0 V                                              | 10                    | 30   | 60          | kΩ   |
| Pull-down resistance           | R2     | EEWE                                                                         | Vi = Vdd                                              | 2                     | 5    | 10          | kΩ   |

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

|       | Parameter                 | Symbol |                                                                   | Conditions       |                                          | MIN. | TYP. | MAX. | Unit |
|-------|---------------------------|--------|-------------------------------------------------------------------|------------------|------------------------------------------|------|------|------|------|
| Power | supply current Note 1     | IDD1   | 5.0 MHz oscillation                                               | EEPROM operating | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 2.7  | 5.4  | mA   |
|       |                           |        | operating mode <sup>Note 2</sup><br>(C1 = C2 = 22 pF)             |                  | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 1.2  | 2.4  | mA   |
|       |                           | IDD2   | $(0^{\circ})^{\circ} = 0^{\circ} = 2^{\circ} p(^{\circ})^{\circ}$ | EEPROM stopped   | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%$ |      | 2.3  | 4.6  | mA   |
|       |                           |        |                                                                   |                  | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 1.1  | 2.2  | mA   |
|       |                           | IDD3   | 5.0 MHz oscillation                                               | EEPROM stopped   | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%$ |      | 1.0  | 2.0  | mA   |
|       |                           |        | HALT mode <sup>Note 2</sup><br>(C1 = C2 = 22 pF)                  |                  | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 0.5  | 1.0  | mA   |
|       |                           | DD4    | STOP mode                                                         | EEPROM stopped   | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 1.0  | 14.0 | μA   |
|       |                           |        |                                                                   | POC operating    | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 0.9  | 7.0  | μA   |
|       |                           | IDD5   |                                                                   | EEPROM stopped   | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 0.1  | 10.0 | μA   |
|       | <b>r</b>                  |        |                                                                   | POC stopped      | $V_{\text{DD}}=3.0~\text{V}\pm10\%$      |      | 0.05 | 5.0  | μA   |
| POC   | Detection voltage         | VPOC   | Response time 2 ms                                                | 3                |                                          | 1.8  | 1.9  | 2.0  | V    |
| LVI   | LVI7 detection voltage    | Vlvi7  | Response time 2 ms                                                | 3                |                                          | 2.4  | 2.6  | 2.8  | V    |
|       | LVI6 detection voltage    | Vlvi6  | Response time 2 ms                                                | 3                |                                          |      | 2.5  |      | V    |
|       | LVI5 detection voltage    | Vlvi5  | Response time 2 ms                                                | 3                |                                          |      | 2.4  |      | V    |
|       | LVI4 detection voltage    | Vlvi4  | Response time 2 ms                                                | 3                |                                          |      | 2.3  |      | V    |
|       | LVI3 detection voltage    | Vlvi3  | Response time 2 ms                                                | 3                |                                          |      | 2.2  |      | V    |
|       | LVI2 detection voltage    | Vlvi2  | Response time 2 ms                                                | 3                |                                          |      | 2.1  |      | V    |
|       | LVI1 detection<br>voltage | VLVI1  | Response time 2 ms                                                | 3                |                                          |      | 2.0  |      | V    |
|       | LVI0 detection voltage    | Vlvio  | Response time 2 ms                                                | ;<br>;           |                                          | 1.7  | 1.9  | 2.1  | V    |

# DC Characteristics (TA = -40 to $+85^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V) (2/2)

Notes 1. Port current (including the current flowing through the internal pull-up resistors) is not included.

2. During high-speed mode operation (when the processor clock control register (PCC) is set to 00H)

 $\label{eq:remark} \textbf{Remark} \quad V_{LV17} > V_{LV16} > V_{LV15} > V_{LV14} > V_{LV13} > V_{LV12} > V_{LV11} > V_{LV10}$ 

### **AC Characteristics**

| Parameter                             | Symbol        | Conditions                                                | MIN.         | TYP. | MAX. | Unit |
|---------------------------------------|---------------|-----------------------------------------------------------|--------------|------|------|------|
| Instruction cycle                     | Тсү           | $2.7~V \leq V_{DD} \leq 5.5~V$                            | 0.4          |      | 2.67 | μs   |
| (Minimum instruction execution time)  |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 1.6          |      | 2.67 | μs   |
| TI00, TI01 input high-/low-level      | tтюн, tтю∟    | $2.7~V \leq V_{DD} \leq 5.5~V$                            | 2/fsam + 0.2 |      |      | μs   |
| width                                 |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 2/fsam + 0.4 |      |      | μs   |
| TI50 input high-/low-level width      | t⊤ıн, t⊤ı∟    | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 100          |      |      | ns   |
|                                       |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 400          |      |      | ns   |
| Key input pin high-level width        | <b>t</b> krih | KR5                                                       | 10           |      |      | μs   |
| Key input pin low-level width         | <b>t</b> KRIL | KR0 to KR5                                                | 10           |      |      | μs   |
| Interrupt input high-/low-level width | tintн,        | INTP0, INTP1                                              | 10           |      |      | μs   |
|                                       | <b>t</b> intl |                                                           |              |      |      |      |
| RESET input low-level width           | <b>t</b> RST  |                                                           | 10           |      |      | μs   |

## (1) Basic operation ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)

**Remark** fsam: Timer count clock (Note that when selecting the TI00 and TI01 valid edges as the timer count clock, fsam = fx/8 (refer to **Figure 7-1 Block Diagram of 16-Bit Timer/Event Counter 0**))





### (2) Serial interface 2 (V<sub>DD</sub> = 1.8 to 5.5 V, $T_A = -40$ to +85°C)

| Parameter                                 | Symbol        | Conditio                                                   | ons                                                       | MIN.          | TYP. | MAX. | Unit |
|-------------------------------------------|---------------|------------------------------------------------------------|-----------------------------------------------------------|---------------|------|------|------|
| SCK2 cycle time                           | tkcy1         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                      |                                                           | 800           |      |      | ns   |
|                                           |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$  | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |               |      |      | ns   |
| SCK2 high-/low-level                      | <b>t</b> кн1, | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                      |                                                           | tксү1/2 – 50  |      |      | ns   |
| width                                     | tĸ∟1          | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$      |                                                           | tксү1/2 – 150 |      |      | ns   |
| SI2 setup time                            | tsik1         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                      |                                                           | 150           |      |      | ns   |
| (to SCK2↑)                                |               | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$      |                                                           | 500           |      |      | ns   |
| SI2 hold time                             | tksi1         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                      |                                                           | 400           |      |      | ns   |
| (from SCK2↑)                              |               | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$      |                                                           | 600           |      |      | ns   |
| Delay time from                           | tkso1         | $R = 1 \text{ k}\Omega,  C = 100 \text{ pF}^{\text{Note}}$ | $2.7~V \le V_{\text{DD}} \le 5.5~V$                       | 0             |      | 250  | ns   |
| $\overline{SCK2}\downarrow$ to SO2 output |               |                                                            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 0             |      | 1000 | ns   |

### (a) 3-wire serial I/O mode (SCK2...Internal clock)

**Note** R and C are the load resistance and load capacitance of the SO2 output line.

## (b) 3-wire serial I/O mode (SCK2...External clock)

| Parameter                       | Symbol        | Conditi                                                   | ons                                                       | MIN. | TYP. | MAX. | Unit |
|---------------------------------|---------------|-----------------------------------------------------------|-----------------------------------------------------------|------|------|------|------|
| SCK2 cycle time                 | tkCY2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                           | 800  |      |      | ns   |
|                                 |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |                                                           | 3200 |      |      | ns   |
| SCK2 high-/low-level            | <b>t</b> кн2, | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                           | 400  |      |      | ns   |
| width                           | tĸ∟2          | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |      |      |      | ns   |
| SI2 setup time                  | tsik2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                           | 100  |      |      | ns   |
| (to SCK2↑)                      |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |                                                           | 150  |      |      | ns   |
| SI2 hold time                   | tksi2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                           | 400  |      |      | ns   |
| (from SCK2↑)                    |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |                                                           | 600  |      |      | ns   |
| Delay time from                 | tkso2         | $R = 1 \text{ k}\Omega$ , $C = 100 \text{ pF}^{Note}$     | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 0    |      | 300  | ns   |
| SCK2 $\downarrow$ to SO2 output |               |                                                           | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 0    |      | 1000 | ns   |

 $\label{eq:Note} \textbf{R} \text{ and } \textbf{C} \text{ are the load resistance and load capacitance of the SO2 output line.}$ 

### (c) UART mode (dedicated baud rate generator output)

| Parameter     | Symbol | Conditions                                               | MIN. | TYP. | MAX.  | Unit |
|---------------|--------|----------------------------------------------------------|------|------|-------|------|
| Transfer rate |        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                    |      |      | 78125 | bps  |
|               |        | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$ |      |      | 19531 | bps  |

# (d) UART mode (external clock input)

| Parameter                  | Symbol     | Conditions                                                | MIN. | TYP. | MAX.  | Unit |
|----------------------------|------------|-----------------------------------------------------------|------|------|-------|------|
| ASCK2 cycle time           | tксүз      | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     | 800  |      |       | ns   |
|                            |            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 3200 |      |       | ns   |
| ASCK2 high-/low-           | tкнз, tк∟з | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     | 400  |      |       | ns   |
| level width                |            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 1600 |      |       | ns   |
| Transfer rate              |            | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     |      |      | 39063 | bps  |
|                            |            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |      |      | 9766  | bps  |
| ASCK2 rise time, fall time | tr, tr     |                                                           |      |      | 1     | μs   |

#### AC Timing Test Points (Excluding X1 Input)



#### Serial Transfer Timing

#### 3-wire serial I/O mode:



**Remark** m = 1, 2

UART mode (external clock input):



#### (3) EEPROM ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)

| Parameter                  | Symbol | Conditions | MIN. | TYP. | MAX.   | Unit  |
|----------------------------|--------|------------|------|------|--------|-------|
| Write time <sup>Note</sup> |        |            | 3.3  |      | 6.6    | ms    |
| Rewrite count              |        | Per byte   |      |      | 100000 | Times |

**Note** Write time =  $T \times 145$  (T: Time for the cycle of the clock selected by EWCS10 to EWCS12)

#### (4) Power supply startup ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)

| Parameter                   | Symbol | Conditions                                                             | MIN. | TYP. | MAX. | Unit |
|-----------------------------|--------|------------------------------------------------------------------------|------|------|------|------|
| Power supply startup time 1 | tpth1  | POC switching circuit used (V <sub>DD</sub> : 0 V $\rightarrow$ 1.8 V) |      |      | 100  | ms   |
| Power supply startup time 2 | tpth2  | POC always used (V <sub>DD</sub> : 0 V $\rightarrow$ 1.8 V)            | 0.01 |      | 100  | ms   |

#### Memory Storage Data Retention Characteristics (T<sub>A</sub> = -40 to +85°C)

| Parameter                           | Symbol        | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------------|---------------|------------|------|------|------|------|
| Data retention power supply voltage | Vdddr         |            | 1.8  |      | 5.5  | V    |
| Release signal set time             | <b>t</b> SREL |            | 0    |      |      | μs   |

#### Oscillation Wait Time (T<sub>A</sub> = -40 to +85°C, V<sub>DD</sub> = 1.8 to 5.5 V)

| Parameter                      | Symbol        | Conditions                  | MIN. | TYP.                | MAX. | Unit |
|--------------------------------|---------------|-----------------------------|------|---------------------|------|------|
| Oscillation stabilization wait | <b>t</b> wait | Release by RESET pin or POC |      | 2 <sup>12</sup> /fx |      | s    |
| time <sup>Note 1</sup>         |               | Release by interrupt        |      | Note 2              |      | s    |

**Notes 1.** The oscillation stabilization wait time is the time the CPU operation is stopped to prevent unstable operation when oscillation starts.

**2.** 2<sup>12</sup>/fx, 2<sup>15</sup>/fx, or 2<sup>17</sup>/fx can be selected by using bits 0 to 2 (OSTS0 to OSTS2) of the oscillation stabilization time selection register (OSTS).

**Remark** fx: System clock oscillation frequency





#### Data Retention Timing (Standby Release Signal: STOP Mode Release by Interrupt Signal)



#### CHAPTER 22 ELECTRICAL SPECIFICATIONS (µPD78E9862)

# Caution The $\mu$ PD78E9862 is provided exclusively for program development; the product life and reliability are not guaranteed. Use the $\mu$ PD789862 for reliability testing and mass production.

#### Absolute Maximum Ratings (T<sub>A</sub> = 25°C)

★

| Parameter                     | Symbol | Conditions         | Ratings                                  | Unit |
|-------------------------------|--------|--------------------|------------------------------------------|------|
| Supply voltage                | Vdd    |                    | -0.3 to +6.5                             | V    |
|                               | Vpp    |                    | –0.3 to +10.5                            | V    |
| Input voltage                 | Vı     |                    | $-0.3$ to V <sub>DD</sub> + $0.3^{Note}$ | V    |
| Output voltage                | Vo     |                    | $-0.3$ to V <sub>DD</sub> + $0.3^{Note}$ | V    |
| Output current, high          | Іон    | Per pin            | -10                                      | mA   |
|                               |        | Total for all pins | -30                                      | mA   |
| Output current, low           | lol    | Per pin            | 30                                       | mA   |
|                               |        | Total for all pins | 80                                       | mA   |
| Operating ambient temperature | TA     |                    | -40 to +70                               | °C   |
| Storage temperature           | Tstg   |                    | -40 to +125                              | °C   |

Note 6.5 V or less

- 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                                                    | Conditions                                                   | MIN. | TYP. | MAX. | Unit |
|----------------------|---------------------|--------------------------------------------------------------|--------------------------------------------------------------|------|------|------|------|
| Ceramic<br>resonator |                     | Oscillation frequency<br>(f <sub>x</sub> ) <sup>Note 1</sup> | V <sub>DD</sub> = oscillation voltage<br>range               | 3    |      | 5    | MHz  |
|                      |                     | Oscillation stabilization<br>time <sup>Note 2</sup>          | After VDD reaches oscillation voltage range MIN.             |      | 80   |      | μs   |
| Crystal resonator    |                     | Oscillation frequency<br>(fx) <sup>Note 1</sup>              | V <sub>DD</sub> = oscillation voltage range                  | 3    |      | 5    | MHz  |
|                      |                     | Oscillation stabilization<br>time <sup>Note 2</sup>          | After V <sub>DD</sub> reaches oscillation voltage range MIN. |      | 8    |      | ms   |

#### System Clock Oscillator Characteristics (T<sub>A</sub> = -40 to +70°C, V<sub>DD</sub> = 1.8 to 5.5 V)

- Notes 1. Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.
  - **2.** Time required to stabilize oscillation after reset or STOP mode release. Use the resonator that stabilizes oscillation within the oscillation wait time.
- Caution When using the system 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.

#### **Recommended Oscillator Constant**

| Manufacturer     | Part Number     | Frequency<br>(MHz) |    | Recommended Circuit<br>Constant (pF) |      |      |                   | n Voltage<br>e (V <sub>DD</sub> ) | Remarks |
|------------------|-----------------|--------------------|----|--------------------------------------|------|------|-------------------|-----------------------------------|---------|
|                  |                 |                    | C1 | C2                                   | MIN. | MAX. |                   |                                   |         |
| Murata Mfg. Co., | CSTCR4M00G53-R0 | 4.000              | -  | -                                    | 1.8  | 5.5  | On-chip capacitor |                                   |         |
| Ltd.             | CSTLS4M00G53-B0 |                    | -  |                                      |      |      |                   |                                   |         |
|                  | CSTCR4M19G53-R0 | 4.195              |    |                                      |      |      |                   |                                   |         |
|                  | CSTLS4M19G53-B0 |                    |    |                                      |      |      |                   |                                   |         |
|                  | CSTCR5M00G53-R0 | 5.000              |    |                                      |      |      |                   |                                   |         |
|                  | CSTLS5M00G53-B0 |                    |    |                                      |      |      |                   |                                   |         |

#### Ceramic resonator ( $T_A = -40$ to +70°C)

Caution The oscillator constant is a reference value based on evaluation in specific environments by the resonator manufacturer. If the oscillator characteristics need to be optimized in the actual application, request the resonator manufacturer for evaluation on the implementation circuit. Note that the oscillation voltage and oscillation frequency merely indicate the characteristics of the oscillator. Use the internal operation conditions of the  $\mu$ PD78E9862 within the specifications of the DC and AC characteristics.

| Parameter                      | Symbol | Condition                                                                    | s                                                     | MIN.      | TYP.  | MAX.   | Unit |
|--------------------------------|--------|------------------------------------------------------------------------------|-------------------------------------------------------|-----------|-------|--------|------|
| Output current, low            | lог    | Per pin                                                                      |                                                       |           |       | 2.5    | mA   |
|                                |        | Total for all pins                                                           |                                                       |           |       | 80.0   | mA   |
| Output current, high           | Іон    | Per pin                                                                      |                                                       |           |       | -0.5   | mA   |
|                                |        | Total for all pins                                                           |                                                       |           | -15.0 | mA     |      |
| Input voltage, high            | VIH1   | P22 to P24, P30, P32,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0.8Vdd    |       | Vdd    | V    |
|                                |        | P33, P40 to P45, RESET,<br>KRREN                                             | $1.8~V \leq V_{DD} < 2.7~V$                           | 0.9Vdd    |       | Vdd    | V    |
|                                | VIH2   | P00 to P03, P10, P11,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0.7Vdd    |       | Vdd    | V    |
|                                |        | P20, P21, P31                                                                | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$ | 0.9Vdd    |       | Vdd    | V    |
|                                | Vінз   | X1, X2                                                                       |                                                       | Vdd - 0.1 |       | Vdd    | V    |
|                                | VIH4   | EEWE                                                                         |                                                       | 0.9Vdd    |       | Vdd    | V    |
| Input voltage, low             | VIL1   | P22 to P24, P30, P32,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0         |       | 0.2VDD | V    |
|                                |        | P33, P40 to P45, RESET,<br>KRREN, EEWE                                       | $1.8~V \leq V_{DD} < 2.7~V$                           | 0         |       | 0.1Vdd | V    |
|                                | VIL2   | P00 to P03, P10, P11,                                                        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                 | 0         |       | 0.3Vdd | V    |
|                                |        | P20, P21, P31                                                                | $1.8~\text{V} \leq \text{V}_\text{DD} < 2.7~\text{V}$ | 0         |       | 0.1Vdd | V    |
|                                | VIL3   | X1, X2                                                                       |                                                       | 0         |       | 0.1    | V    |
| Output voltage, high           | Voh1   | Іон = -100 <i>μ</i> А                                                        | $V_{DD} - 0.5$                                        |           |       | V      |      |
|                                | Voh2   | Іон = -500 <i>µ</i> А                                                        | Vdd - 0.7                                             |           |       | V      |      |
| Output voltage, low            | Vol1   | P00 to P03, P10, P11, P22<br>to P24, P30 to P33, P70                         | IoL = 400 μA                                          |           |       | 0.5    | V    |
|                                | Vol2   | P00 to P03, P10, P11, P22<br>to P24, P30 to P33, P70                         | IoL = 2 mA                                            |           |       | 0.7    | V    |
|                                | Vol3   | P20, P21                                                                     | loL = 2.5 mA                                          |           |       | 0.5    | V    |
| Input leakage<br>current, high | Ілні   | P00 to P03, P10, P11, P20<br>to P24, P30 to P33, P40 to<br>P45, RESET, KRREN | Vi = Vdd                                              |           |       | 3      | μA   |
|                                | Іцн2   | X1, X2                                                                       | Vi = Vdd                                              |           |       | 20     | μA   |
| Input leakage<br>current, low  | Ilil1  | P00 to P03, P10, P11, P20<br>to P24, P30 to P33,<br>KRREN, EEWE              | V1 = 0 V                                              |           |       | -3     | μA   |
|                                | ILIL2  | X1, X2                                                                       | V1 = 0 V                                              |           |       | -20    | μA   |
| Pull-up resistance             | R1     | Other than P20, P21                                                          | V1 = 0 V                                              | 50        | 100   | 200    | kΩ   |
|                                | R3     | P20, P21                                                                     | V1 = 0 V                                              | 10        | 30    | 60     | kΩ   |
| Pull-down resistance           | R2     | EEWE                                                                         | Vi = Vdd                                              | 2         | 5     | 10     | kΩ   |

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

|                                | Parameter                 | Symbol                                           |                                                                   | Conditions                        |                                          | MIN. | TYP. | MAX. | Unit |
|--------------------------------|---------------------------|--------------------------------------------------|-------------------------------------------------------------------|-----------------------------------|------------------------------------------|------|------|------|------|
| Power                          | supply current Note 1     | IDD1                                             | 5.0 MHz oscillation                                               | EEPROM operating                  | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 3.1  | 6.2  | mA   |
|                                |                           |                                                  | operating mode <sup>Note 2</sup><br>(C1 = C2 = 22 pF)             |                                   | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 1.5  | 3.0  | mA   |
|                                |                           | IDD2                                             | $(0^{\circ})^{\circ} = 0^{\circ} = 2^{\circ} p(^{\circ})^{\circ}$ | EEPROM stopped                    | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%$ |      | 2.9  | 5.8  | mA   |
|                                |                           |                                                  |                                                                   |                                   | $V_{\text{DD}}=3.0~\text{V}\pm10\%$      |      | 1.4  | 2.8  | mA   |
|                                |                           | IDD3                                             | 5.0 MHz oscillation                                               | EEPROM stopped                    | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 1.6  | 3.2  | mA   |
|                                |                           | HALT mode <sup>Note 2</sup><br>(C1 = C2 = 22 pF) |                                                                   | $V_{DD} = 3.0 \text{ V} \pm 10\%$ |                                          | 0.7  | 1.4  | mA   |      |
|                                |                           | DD4                                              | STOP mode                                                         | EEPROM stopped                    | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 1.0  | 26.0 | μA   |
|                                |                           |                                                  |                                                                   | POC operating                     | $V_{DD} = 3.0 \text{ V} \pm 10\%$        |      | 0.9  | 13.0 | μA   |
|                                |                           | IDD5                                             |                                                                   | EEPROM stopped                    | $V_{DD} = 5.0 \text{ V} \pm 10\%$        |      | 0.1  | 22.0 | μA   |
|                                | 1                         |                                                  |                                                                   | POC stopped                       | $V_{\text{DD}}=3.0~\text{V}\pm10\%$      |      | 0.05 | 11.0 | μA   |
| POC                            | Detection voltage         | VPOC                                             | Response time 2 ms                                                | 3                                 |                                          | 1.8  | 1.9  | 2.0  | V    |
| LVI                            | LVI7 detection voltage    | Vlvi7                                            | Response time 2 ms                                                |                                   |                                          | 2.4  | 2.6  | 2.8  | V    |
|                                | LVI6 detection voltage    | Vlvi6                                            | Response time 2 ms                                                |                                   |                                          |      | 2.5  |      | V    |
|                                | LVI5 detection voltage    | Vlvi5                                            | Response time 2 ms                                                | 3                                 |                                          |      | 2.4  |      | V    |
|                                | LVI4 detection voltage    | Vlvi4                                            | Response time 2 ms                                                | 3                                 |                                          |      | 2.3  |      | V    |
|                                | LVI3 detection voltage    | Vlvi3                                            | Response time 2 ms                                                | 3                                 |                                          |      | 2.2  |      | V    |
| LVI2 detection VLVI<br>voltage |                           | Vlvi2                                            | Response time 2 ms                                                | 3                                 |                                          |      | 2.1  |      | V    |
|                                | LVI1 detection<br>voltage | VLVI1                                            | Response time 2 ms                                                | 3                                 |                                          |      | 2.0  |      | V    |
|                                | LVI0 detection voltage    | Vlvio                                            | Response time 2 ms                                                | ;<br>;                            |                                          | 1.7  | 1.9  | 2.1  | V    |

### DC Characteristics (TA = -40 to $+70^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V) (2/2)

Notes 1. Port current (including the current flowing through the internal pull-up resistors) is not included.

2. During high-speed mode operation (when the processor clock control register (PCC) is set to 00H)

 $\label{eq:remark} \textbf{Remark} \quad V_{LV17} > V_{LV16} > V_{LV15} > V_{LV14} > V_{LV13} > V_{LV12} > V_{LV11} > V_{LV10}$ 

#### **AC Characteristics**

| Parameter                              | Symbol        | Conditions                                                | MIN.         | TYP. | MAX. | Unit |
|----------------------------------------|---------------|-----------------------------------------------------------|--------------|------|------|------|
| Instruction cycle                      | Тсч           | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 0.4          |      | 2.67 | μs   |
| (Minimum instruction execution time)   |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 1.6          |      | 2.67 | μs   |
| TI00, TI01 input high-/low-level width | tтюн, tтю∟    | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 2/fsam + 0.2 |      |      | μs   |
|                                        |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 2/fsam + 0.4 |      |      | μs   |
| TI50 input high-/low-level width       | t⊤ıн, t⊤ı∟    | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 100          |      |      | ns   |
|                                        |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 400          |      |      | ns   |
| Key input pin high-level width         | <b>t</b> KRIH | KR5                                                       | 10           |      |      | μs   |
| Key input pin low-level width          | <b>t</b> KRIL | KR0 to KR5                                                | 10           |      |      | μs   |
| Interrupt input high-/low-level width  | tınтн,        | INTP0, INTP1                                              | 10           |      |      | μs   |
|                                        | <b>t</b> intl |                                                           |              |      |      |      |
| RESET input low-level width            | <b>t</b> RST  |                                                           | 10           |      |      | μs   |

#### (1) Basic operation ( $T_A = -40$ to $+70^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)

**Remark** fsam: Timer count clock (Note that when selecting the TI00 and TI01 valid edges as the timer count clock, fsam = fx/8 (refer to **Figure 7-1 Block Diagram of 16-Bit Timer/Event Counter 0**))





#### (2) Serial interface 2 (V<sub>DD</sub> = 1.8 to 5.5 V, $T_A = -40$ to +70°C)

| Parameter                                        | Symbol | Conditio                                                  | Conditions                                                |   |  | MAX. | Unit |
|--------------------------------------------------|--------|-----------------------------------------------------------|-----------------------------------------------------------|---|--|------|------|
| SCK2 cycle time                                  | tkcy1  | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 800                                                       |   |  | ns   |      |
|                                                  |        | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 3200                                                      |   |  | ns   |      |
| SCK2 high-/low-level                             | tкнı,  | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | tксү1/2 – 50                                              |   |  | ns   |      |
| width                                            | tĸ∟1   | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | tксү1/2 – 150                                             |   |  | ns   |      |
| SI2 setup time                                   | tsik1  | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | $V \le V_{DD} \le 5.5 V$                                  |   |  |      | ns   |
| (to SCK2↑)                                       |        | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |   |  |      | ns   |
| SI2 hold time                                    | tksi1  | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 400                                                       |   |  | ns   |      |
| (from SCK2↑)                                     |        | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |   |  |      | ns   |
| Delay time from                                  | tkso1  | $R = 1 \text{ k}\Omega, C = 100 \text{ pF}^{Note}$        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | 0 |  | 250  | ns   |
| $\overline{\text{SCK2}}\downarrow$ to SO2 output |        |                                                           | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 0 |  | 1000 | ns   |

#### (a) 3-wire serial I/O mode (SCK2...Internal clock)

**Note** R and C are the load resistance and load capacitance of the SO2 output line.

#### (b) 3-wire serial I/O mode (SCK2...External clock)

| Parameter                                        | Symbol        | Conditi                                                   | MIN.                                                         | TYP. | MAX. | Unit |    |
|--------------------------------------------------|---------------|-----------------------------------------------------------|--------------------------------------------------------------|------|------|------|----|
| SCK2 cycle time                                  | tkCY2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                              | 800  |      |      | ns |
|                                                  |               | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$    |      |      |      | ns |
| SCK2 high-/low-level                             | <b>t</b> кн2, | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                              | 400  |      |      | ns |
| width                                            | tĸ∟2          | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |                                                              | 1600 |      |      | ns |
| SI2 setup time                                   | tsik2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     | $2.7 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V}$ |      |      |      | ns |
| (to SCK2↑)                                       |               | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |                                                              | 150  |      |      | ns |
| SI2 hold time                                    | tksi2         | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |                                                              | 400  |      |      | ns |
| (from SCK2↑)                                     |               | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  |                                                              | 600  |      |      | ns |
| Delay time from                                  | tkso2         | $R = 1 \text{ k}\Omega$ , $C = 100 \text{ pF}^{Note}$     | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                        | 0    |      | 300  | ns |
| $\overline{\text{SCK2}}\downarrow$ to SO2 output |               |                                                           | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$    | 0    |      | 1000 | ns |

 $\label{eq:Note} \textbf{R} \text{ and } \textbf{C} \text{ are the load resistance and load capacitance of the SO2 output line.}$ 

#### (c) UART mode (dedicated baud rate generator output)

| Parameter     | Symbol | Conditions                                                | MIN. | TYP. | MAX.  | Unit |
|---------------|--------|-----------------------------------------------------------|------|------|-------|------|
| Transfer rate |        | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$                     |      |      | 78125 | bps  |
|               |        | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |      |      | 19531 | bps  |

### (d) UART mode (external clock input)

| Parameter                  | Symbol     | Conditions                                                | MIN. | TYP. | MAX.  | Unit |
|----------------------------|------------|-----------------------------------------------------------|------|------|-------|------|
| ASCK2 cycle time           | tксүз      | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     | 800  |      |       | ns   |
|                            |            | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 2.7 \text{ V}$  | 3200 |      |       | ns   |
| ASCK2 high-/low-           | tкнз, tк∟з | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     | 400  |      |       | ns   |
| level width                |            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ | 1600 |      |       | ns   |
| Transfer rate              |            | $2.7 \text{ V} \leq V_{\text{DD}} \leq 5.5 \text{ V}$     |      |      | 39063 | bps  |
|                            |            | $1.8 \text{ V} \leq \text{V}_{\text{DD}} < 2.7 \text{ V}$ |      |      | 9766  | bps  |
| ASCK2 rise time, fall time | tr, tr     |                                                           |      |      | 1     | μs   |

#### AC Timing Test Points (Excluding X1 Input)



#### Serial Transfer Timing

#### 3-wire serial I/O mode:



**Remark** m = 1, 2

UART mode (external clock input):



#### (3) EEPROM (T<sub>A</sub> = -40 to $+70^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V)

| Parameter                    | Symbol | Conditions | MIN. | TYP. | MAX.   | Unit  |
|------------------------------|--------|------------|------|------|--------|-------|
| Write time <sup>Note 1</sup> |        |            | 3.3  |      | 6.6    | ms    |
| Rewrite count                |        | Per byte   |      |      | Note 2 | Times |

**Notes 1.** Write time =  $T \times 145$  (T: Time for the cycle of the clock selected by EWCS10 to EWCS12)

**2.** The rewrite count of EEPROM is not guaranteed because the μPD78E9862 is used exclusively for program development.

#### (4) Power supply startup ( $T_A = -40$ to $+70^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)

| Parameter                   | Symbol | Conditions                                                  | MIN. | TYP. | MAX. | Unit |
|-----------------------------|--------|-------------------------------------------------------------|------|------|------|------|
| Power supply startup time 1 | tpth1  | POC switching circuit used (V_DD: 0 V $\rightarrow$ 1.8 V)  | 0.01 |      | 100  | ms   |
| Power supply startup time 2 | tртн2  | POC always used (V <sub>DD</sub> : 0 V $\rightarrow$ 1.8 V) | 0.01 |      | 100  | ms   |

#### Memory Storage Data Retention Characteristics (T<sub>A</sub> = -40 to +70°C)

| Parameter                           | Symbol        | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------------|---------------|------------|------|------|------|------|
| Data retention power supply voltage | Vdddr         |            | 1.8  |      | 5.5  | V    |
| Release signal set time             | <b>t</b> SREL |            | 0    |      |      | μs   |

#### Oscillation Wait Time (T<sub>A</sub> = -40 to +70°C, V<sub>DD</sub> = 1.8 to 5.5 V)

| Parameter                      | Symbol        | Conditions                  | MIN. | TYP.                | MAX. | Unit |
|--------------------------------|---------------|-----------------------------|------|---------------------|------|------|
| Oscillation stabilization wait | <b>t</b> wait | Release by RESET pin or POC |      | 2 <sup>12</sup> /fx |      | s    |
| time <sup>Note 1</sup>         |               | Release by interrupt        |      | Note 2              |      | S    |

**Notes 1.** The oscillation stabilization wait time is the time the CPU operation is stopped to prevent unstable operation when oscillation starts.

**2.** 2<sup>12</sup>/fx, 2<sup>15</sup>/fx, or 2<sup>17</sup>/fx can be selected by using bits 0 to 2 (OSTS0 to OSTS2) of the oscillation stabilization time selection register (OSTS).

Remark fx: System clock oscillation frequency





#### Data Retention Timing (Standby Release Signal: STOP Mode Release by Interrupt Signal)



# 30-PIN PLASTIC SSOP (7.62 mm (300))



detail of lead end

U

- E





#### NOTE

Each lead centerline is located within 0.13 mm of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS                           |
|------|---------------------------------------|
| А    | 9.85±0.15                             |
| В    | 0.45 MAX.                             |
| С    | 0.65 (T.P.)                           |
| D    | $0.24^{+0.08}_{-0.07}$                |
| Е    | 0.1±0.05                              |
| F    | 1.3±0.1                               |
| G    | 1.2                                   |
| Н    | 8.1±0.2                               |
| I    | 6.1±0.2                               |
| J    | 1.0±0.2                               |
| К    | 0.17±0.03                             |
| L    | 0.5                                   |
| М    | 0.13                                  |
| Ν    | 0.10                                  |
| Р    | $3^{\circ}^{+5^{\circ}}_{-3^{\circ}}$ |
| Т    | 0.25                                  |
| U    | 0.6±0.15                              |
|      | S30MC-65-5A4-2                        |

#### CHAPTER 24 RECOMMENDED SOLDERING CONDITIONS

The  $\mu$ PD789862 Subseries should be soldered and mounted under the following recommended conditions.

For soldering methods and conditions other than those recommended below, contact an NEC Electronics sales representative.

For technical information, see the following website.

\*

Semiconductor Device Mount Manual (http://www.necel.com/pkg/en/mount/index.html)

#### Table 24-1. Surface Mounting Type Soldering Conditions (1/2)

(1) μPD789862MC-×××-5A4: 30-pin plastic SSOP (7.62 mm (300))

| Soldering Method | Soldering Conditions                                                                                                                                                                                                                | Recommended<br>Condition Symbol |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow  | Package peak temperature: 235°C, Time: 30 seconds max. (at 210°C or higher),<br>Count: Twice or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for<br>20 hours)                                         | IR35-207-2                      |
| VPS              | Package peak temperature: 215°C, Time: 40 seconds max. (at 200°C or higher),<br>Count: Twice or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for<br>20 hours)                                         | VP15-207-2                      |
| Wave soldering   | Solder bath temperature: 260°C max., Time: 10 seconds max., Count: Once,<br>Preheating temperature: 120°C max. (package surface temperature), Exposure<br>limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for 20 hours) | WS60-207-1                      |
| Partial heating  | Pin temperature: 300°C max., Time: 3 seconds max. (per pin row)                                                                                                                                                                     | _                               |

Note After opening the dry pack, store it at 25°C or less and 65% RH or less for the allowable storage period.

Caution Do not use different soldering methods together (except for partial heating).

#### Table 24-1. Surface Mounting Type Soldering Conditions (2/2)

#### (2) μPD78E9862MC-5A4: 30-pin plastic SSOP (7.62 mm (300))

| Soldering Method | Soldering Conditions                                                                                                                                                                                                                | Recommended<br>Condition Symbol |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow  | Package peak temperature: 235°C, Time: 30 seconds max. (at 210°C or higher),<br>Count: Three times or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C<br>for 10 hours)                                   | IR35-107-3                      |
| VPS              | Package peak temperature: 215°C, Time: 40 seconds max. (at 200°C or higher),<br>Count: Three times or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C<br>for 10 hours)                                   | VP15-107-3                      |
| Wave soldering   | Solder bath temperature: 260°C max., Time: 10 seconds max., Count: Once,<br>Preheating temperature: 120°C max. (package surface temperature), Exposure<br>limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for 10 hours) | WS60-107-1                      |
| Partial heating  | Pin temperature: 300°C max., Time: 3 seconds max. (per pin row)                                                                                                                                                                     | -                               |

**Note** After opening the dry pack, store it at 25°C or less and 65% RH or less for the allowable storage period.

Caution Do not use different soldering methods together (except for partial heating).

#### APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for development of systems using the  $\mu$ PD789862 Subseries. Figure A-1 shows development tools.

• Compatibility with PC98-NX Series

Unless stated otherwise, products which are supported for IBM PC/AT<sup>™</sup> and compatibles can also be used with the PC98-NX Series. When using the PC98-NX Series, therefore, refer to the explanations for IBM PC/AT and compatibles.

• Windows

Unless stated otherwise, "Windows" refers to the following operating systems.

- Windows 3.1
- Windows 95
- Windows 98
- Windows 2000
- Windows NT<sup>™</sup> Ver. 4.0







The project manager is included in the assembler package.
 The project manager is not used in environments other than Windows.

#### A.1 Software Package

| SP78K0S<br>Software package | Various software tools for 78K/0S Series development are integrated in one package.<br>The following tools are included.<br>RA78K0S, CC78K0S, ID78K0S-NS, various device files |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Part number: <i>µ</i> S××××SP78K0S                                                                                                                                             |

# μS<u>××××</u> SP78K0S

| ××××                           | Host Machine    | OS               | Supply Medium |
|--------------------------------|-----------------|------------------|---------------|
| AB17                           | PC-9800 series, | Japanese Windows | CD-ROM        |
| BB17 IBM PC/AT and compatibles |                 | English Windows  |               |

#### A.2 Language Processing Software

| <ul> <li>Program that converts program written in mnemonic into object code that can be executed by microcontroller.</li> <li>In addition, automatic functions to generate symbol table and optimize branch instructions are also provided. Used in combination with device file (DF789862) (sold separately).</li> <li><caution environment="" in="" pc="" used="" when=""></caution></li> <li>The assembler package is a DOS-based application but may be used in the Windows environment by using Project Manager of Windows (included in the assembler package).</li> <li>Part number: μS××××RA78K0S</li> </ul> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Program that converts program written in C language into object codes that can be executed by microcontroller.<br>Used in combination with assembler package (RA78K0S) and device file (DF789862) (both sold separately).<br><caution environment="" in="" pc="" used="" when=""><br/>The C compiler package is a DOS-based application but may be used in the Windows environment by using Project Manager of Windows (included in the assembler package).</caution>                                                                                                                                               |
| Part number: μSxxxxCC78K0S         File containing the information inherent to the device.         Used in combination with other tools (RA78K0S, CC78K0S, ID78K0S-NS) (all sold separately).         Part number: μSxxxxDF789862                                                                                                                                                                                                                                                                                                                                                                                   |
| Source file of functions constituting object library included in C compiler package.         Necessary for changing object library included in C compiler package according to customer's specifications.         Since this is the source file, its working environment does not depend on any particular operating system.         Part number: μSxxxxCC78K0S-L                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Notes 1. DF789862 is a common file that can be used with RA78K0S and CC78K0S.

2. CC78K0S-L is not included in the software package (SP78K0S).

**Remark** ×××× in the part number differs depending on the host machines and operating systems to be used.

### $\mu$ S××××RA78K0S

 $\mu S \times \times \times CC78 K0S$ 

| ×××× | Host Machine                   | OS                                                                  | Supply Medium |
|------|--------------------------------|---------------------------------------------------------------------|---------------|
| AB13 | PC-9800 series,                | Japanese Windows                                                    | 3.5" 2HD FD   |
| BB13 | IBM PC/AT and compatibles      | English Windows                                                     |               |
| AB17 |                                | Japanese Windows                                                    | CD-ROM        |
| BB17 |                                | English Windows                                                     |               |
| 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××××DF789862

μS<u>××××</u>CC78K0S-L

| <br>×××× | Host Machine              | OS                  | Supply Medium |
|----------|---------------------------|---------------------|---------------|
| AB13     | PC-9800 series,           | Japanese Windows    | 3.5" 2HD FD   |
| BB13     | IBM PC/AT and compatibles | English Windows     |               |
| 3P16     | HP9000 series 700         | HP-UX (Rel.10.10)   | DAT           |
| 3K13     | SPARCstation              | SunOS (Rel.4.1.4),  | 3.5" 2HD FD   |
| 3K15     |                           | Solaris (Rel.2.5.1) | 1/4" CGMT     |

#### A.3 Control Software

| Project manager | Control software provided for an efficient user program development in the Windows environment. The project manager allows a series of tasks required for user program development to be performed, including starting the editor, building, and starting the debugger. |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <caution><br/>The project manager is included in the assembler package (RA78K0S).<br/>It cannot be used in an environment other than Windows.</caution>                                                                                                                 |

#### A.4 EEPROM (Program Memory) Writing Tools

| Flashpro III<br>(part number: FL-PR3, PG-FP3)<br>Flashpro IV<br>(part number: FL-PR4, PG-FP4)<br>Flash programmer | Flash programmer dedicated to microcontrollers incorporating flash memory (EEPROM) |
|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| FA-30MC<br>Flash memory (EEPROM) writing<br>adapter                                                               | Flash memory (EEPROM) writing adapter. Used connected to Flashpro III/Flashpro IV. |

Remark FL-PR3, FL-PR4, and FA-30MC are products of Naito Densei Machida Mfg. Co., Ltd. For further information, contact: Naito Densei Machida Mfg. Co., Ltd. (+81-45-475-4191)

#### A.5 Debugging Tools

#### A.5.1 Hardware

| IE-78K0S-NS<br>In-circuit emulator   |                                                | In-circuit emulator for debugging hardware and software of application system using 78K/0S Series. Supports integrated debugger (ID78K0S-NS). Used in combination with power supply unit, emulation probe, and interface adapter for connecting the host machine. |
|--------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IE-78K0S-NS-A<br>In-circuit emulator |                                                | In-circuit emulator with expanded functions of IE-78K0S-NS. The debugging function is enhanced by the addition of a coverage function and the tracer function and timer function are also enhanced.                                                               |
|                                      | 0-MC-PS-B<br>upply unit                        | Adapter for supplying power from 100 to 240 VAC outlet.                                                                                                                                                                                                           |
|                                      | 0-98-IF-C<br>e adapter                         | Adapter required when using a PC-9800 series (except notebook type) as the host machine of IE-78K0S-NS (C bus supported).                                                                                                                                         |
|                                      | 0-CD-IF-A<br>interface                         | PC card and interface cable required when using a notebook type PC as the host machine of IE-78K0S-NS (PCMCIA socket supported).                                                                                                                                  |
|                                      | 0-PC-IF-C<br>e adapter                         | Adapter required when using IBM PC/AT and compatibles as the host machine of IE-78K0S-<br>NS (ISA bus supported).                                                                                                                                                 |
|                                      | 0-PCI-IF-A<br>e adapter                        | Adapter required when using a personal computer incorporating the PCI bus as the host machine of IE-78K0S-NS.                                                                                                                                                     |
| IE-789862-NS-EM1<br>Emulation board  |                                                | Emulation board for emulating the peripheral hardware inherent to the device.<br>Used in combination with in-circuit emulator.                                                                                                                                    |
| NP-30MC<br>Emulation probe           |                                                | Probe for connecting in-circuit emulator and target system.<br>Used in combination with NSPACK30BK and YSPACK30BK.                                                                                                                                                |
|                                      | NSPACK30BK<br>YSPACK30BK<br>Conversion adapter | Conversion adapter for connecting target system board for mounting 30-pin plastic SSOP and NP-30MC.                                                                                                                                                               |

Remarks 1. NP-30MC is a product of Naito Densei Machida Mfg. Co., Ltd.

For further information, contact: Naito Densei Machida Mfg. Co., Ltd. (+81-45-475-4191)

2. NSPACK30BK and YSPACK30BK are products of TOKYO ELETECH CORPORATION.

For further information, contact: Daimaru Kogyo, Ltd.

Tokyo Electronics Department (+81-3-3820-7112)

Osaka Electronics Department (+81-6-6244-6672)

#### A.5.2 Software

| ID78K0S-NS                    | Control program for debugging the 78K/0S Series.                                               |
|-------------------------------|------------------------------------------------------------------------------------------------|
| Integrated debugger           | This program provides a graphical user interface. It runs on Windows, and has visual designs   |
| (Supports in-circuit emulator | and operability that comply with these operating systems. In addition, it has a powerful debug |
| IE-78K0S-NS,                  | function that supports C language. Therefore, trace results can be displayed at a C language   |
| IE-78K0S-NS-A)                | level by the window integration function that links source program, disassembled display, and  |
|                               | memory display, to the trace result. This software also allows users to add other function     |
|                               | extension modules such as task debugger and system performance analyzer to improve the         |
|                               | debug efficiency for programs using a real-time operating system.                              |
|                               | Used in combination with a device file (DF789862) (sold separately).                           |
|                               | Part number: µSxxxxID78K0S-NS                                                                  |

**Remark** ×××× in the part number differs depending on the host machines and operating systems to be used.

| <br>×××× | Host Machine              | OS               | Supply Medium |
|----------|---------------------------|------------------|---------------|
| AB13     | IBM PC/AT and compatibles | Japanese Windows | 3.5" 2HD FD   |
| BB13     |                           | English Windows  |               |
| AB17     |                           | Japanese Windows | CD-ROM        |
| BB17     |                           | English Windows  |               |

μS<u>××××</u>ID78K0S-NS

#### A.6 Notes on Target System Design

The following show the conditions when connecting the emulation probe to the conversion adapter. Follow the configuration below and consider the shape of parts to be mounted on the target system when designing a system.



Figure A-2. Distance Between In-Circuit Emulator and Conversion Adapter

Remarks 1. The NP-30MC is a product of Naito Densei Machida Mfg. Co., Ltd.

2. The YSPACK30BK and NSPACK30BK are products of TOKYO ELETECH CORPORATION.



Figure A-3. Connection Condition of Target System

- Remarks 1. NP-30MC is a product of Naito Densei Machida Mfg. Co., Ltd.
  - **2.** YSPACK30BK, NSPACK30BK, and YQGUIDE are products of TOKYO ELETECH CORPORATION.

#### APPENDIX B REGISTER INDEX

### B.1 Register Name Index (in Alphabetical Order)

| 8-bit timer compare register 5 (CR5)                           |    |
|----------------------------------------------------------------|----|
| 8-bit timer compare register 80 (CR80)                         |    |
| 8-bit timer counter 5 (TM5)                                    |    |
| 8-bit timer counter 80 (TM80)                                  |    |
| 8-bit timer mode control register 5 (TMC5)                     |    |
| 8-bit timer mode control register 80 (TMC80)                   | 64 |
| 16-bit compare register D (CMD)                                |    |
| 16-bit timer capture/compare register 00 (CR00)                |    |
| 16-bit timer capture/compare register 01 (CR01)                |    |
| 16-bit timer counter 0 (TM0)                                   |    |
| 16-bit timer counter D (TMD)                                   |    |
| 16-bit timer mode control register 0 (TMC0)                    | 94 |
| 16-bit timer mode control register D (TMCD)                    |    |
| 16-bit timer output control register 0 (TOC0)                  |    |
| [A]                                                            |    |
| Asynchronous serial interface mode register 2 (ASIM2)          |    |
| Asynchronous serial interface status register 2 (ASIS2)        |    |
| [B]                                                            |    |
| Baud rate generator control register 2 (BRGC2)                 |    |
| Bit sequential buffer 1 data registers L, H (BSFRL10, BSFRH10) |    |
| Bit sequential buffer 1 output control register (BSF1C)        |    |
| [C]                                                            |    |
| Capture/compare control register 0 (CRC0)                      | 96 |
| [E]                                                            |    |
| EEPROM write control register 10 (EEWC10)                      | 61 |
| External interrupt mode register 0 (INTM0)                     |    |
| [1]                                                            |    |
| Interrupt mask flag registers 0, 1 (MK0, MK1)                  |    |
| Interrupt request flag registers 0, 1 (IF0, IF1)               |    |
| [K]                                                            |    |
| Key return edge detection register (EDG)                       |    |
| [L]                                                            |    |
| Low-voltage detection level selection register (LVIS)          |    |
| Low-voltage detection register (LVIF)                          |    |

### [0]

| Oscillation stabilization time selection register (OSTS) |
|----------------------------------------------------------|
|----------------------------------------------------------|

### [P]

| Port 0 (P0)                                             | 70           |
|---------------------------------------------------------|--------------|
| Port 1 (P1)                                             | 71           |
| Port 0 (P0)<br>Port 1 (P1)<br>Port 2 (P2)               | 72           |
| Port 3 (P3)                                             |              |
| Port 4 (P4)                                             |              |
| Port 7 (P7)                                             |              |
| Port mode register 0 (PM0)                              |              |
| Port mode register 1 (PM1)                              | 80           |
| Port mode register 2 (PM2)                              |              |
| Port mode register 3 (PM3)                              | 80, 163, 174 |
| Power-on-clear register (POCF)                          |              |
| Prescaler mode register 0 (PRM0)                        |              |
| Processor clock control register (PCC)                  |              |
| Pull-up resistor option registers 0 to 3 (PUB0 to PUB3) | 81           |
| [R]                                                     |              |
| Receive buffer register 2 (RXB2)                        |              |

## [S]

#### [T]

| Timer clock select register 5 (TCL5) | .128 |
|--------------------------------------|------|
| Transmit shift register 2 (TXS2)     | .148 |

### [W]

| Watchdog timer clock select register (WDCS) | 140 |
|---------------------------------------------|-----|
| Watchdog timer mode register (WDTM)         | 141 |

### **B.2 Register Symbol Index (in Alphabetical Order)**

### [A]

| ASIM2: Asynchronous serial interface mode register 2   | 150, | 156, | 158, | 172 |
|--------------------------------------------------------|------|------|------|-----|
| ASIS2: Asynchronous serial interface status register 2 |      |      | 152, | 159 |

### [B]

| BRGC2: Baud rate generator control register 2                 | 153, 160, 173 |
|---------------------------------------------------------------|---------------|
| BSF1C: Bit sequential buffer 1 output control register        | 187           |
| BSFRL10, BSFRH10: Bit sequential buffer 1 data registers L, H | 186           |

### [C]

| CMD: 16-bit compare register D                 | 120               |
|------------------------------------------------|-------------------|
| CR00: 16-bit timer capture/compare register 00 | 92                |
| CR01: 16-bit timer capture/compare register 01 | 93                |
| CR5: 8-bit timer compare register 5            | 127               |
| CR80: 8-bit timer compare register 80          | 63                |
| CRC0: Capture/compare control register 0       | 96                |
| CSIM2: Serial operating mode register 214      | 49, 156, 157, 171 |

### [E]

| EDG: Key return edge detection register  | .193 |
|------------------------------------------|------|
| EEWC10: EEPROM write control register 10 | 61   |

### [I]

| IF0, IF1: Interrupt request flag registers 0, 1 | 198 |
|-------------------------------------------------|-----|
| INTM0: External interrupt mode register 0       | 200 |

### [L]

| LVIF: Low-voltage detection register                 | 180 |
|------------------------------------------------------|-----|
| LVIS: Low-voltage detection level selection register | 180 |

#### [M]

### [0]

### [P]

| P0: Port 0                            | 70 |
|---------------------------------------|----|
| P1: Port 1                            | 71 |
| P2: Port 2                            |    |
| P3: Port 3                            |    |
| P4: Port 4                            |    |
| P7: Port 7                            |    |
| PCC: Processor clock control register |    |
| PM0: Port mode register 0             | 80 |
| PM1: Port mode register 1             |    |

| 80, 99, 130, 187 |
|------------------|
|                  |
| 179              |
|                  |
| 81               |
|                  |

### [R]

| RXB2: Receive buffer register 2 | .148 |
|---------------------------------|------|
| RXS2: Receive shift register 2  | .148 |

### [T]

| TCL5: Timer clock select register 5          | 128 |
|----------------------------------------------|-----|
| TM0: 16-bit timer counter 0                  | 92  |
| TM5: 8-bit timer counter 5                   | 127 |
| TM80: 8-bit timer counter 80                 | 63  |
| TMC0: 16-bit timer mode control register 0   | 94  |
| TMC5: 8-bit timer mode control register 5    | 129 |
| TMC80: 8-bit timer mode control register 80  | 64  |
| TMCD: 16-bit timer mode control register D   | 122 |
| TMD: 16-bit timer counter D                  | 119 |
| TOC0: 16-bit timer output control register 0 | 97  |
| TXS2: Transmit shift register 2              | 148 |

### [W]

| WDCS: Watchdog timer clock select register | .140 |
|--------------------------------------------|------|
| WDTM: Watchdog timer mode register         | .141 |

#### APPENDIX C REVISION HISTORY

A history of the revisions up to this edition is shown below. "Applied to:" indicates the chapters to which the revision was applied.

| Edition | Contents                                                                                                                         | Applied to:                                      |
|---------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| 2nd     | Update of 1.5 78K/0S Series Lineup                                                                                               | CHAPTER 1 GENERAL                                |
|         | Modification of description in Table 2-1 Types of Pin I/O Circuits and Recommended Connection of Unused Pins                     | CHAPTER 2 PIN FUNCTIONS                          |
|         | Modification of Figure 2-1 Pin I/O Circuits                                                                                      |                                                  |
|         | Addition of description to 4.5 Notes for EEPROM Writing                                                                          | CHAPTER 4 EEPROM (DATA<br>MEMORY)                |
|         | Modification of description in Figure 9-2 Format of Timer Clock Select<br>Register 5 (TCL5)                                      | CHAPTER 9 8-BIT TIMER/EVENT<br>COUNTER 5         |
|         | Correction of description in Figure 12-5 Format of Low-Voltage<br>Detection Level Selection Register                             | CHAPTER 12 POWER-ON-CLEAR<br>CIRCUITS            |
|         | Addition of Caution to Figure 15-2 Format of Interrupt Request Flag<br>Register                                                  | CHAPTER 15 INTERRUPT<br>FUNCTIONS                |
|         | Modification and addition of description in <b>18.1 EEPROM (Program Memory)</b>                                                  | CHAPTER 18 μPD78E9862                            |
|         | Modification and addition of description                                                                                         | CHAPTER 21 ELECTRICAL<br>SPECIFICATIONS (TARGET) |
|         | Addition of description to A.4 EEPROM (Program Memory) Writing<br>Tools                                                          | APPENDIX A DEVELOPMENT<br>TOOLS                  |
|         | Addition of chapter                                                                                                              | APPENDIX C REVISION HISTORY                      |
| 3rd     | <ul> <li>μPD789862 Under development → Developed</li> <li>μPD78E9862 has ES version (for development evaluation) only</li> </ul> | Throughout                                       |
|         | Update of 1.5 78K/0S Series Lineup                                                                                               | CHAPTER 1 GENERAL                                |
|         | <ul> <li>Modification of description of operating ambient temperature in</li> <li>1.7 Overview of Functions</li> </ul>           |                                                  |
|         | • Modification of description of VPP pin in 2.1 (2) Non-port pins                                                                | CHAPTER 2 PIN FUNCTIONS                          |
|         | • Modification of description in 2.2.13 VPP (µPD78E9862 only)                                                                    |                                                  |
|         | • Modification of description of VPP pin in Table 2-1 Types of Pin<br>I/O Circuits and Recommended Connection of Unused Pins     |                                                  |
|         | Correction of [Description example] in 3.4.4 Register addressing                                                                 | CHAPTER 3 CPU<br>ARCHITECTURE                    |

| Edition                                                                             | Contents                                                                                                                                                           | Applied to:                               |
|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| 3rd                                                                                 | Addition of description in Table 7-1 Configuration of 16-Bit<br>Timer/Event Counter 0                                                                              | CHAPTER 7 16-BIT TIMER/EVENT<br>COUNTER 0 |
| Counter 0<br>• Correction of Caut<br>00 (CR00)<br>• Correction of Caut<br>01 (CR01) | Correction of Figure 7-1 Block Diagram of 16-Bit Timer/Event     Counter 0                                                                                         |                                           |
|                                                                                     | • Correction of Caution in 7.2 (2) 16-bit timer capture/compare register 00 (CR00)                                                                                 |                                           |
|                                                                                     | • Correction of Caution in 7.2 (3) 16-bit timer capture/compare register 01 (CR01)                                                                                 |                                           |
|                                                                                     | Addition of description in 7.3 Registers to Control 16-Bit Timer/Event     Counter 0                                                                               |                                           |
|                                                                                     | Correction of Caution in Figure 7-2 Format of 16-Bit Timer Mode     Control Register 0 (TMC0)                                                                      |                                           |
|                                                                                     | Addition of Caution in Figure 7-5 Format of Prescaler Mode Register 0 (PRM0)                                                                                       |                                           |
|                                                                                     | Addition of description in 7.3 (5) Port mode register 2 (PM2)                                                                                                      |                                           |
|                                                                                     | Addition of Note in Figure 7-8 Interval Timer Configuration Diagram                                                                                                |                                           |
|                                                                                     | Correction of Caution in Figure 7-10 Control Register Settings for<br>PPG Output Operation                                                                         |                                           |
|                                                                                     | Addition of Figure 7-11 PPG Output Configuration Diagram                                                                                                           |                                           |
|                                                                                     | Addition of Figure 7-12 PPG Output Operation Timing                                                                                                                |                                           |
| Operatio                                                                            | • Addition of Note in Figure 7-15 Timing of Pulse Width Measurement<br>Operation by Free-Running Counter and One Capture Register (with<br>Both Edges Specified)   |                                           |
|                                                                                     | Addition of Note in Figure 7-18 Timing of Pulse Width Measurement     Operation by Free-Running Counter (with Both Edges Specified)                                |                                           |
|                                                                                     | • Addition of Note in Figure 7-20 Timing of Pulse Width Measurement<br>Operation by Free-Running Counter and Two Capture Registers<br>(with Rising Edge Specified) |                                           |
| Diagram<br>• Correction of desc<br>timing<br>• Correction of Figure<br>5            | Correction of Figure 7-24 External Event Counter Configuration Diagram                                                                                             |                                           |
|                                                                                     | Correction of description in 7.5 (4) Capture register data retention timing                                                                                        |                                           |
|                                                                                     | Correction of Figure 7-30 Capture Register Data Retention Timing                                                                                                   |                                           |
|                                                                                     | Correction of Figure 9-1 Block Diagram of 8-Bit Timer/Event Counter 5                                                                                              | CHAPTER 9 8-BIT TIMER/EVENT<br>COUNTER 5  |
|                                                                                     | Addition of description in Table 9-1 Configuration of 8-Bit Timer/Event     Counter 5                                                                              |                                           |
|                                                                                     | Addition of description in 9.2 (2) 8-bit timer compare register 5 (CR5)                                                                                            |                                           |
|                                                                                     | Addition of description in 9.3 Registers to Control 8-Bit Timer/Event     Counter 5                                                                                |                                           |
|                                                                                     | Modification of Figure 9-2 Format of Timer Clock Select Register 5     (TCL5)                                                                                      |                                           |
|                                                                                     | Addition of description in 9.3 (3) Port mode register 2 (PM2)                                                                                                      |                                           |
|                                                                                     | Correction of Figure 9-5 Interval Timer Operation Timing                                                                                                           |                                           |
|                                                                                     | Addition of Remark in Figure 9-8 PWM Output Operation Timing                                                                                                       |                                           |

| Edition | Contents                                                                                                                                                             | Applied to:                                           |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| 3rd     | Addition of description in Table 11-1 Configuration of Serial Interface 2                                                                                            | CHAPTER 11 SERIAL                                     |
|         | Addition of description in 11.3 Control Registers of Serial Interface 2                                                                                              | INTERFACE 2                                           |
|         | • Addition of 11.4.2 (1) (e) Port mode register 3 (PM3)                                                                                                              |                                                       |
|         | Addition of 11.4.3 (1) (d) Port mode register 3 (PM3)                                                                                                                |                                                       |
|         | Correction of Figure 12-1 Block Diagram of Power-on-Clear Circuit     Correction of Figure 12-2 Block Diagram of Low-Voltage Detection     Circuit                   | CHAPTER 12 POWER-ON-CLEAR<br>CIRCUITS                 |
|         | Modification of description                                                                                                                                          | CHAPTER 18 µPD78E9862                                 |
|         | <ul> <li>Addition of Recommended Oscillator Constant</li> <li>Modification of high-level input voltage and power supply current in DC<br/>Characteristics</li> </ul> | CHAPTER 21 ELECTRICAL<br>SPECIFICATIONS (µPD789862)   |
|         | Modification of (4) Power supply startup in AC Characteristics                                                                                                       |                                                       |
|         | Modification of operating ambient temperature in Absolute Maximum     Ratings                                                                                        | CHAPTER 22 ELECTRICAL<br>SPECIFICATIONS (PRELIMINARY) |
|         | Addition of Recommended Oscillator Constant                                                                                                                          | ( <i>µ</i> PD78E9862)                                 |
|         | Modification of high-level input voltage in DC Characteristics                                                                                                       |                                                       |
|         | Modification of (4) Power supply startup in AC Characteristics                                                                                                       |                                                       |
|         | Addition of chapter                                                                                                                                                  | CHAPTER 24 RECOMMENDED<br>SOLDERING CONDITIONS        |
|         | Modification of description in A.5.1 Hardware     Addition of A.6 Notes on Target System Design                                                                      | APPENDIX A DEVELOPMENT<br>TOOLS                       |
| 4th     | Modification of Note in 1.3 Ordering Information     Revision of 1.5 78K/0S Series Lineup                                                                            | CHAPTER 1 GENERAL                                     |
|         | Modification of Table 4-1 EEPROM Write Time     Modification of program example of (3) in 4.5 Notes for EEPROM     Writing                                           | CHAPTER 4 EEPROM<br>(DATA MEMORY)                     |
|         | Addition of 7.5 (2) Prohibition of compare register change during timer count operation                                                                              | CHAPTER 7 16-BIT TIMER/EVENT<br>COUNTER 0             |
|         | Addition of 11.3 (4) (c) Generation of serial clock from system clock<br>in 3-wire serial I/O mode                                                                   | CHAPTER 11 SERIAL<br>INTERFACE 2                      |
|         | Modification of description and addition of Note in 12.4.1 Power-on-<br>clear (POC) circuit operation                                                                | CHAPTER 12 POWER-ON-<br>CLEAR CIRCUITS                |
|         | Addition of Caution to 12.4.2 Operation of low-voltage detector (LVI)                                                                                                |                                                       |
|         | Modification of Figure 12-9 LVI Circuit Operation Timing     Addition of 13.3 (2) Port mode register 2 (PM2)                                                         | CHAPTER 13 BIT SEQUENTIAL                             |
|         | <ul> <li>Modification of Note 1 in Table 18-1 Difference Between<br/>µPD78E9862 and Mask ROM Version</li> </ul>                                                      | BUFFER<br>CHAPTER 18 μPD78E9862                       |
|         | Modification of Table 18-2 Communication Mode List                                                                                                                   |                                                       |
|         | Addition of Caution     Modification of Note 2 in AC Characteristics (3) EEPROM                                                                                      | CHAPTER 22 ELECTRICAL<br>SPECIFICATIONS (µPD78E9862)  |
|         | Change of Table 24-1 Surface Mounting Type Soldering Conditions                                                                                                      | CHAPTER 24 RECOMMENDED<br>SOLERING CONDITIONS         |