## 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$ PD789026 Subseries

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

μPD789022 μPD789024 μPD789025 μPD789026 μPD78F9026A

Document No. U11919EJ5V0UD00 (5th edition) Date Published May 2005 NS CP(K)

© NEC Electronics Corporation 1986, 2003 Printed in Japan

2

[MEMO]

### **1** VOLTAGE APPLICATION WAVEFORM AT INPUT PIN

Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between V<sub>IL</sub> (MAX) and V<sub>IH</sub> (MIN) due to noise, etc., the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between V<sub>IL</sub> (MAX) and V<sub>IH</sub> (MIN).

## 2 HANDLING OF UNUSED INPUT PINS

Unconnected CMOS device inputs can be cause of malfunction. If an input pin is unconnected, it is possible that an internal input level may be generated due to noise, etc., causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using pull-up or pull-down circuitry. Each unused pin should be connected to V<sub>DD</sub> or GND via a resistor if there is a possibility that it will be an output pin. All handling related to unused pins must be judged separately for each device and according to related specifications governing the device.

## **③** PRECAUTION AGAINST ESD

A 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 when it has occurred. Environmental control must be adequate. When it is dry, a humidifier should be used. It is recommended to avoid using insulators that easily build up 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 benches and floors should be grounded. The operator should be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with mounted semiconductor devices.

## **④** STATUS BEFORE INITIALIZATION

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

#### 5 POWER ON/OFF SEQUENCE

In the case of a device that uses different power supplies for the internal operation and external interface, as a rule, switch on the external power supply after switching on the internal power supply. When switching the power supply off, as a rule, switch off the external power supply and then the internal power supply. Use of the reverse power on/off sequences may result in the application of an overvoltage to the internal elements of the device, causing malfunction and degradation of internal elements due to the passage of an abnormal current.

The correct power on/off sequence must be judged separately for each device and according to related specifications governing the device.

#### **(6)** INPUT OF SIGNAL DURING POWER OFF STATE

Do not input signals or an I/O pull-up power supply while the device is not powered. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Input of signals during the power off state must be judged separately for each device and according to related specifications governing the device.

EEPROM and FIP 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, 2005. 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).

M8E 02.11-1

## **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.)<br>Santa Clara, California<br>Tel: 408-588-6000<br>800-366-9782 | NEC Electronics (Europe) GmbH<br>Duesseldorf, Germany<br>Tel: 0211-65030 | NEC Electronics Hong Kong Ltd.<br>Hong Kong<br>Tel: 2886-9318   |
|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------|
|                                                                                                      | <ul> <li>Sucursal en España</li> </ul>                                   | NEC Electronics Hong Kong Ltd.                                  |
|                                                                                                      | Madrid, Spain                                                            | Seoul Branch                                                    |
|                                                                                                      | Tel: 091-504 27 87                                                       | Seoul, Korea                                                    |
|                                                                                                      | Succursale Française                                                     | Tel: 02-558-3737                                                |
|                                                                                                      | Vélizy-Villacoublay, France<br>Tel: 01-30-675800                         | NEC Electronics Shanghai Ltd.<br>Shanghai, P.R. China           |
|                                                                                                      | Filiale Italiana                                                         | Tel: 021-5888-5400                                              |
|                                                                                                      | Milano, Italy<br>Tel: 02-66 75 41                                        | <b>NEC Electronics Taiwan Ltd.</b><br>Taipei, Taiwan            |
|                                                                                                      | <ul> <li>Branch The Netherlands</li> </ul>                               | Tel: 02-2719-2377                                               |
|                                                                                                      | Eindhoven, The Netherlands<br>Tel: 040-2445845                           | NEC Electronics Singapore Pte. Ltd.<br>Novena Square, Singapore |
|                                                                                                      | Tyskland Filial     Taeby, Sweden                                        | Tel: 6253-8311                                                  |
|                                                                                                      | Tel: 08-63 80 820                                                        |                                                                 |
|                                                                                                      | United Kingdom Branch                                                    |                                                                 |
|                                                                                                      | Milton Keynes, UK                                                        |                                                                 |
|                                                                                                      | Tel: 01908-691-133                                                       |                                                                 |
|                                                                                                      |                                                                          |                                                                 |

## INTRODUCTION

| Readers                 | the µPD789026 Subseries to design programs.                                                                                                                                                                                                                                                                                                                                                                            | ters who wish to understand the functions of<br>and develop its application systems and<br>Subseries, which consists of the $\mu$ PD789022,<br>and $\mu$ PD78F9026A.                                                                                                                                                      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Purpose                 | This manual is designed to deepen your the following organization.                                                                                                                                                                                                                                                                                                                                                     | r understanding of the functions described in                                                                                                                                                                                                                                                                             |
| Organization            | Two manuals are available for the ,<br>Instruction Manual (common to the 78K/α<br>μPD789026 Subseries<br>User's Manual<br>• Pin functions<br>• Internal block functions<br>• Interrupts<br>• Other internal peripheral functions<br>• Electrical specifications                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                           |
| How to Read This Manual | <ul> <li>engineering, logic circuits, and microcont</li> <li>To understand the overall functions of</li> <li>→ Read this manual in the order of the The mark ★ shows major revised p</li> <li>How to read register formats</li> <li>→ The name of a bit whose number assembler and is defined as an sfr compiler.</li> <li>To learn the detailed functions of a reg</li> <li>→ See APPENDIX C REGISTER INIT</li> </ul> | the μPD789026 Subseries<br>e <b>CONTENTS</b> .<br>points.<br>er is enclosed with < > is reserved in the<br>variable by the #pragma sfr directive in the C<br>ister whose register name is known<br><b>DEX</b> .<br>ions of the 78K/0S Series<br><b>ions User's Manual (U11047E)</b> separately<br>the μPD789026 Subseries |

| Conventions | Data significance:<br>Active low representation:<br>Note:<br>Caution:<br>Remark:<br>Numerical representation: | Higher digits on the left and lower digits on the right<br>xxx (overscore over pin or signal name)<br>Footnote for item marked with <b>Note</b> in the text<br>Information requiring particular attention<br>Supplementary information<br>Binary xxxx or xxxxB<br>Decimal xxxx<br>Hexadecimal xxxxH |
|-------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                                                                                               |                                                                                                                                                                                                                                                                                                     |

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

## **Documents Related to Devices**

| Document Name                            | Document No. |
|------------------------------------------|--------------|
| $\mu$ PD789026 Subseries User's Manual   | This manual  |
| 78K/0S Series Instructions User's Manual | U11047E      |

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

| Document Name                            |                                                 | Document No. |
|------------------------------------------|-------------------------------------------------|--------------|
| RA78K0S Assembler Package                | Operation                                       | U17391E      |
|                                          | Language                                        | U17390E      |
|                                          | Structured Assembly Language                    | U17389E      |
| CC78K0S C Compiler                       | Operation                                       | U16654E      |
|                                          | Language                                        | U16655E      |
| SM+ System Simulator                     | Operation                                       | U17246E      |
|                                          | User Open Interface                             | U17247E      |
| SM78K Series Ver. 2.52 System Simulator  | Operation                                       | U16768E      |
|                                          | External Part User Open Interface Specification | U15802E      |
| ID78K0S-NS Ver. 2.52 Integrated Debugger | Operation                                       | U16584E      |
| PM plus Ver.5.20                         |                                                 | U16934E      |

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

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

## 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" webpage (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

| CHAPTE | ER 1 GENERAL                                               | 20 |
|--------|------------------------------------------------------------|----|
| 1.1    | Features                                                   | 20 |
| 1.2    | Applications                                               | 20 |
| 1.3    | Ordering Information                                       | 21 |
| 1.4    | Pin Configuration (Top View)                               | 22 |
| 1.5    | 78K/0S Series Lineup                                       | 23 |
| 1.6    | Block Diagram                                              | 27 |
| 1.7    | Overview of Functions                                      | 28 |
| СНАРТЕ | ER 2 PIN FUNCTIONS                                         | 29 |
| 2.1    | List of Pin Functions                                      | 20 |
| 2.1    | Description of Pin Functions                               |    |
| 2.2    | 2.2.1 P00 to P07 (Port 0)                                  |    |
|        | 2.2.2 P10 to P17 (Port 1)                                  |    |
|        | 2.2.2 P10 to P17 (Port 1)<br>2.2.3 P20 to P22 (Port 2)     |    |
|        | 2.2.3 P20 to P22 (Port 2)                                  |    |
|        | 2.2.5 P40 to P47 (Port 4)                                  |    |
|        | 2.2.6 P50 to P53 (Port 5)                                  |    |
|        | 2.2.7 RESET                                                |    |
|        | 2.2.8 X1, X2                                               |    |
|        | 2.2.9 NC                                                   |    |
|        | 2.2.10 VDD                                                 |    |
|        | 2.2.11 VSS                                                 |    |
|        | 2.2.12 VPP (μPD78F9026A only)                              |    |
|        | 2.2.13 IC (mask ROM version only)                          |    |
| 2.3    | Pin I/O Circuits and Recommended Connection of Unused Pins |    |
|        |                                                            |    |
| CHAPTE | ER 3 CPU ARCHITECTURE                                      | 37 |
| 3.1    | Memory Space                                               | 37 |
|        | 3.1.1 Internal program memory space                        | 42 |
|        | 3.1.2 Internal data memory (internal high-speed RAM) space | 43 |
|        | 3.1.3 Special function register (SFR) area                 | 43 |
|        | 3.1.4 Data memory addressing                               | 44 |
| 3.2    | Processor Registers                                        | 49 |
|        | 3.2.1 Control registers                                    | 49 |
|        | 3.2.2 General-purpose registers                            | 52 |
|        | 3.2.3 Special function registers (SFR)                     | 53 |
| 3.3    | Instruction Address Addressing                             | 56 |
|        | 3.3.1 Relative addressing                                  |    |
|        | 3.3.2 Immediate addressing                                 | 57 |
|        | 3.3.3 Table indirect addressing                            | 58 |
|        | 3.3.4 Register addressing                                  |    |
| 3.4    | Operand Address Addressing                                 | 59 |

|        | 3.4.1                                                                     | Direct addressing                                                                                                          |                                        |
|--------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
|        | 3.4.2                                                                     | Short direct addressing                                                                                                    | 60                                     |
|        | 3.4.3                                                                     | Special function register (SFR) addressing                                                                                 | 61                                     |
|        | 3.4.4                                                                     | Register addressing                                                                                                        | 62                                     |
|        | 3.4.5                                                                     | Register indirect addressing                                                                                               | 63                                     |
|        | 3.4.6                                                                     | Based addressing                                                                                                           | 64                                     |
|        | 3.4.7                                                                     | Stack addressing                                                                                                           | 64                                     |
|        |                                                                           | ORT FUNCTIONS                                                                                                              | 65                                     |
| CHAPTI | ER 4 P                                                                    |                                                                                                                            | 05                                     |
| 4.1    | Functio                                                                   | ons of Ports                                                                                                               | 65                                     |
|        | Functio                                                                   | ons of Ports                                                                                                               | 65                                     |
| 4.1    | Functio                                                                   | ons of Ports<br>onfiguration<br>Port 0                                                                                     | 65<br>67<br>67                         |
| 4.1    | Functio<br>Port Co                                                        | ons of Ports<br>onfiguration                                                                                               | 65<br>67<br>67                         |
| 4.1    | Functio<br>Port Co<br>4.2.1                                               | ons of Ports<br>onfiguration<br>Port 0<br>Port 1<br>Port 2                                                                 | 65<br>67<br>67<br>68<br>69             |
| 4.1    | Functio<br>Port Co<br>4.2.1<br>4.2.2                                      | ons of Ports<br>onfiguration<br>Port 0<br>Port 1<br>Port 2<br>Port 3                                                       | 65<br>67<br>67<br>68<br>69<br>72       |
| 4.1    | Functio<br>Port Co<br>4.2.1<br>4.2.2<br>4.2.3                             | Dens of Ports           Denfiguration           Port 0           Port 1           Port 2           Port 3           Port 4 | 65<br>67<br>68<br>68<br>69<br>72<br>73 |
| 4.1    | Function<br>Port Co<br>4.2.1<br>4.2.2<br>4.2.3<br>4.2.4<br>4.2.5<br>4.2.5 | ons of Ports<br>onfiguration<br>Port 0<br>Port 1<br>Port 2<br>Port 3                                                       | 65<br>67<br>68<br>69<br>72<br>73<br>74 |

|        | 5                                |                                                                                                                    |
|--------|----------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Operat | tion of Port Functions           | 79                                                                                                                 |
| 4.4.1  | Writing to I/O port              | 79                                                                                                                 |
| 4.4.2  | Reading from I/O port            | 79                                                                                                                 |
| 4.4.3  | Arithmetic operation of I/O port | 79                                                                                                                 |
|        | 4.4.1<br>4.4.2                   | Operation of Port Functions4.4.1Writing to I/O port4.4.2Reading from I/O port4.4.3Arithmetic operation of I/O port |

| СНАРТ | 'ER 5 ( | CLOCK GENERATOR                                                | 80 |
|-------|---------|----------------------------------------------------------------|----|
| 5.1   | Funct   | on of Clock Generator                                          | 80 |
| 5.2   | Config  | juration of Clock Generator                                    | 80 |
| 5.3   | Regist  | er Controlling Clock Generator                                 | 81 |
| 5.4   | Syster  | n Clock Oscillator                                             | 82 |
|       | 5.4.1   | System clock oscillator                                        | 82 |
|       | 5.4.2   | Examples of incorrect resonator connection                     | 83 |
|       | 5.4.3   | Divider circuit                                                | 84 |
| 5.5   |         |                                                                | 85 |
| 5.6   |         |                                                                |    |
|       | 5.6.1   | Time required for switching between system clock and CPU clock |    |
|       | 5.6.2   | Switching CPU clock                                            | 86 |

| CHAPT | ER 6 1                                | 16-BIT TIMER 20                 | 87 |
|-------|---------------------------------------|---------------------------------|----|
| 6.1   | Functi                                | ions of 16-Bit Timer 20         | 87 |
| 6.2   | Config                                | guration of 16-Bit Timer 20     |    |
| 6.3   | Registers Controlling 16-Bit Timer 20 |                                 |    |
| 6.4   | Operation of 16-Bit Timer 20          |                                 | 93 |
|       | 6.4.1                                 | Operation as timer interrupt    | 93 |
|       | 6.4.2                                 | Operation as timer output       |    |
|       | 6.4.3                                 | Capture operation               |    |
|       | 6.4.4                                 | 16-bit timer counter 20 readout | 97 |

| 6.5   | Notes on Using 16-Bit Timer 20                                  |     |
|-------|-----------------------------------------------------------------|-----|
|       | 6.5.1 Restrictions when rewriting 16-bit compare register 20    | 98  |
| СНАРТ | ER 7 8-BIT TIMER/EVENT COUNTER 00                               |     |
| 7.1   | Functions of 8-Bit Timer/Event Counter 00                       |     |
| 7.2   | Configuration of 8-Bit Timer/Event Counter 00                   |     |
| 7.3   | Registers Controlling 8-Bit Timer/Event Counter 00              |     |
| 7.4   | Operation of 8-Bit Timer/Event Counter 00                       | 104 |
|       | 7.4.1 Operation as interval timer                               |     |
|       | 7.4.2 Operation as external event counter                       |     |
|       | 7.4.3 Operation as square wave output                           | 107 |
| 7.5   | Notes on Using 8-Bit Timer/Event Counter 00                     | 109 |
| СНАРТ | ER 8 WATCHDOG TIMER                                             | 110 |
| 8.1   | Functions of Watchdog Timer                                     | 110 |
| 8.2   | Configuration of Watchdog Timer                                 |     |
| 8.3   | Registers Controlling Watchdog Timer                            |     |
| 8.4   | Operation of Watchdog Timer                                     |     |
|       | 8.4.1 Operation as watchdog timer                               |     |
|       | 8.4.2 Operation as interval timer                               | 115 |
| СНАРТ | ER 9 SERIAL INTERFACE 00                                        | 116 |
| 9.1   | Functions of Serial Interface 00                                | 116 |
| 9.2   | Configuration of Serial Interface 00                            | 116 |
| 9.3   | Registers Controlling Serial Interface 00                       |     |
| 9.4   | Operation of Serial Interface 00                                |     |
|       | 9.4.1 Operation stop mode                                       |     |
|       | 9.4.2 Asynchronous serial interface (UART) mode                 |     |
|       | 9.4.3 3-wire serial I/O mode                                    | 141 |
| СНАРТ | ER 10 INTERRUPT FUNCTIONS                                       | 145 |
| 10.1  | Interrupt Function Types                                        | 145 |
| 10.2  | Interrupt Sources and Configuration                             | 145 |
| 10.3  | Registers Controlling Interrupt Function                        | 148 |
| 10.4  | Interrupt Servicing Operation                                   | 154 |
|       | 10.4.1 Non-maskable interrupt request acknowledgement operation | 154 |
|       | 10.4.2 Maskable interrupt request acknowledgement operation     | 156 |
|       | 10.4.3 Nesting processing                                       | 158 |
|       | 10.4.4 Interrupt request hold                                   | 160 |
| СНАРТ | ER 11 STANDBY FUNCTION                                          | 161 |
| 11.1  | Standby Function and Configuration                              |     |
|       | 11.1.1 Standby function                                         |     |
|       |                                                                 |     |

|            | 11.1.2    | Standby function control register                         | 162 |
|------------|-----------|-----------------------------------------------------------|-----|
| 11.2       | Operation | on of Standby Function                                    | 163 |
|            | 11.2.1    | HALT mode                                                 | 163 |
|            | 11.2.2    | STOP mode                                                 | 166 |
|            |           |                                                           |     |
| СНАРТЕ     | R 12 R    |                                                           |     |
|            |           |                                                           |     |
| СНАРТЕ     | ER 13 μ   | PD78F9026A                                                | 172 |
| 13.1       | Flash M   | lemory Characteristics                                    |     |
|            | 13.1.1    | Programming environment                                   |     |
|            | 13.1.2    | Communication mode                                        | 174 |
|            | 13.1.3    | On-board pin processing                                   | 177 |
|            | 13.1.4    | Connection of adapter for flash writing                   | 180 |
|            |           |                                                           |     |
| CHAPTE     | ER 14 II  | NSTRUCTION SET                                            |     |
| 14.1       | Operation | on                                                        | 183 |
|            | 14.1.1    | Operand identifiers and writing methods                   | 183 |
|            | 14.1.2    | Description of "Operation" column                         | 184 |
|            | 14.1.3    | Description of "Flag" column                              | 184 |
| 14.2       | Operation | on List                                                   | 185 |
| 14.3       | Instruct  | ions Listed by Addressing Type                            | 190 |
|            |           |                                                           |     |
| CHAPTE     | ER 15 E   | LECTRICAL SPECIFICATIONS                                  | 193 |
|            |           |                                                           |     |
| CHAPTE     | ER 16 C   | CHARACTERISTICS CURVES (MASK ROM VERSION)                 | 205 |
|            |           |                                                           |     |
| СНАРТЕ     | ER 17 P   | ACKAGE DRAWING                                            | 206 |
| 0114 DT    |           |                                                           |     |
| CHAPIE     | -R 18 H   | RECOMMENDED SOLDERING CONDITIONS                          | 207 |
|            | ם ג צונ   | EVELOPMENT TOOLS                                          | 200 |
|            |           |                                                           |     |
| A.1        |           | e Package                                                 |     |
| A.2        | •         | ge Processing Software                                    |     |
| A.3        |           | Software                                                  |     |
| A.4        |           | lemory Writing Tools                                      |     |
| A.5<br>A.6 |           | jing Tools (Hardware)<br>jing Tools (Software)            |     |
| А.6<br>А.7 |           | ling Tools (Soπware)<br>sion Adapter (TGB-044SAP) Drawing |     |
| A./        | Convers   | Sion Adapter (IGD-0443AF) Drawing                         |     |
|            | )IX B N   | OTES ON TARGET SYSTEM DESIGN                              |     |
|            |           |                                                           |     |
| ADDENI     | DIX C R   | EGISTER INDEX                                             |     |

|   | C.1    | Register Name Index                   | 218 |
|---|--------|---------------------------------------|-----|
|   |        | Register Symbol Index                 |     |
|   | APPENI | DIX D REVISION HISTORY                | 222 |
| * | D.1    | Major Revisions in This Edition       | 222 |
| * | D.2    | Revision History of Previous Editions | 223 |

## LIST OF FIGURES (1/3)

| Figure No | . Title                                     | Page |
|-----------|---------------------------------------------|------|
| 2-1       | Pin I/O Circuits                            |      |
| 3-1       | Метогу Мар (µPD789022)                      |      |
| 3-2       | Метогу Мар (µPD789024)                      |      |
| 3-3       | Метогу Мар (µPD789025)                      |      |
| 3-4       | Метогу Мар (µPD789026)                      | 40   |
| 3-5       | Метогу Мар (µPD78F9026A)                    | 41   |
| 3-6       | Data Memory Addressing (µPD789022)          | 44   |
| 3-7       | Data Memory Addressing (µPD789024)          | 45   |
| 3-8       | Data Memory Addressing (µPD789025)          | 46   |
| 3-9       | Data Memory Addressing (µPD789026)          | 47   |
| 3-10      | Data Memory Addressing (µPD78F9026A)        |      |
| 3-11      | Program Counter Configuration               | 49   |
| 3-12      | Program Status Word Configuration           | 49   |
| 3-13      | Stack Pointer Configuration                 | 51   |
| 3-14      | Data to Be Saved to Stack Memory            | 51   |
| 3-15      | Data to Be Restored from Stack Memory       | 51   |
| 3-16      | General-Purpose Register Configuration      |      |
| 4-1       | Port Types                                  | 65   |
| 4-2       | Block Diagram of P00 to P07                 | 67   |
| 4-3       | Block Diagram of P10 to P17                 | 68   |
| 4-4       | Block Diagram of P20                        | 69   |
| 4-5       | Block Diagram of P21                        | 70   |
| 4-6       | Block Diagram of P22                        |      |
| 4-7       | Block Diagram of P30 to P32                 | 72   |
| 4-8       | Block Diagram of P40 to P47                 | 73   |
| 4-9       | Block Diagram of P50                        | 74   |
| 4-10      | Block Diagram of P51                        | 75   |
| 4-11      | Block Diagram of P52 and P53                |      |
| 4-12      | Format of Port Mode Register                |      |
| 4-13      | Format of Pull-Up Resistor Option Register  |      |
| 5-1       | Block Diagram of Clock Generator            |      |
| 5-2       | Format of Processor Clock Control Register  |      |
| 5-3       | External Circuit of System Clock Oscillator |      |
| 5-4       | Examples of Incorrect Resonator Connection  |      |
| 5-5       | Switching CPU Clock                         |      |
| 6-1       | Block Diagram of 16-Bit Timer 20            |      |

## LIST OF FIGURES (2/3)

| Figure No | . Title                                                                         | Page |
|-----------|---------------------------------------------------------------------------------|------|
| 6-2       | Format of 16-Bit Timer Mode Control Register 20                                 |      |
| 6-3       | Format of Port Mode Register 5                                                  |      |
| 6-4       | Settings of 16-Bit Timer Mode Control Register 20 for Timer Interrupt Operation |      |
| 6-5       | Timer Interrupt Operation Timing                                                |      |
| 6-6       | Settings of 16-Bit Timer Mode Control Register 20 for Timer Output Operation    |      |
| 6-7       | Timer Output Timing                                                             |      |
| 6-8       | Settings of 16-Bit Timer Mode Control Register 20 for Capture Operation         |      |
| 6-9       | Capture Operation Timing (Both Edges of CPT2 Pin Are Specified)                 |      |
| 6-10      | Readout Timing of 16-Bit Timer Counter 20                                       |      |
| 7-1       | Block Diagram of 8-Bit Timer/Event Counter 00                                   |      |
| 7-2       | Format of 8-Bit Timer Mode Control Register 00                                  |      |
| 7-3       | Format of Port Mode Register 5                                                  |      |
| 7-4       | Interval Timer Operation Timing                                                 |      |
| 7-5       | External Event Counter Operation Timing (with Rising Edge Specified)            |      |
| 7-6       | Square Wave Output Timing                                                       |      |
| 7-7       | Start Timing of 8-Bit Timer Counter 00                                          |      |
| 7-8       | One Pulse Count Operation Timing                                                |      |
| 8-1       | Block Diagram of Watchdog Timer                                                 | 111  |
| 8-2       | Format of Timer Clock Select Register 2                                         | 112  |
| 8-3       | Format of Watchdog Timer Mode Register                                          | 113  |
| 9-1       | Block Diagram of Serial Interface 00                                            | 117  |
| 9-2       | Block Diagram of Baud Rate Generator                                            | 118  |
| 9-3       | Format of Serial Operation Mode Register 00                                     |      |
| 9-4       | Format of Asynchronous Serial Interface Mode Register 00                        |      |
| 9-5       | Format of Asynchronous Serial Interface Status Register 00                      |      |
| 9-6       | Format of Baud Rate Generator Control Register 00                               |      |
| 9-7       | Format of Asynchronous Serial Interface Transmit/Receive Data                   |      |
| 9-8       | Asynchronous Serial Interface Transmission Completion Interrupt Timing          |      |
| 9-9       | Asynchronous Serial Interface Reception Completion Interrupt Timing             |      |
| 9-10      | Receive Error Timing                                                            |      |
| 9-11      | 3-Wire Serial I/O Mode Timing                                                   | 144  |
| 10-1      | Basic Configuration of Interrupt Function                                       | 147  |
| 10-2      | Format of Interrupt Request Flag Register                                       |      |
| 10-3      | Format of Interrupt Mask Flag Register                                          |      |
| 10-4      | Format of External Interrupt Mode Register 0                                    |      |
| 10-5      | Configuration of Program Status Word                                            |      |

## LIST OF FIGURES (3/3)

| Figure No. | Title                                                                                   | Page |
|------------|-----------------------------------------------------------------------------------------|------|
| 10-6       | Format of Key Return Mode Register 00                                                   |      |
| 10-7       | Block Diagram of Falling Edge Detector                                                  |      |
| 10-8       | Flowchart from Non-Maskable Interrupt Request Generation to Acknowledgement             |      |
| 10-9       | Non-Maskable Interrupt Request Acknowledgement Timing                                   |      |
| 10-10      | Acknowledgement of Non-Maskable Interrupt Request                                       |      |
| 10-11      | Interrupt Request Acknowledgement Processing Algorithm                                  |      |
| 10-12      | Interrupt Request Acknowledgement Timing (Example of MOV A, r)                          |      |
| 10-13      | Interrupt Request Acknowledgement Timing (When Interrupt Request Flag Is Set at Last Cl |      |
|            | Instruction Execution)                                                                  |      |
| 10-14      | Example of Nesting                                                                      | 159  |
| 11-1       | Format of Oscillation Stabilization Time Select Register                                |      |
| 11-2       | Releasing HALT Mode by Interrupt                                                        | 164  |
| 11-3       | Releasing HALT Mode by RESET Input                                                      | 165  |
| 11-4       | Releasing STOP Mode by Interrupt                                                        | 167  |
| 11-5       | Releasing STOP Mode by RESET Input                                                      | 168  |
| 12-1       | Block Diagram of Reset Function                                                         | 170  |
| 12-2       | Reset Timing by RESET Input                                                             | 170  |
| 12-3       | Reset Timing by Overflow in Watchdog Timer                                              | 170  |
| 12-4       | Reset Timing by RESET Input in STOP Mode                                                | 170  |
| 13-1       | Environment for Writing Program to Flash Memory                                         | 173  |
| 13-2       | Communication Mode Selection Format                                                     | 174  |
| 13-3       | Example of Connection with Dedicated Flash Programmer                                   | 175  |
| 13-4       | VPP Pin Connection Example                                                              | 177  |
| 13-5       | Signal Conflict (Input Pin of Serial Interface)                                         | 178  |
| 13-6       | Abnormal Operation of Other Device                                                      | 178  |
| 13-7       | Signal Conflict (RESET Pin)                                                             | 179  |
| 13-8       | Wiring Example for Flash Writing Adapter with 3-Wire Serial I/O                         |      |
| 13-9       | Wiring Example for Flash Writing Adapter with UART                                      | 181  |
| 13-10      | Wiring Example for Flash Writing Adapter with Pseudo 3-Wire (When P0 Is Used)           |      |
| A-1        | Development Tools                                                                       | 210  |
| A-2        | TGB-044SAP Package Drawing (Reference)                                                  | 215  |
| B-1        | Distance Between In-Circuit Emulator and Conversion Adapter                             |      |
| B-2        | Connection Condition of Target System (NP-H44GB-TQ)                                     | 217  |

## LIST OF TABLES (1/2)

| Table No. | Title                                                                                   | Page |
|-----------|-----------------------------------------------------------------------------------------|------|
| 2-1       | Types of Pin I/O Circuits and Recommended Connection of Unused Pins                     | 35   |
| 3-1       | Internal ROM Capacity                                                                   | 42   |
| 3-2       | Vector Table                                                                            | 42   |
| 3-3       | Internal High-Speed RAM Capacity                                                        | 43   |
| 3-4       | Special Function Registers                                                              | 54   |
| 4-1       | Port Functions                                                                          | 66   |
| 4-2       | Port Configuration                                                                      | 67   |
| 4-3       | Port Mode Register and Output Latch Settings When Using Alternate Functions             | 77   |
| 5-1       | Configuration of Clock Generator                                                        | 80   |
| 5-2       | Maximum Time Required for Switching CPU Clock                                           | 86   |
| 6-1       | Configuration of 16-Bit Timer 20                                                        | 88   |
| 6-2       | Interval Time of 16-Bit Timer 20                                                        | 93   |
| 6-3       | Settings of Capture Edge                                                                | 96   |
| 7-1       | Interval Time of 8-Bit Timer/Event Counter 00                                           | 100  |
| 7-2       | Square Wave Output Range of 8-Bit Timer/Event Counter 00                                | 100  |
| 7-3       | Configuration of 8-Bit Timer/Event Counter 00                                           | 101  |
| 7-4       | Interval Time of 8-Bit Timer/Event Counter 00                                           | 104  |
| 7-5       | Square Wave Output Range of 8-Bit Timer/Event Counter 00                                | 107  |
| 8-1       | Inadvertent Loop Detection Time of Watchdog Timer                                       | 110  |
| 8-2       | Interval Time                                                                           | 110  |
| 8-3       | Configuration of Watchdog Timer                                                         | 111  |
| 8-4       | Inadvertent Loop Detection Time of Watchdog Timer                                       | 114  |
| 8-5       | Interval Time of Interval Timer                                                         | 115  |
| 9-1       | Configuration of Serial Interface 00                                                    | 116  |
| 9-2       | Operating Mode Settings of Serial Interface 00                                          | 122  |
| 9-3       | Example of Relationship Between System Clock and Baud Rate                              | 125  |
| 9-4       | Relationship Between ASCK Pin Input Frequency and Baud Rate (When BRGC00 Is Set to 80H) | 126  |
| 9-5       | Example of Relationship Between System Clock and Baud Rate                              | 133  |
| 9-6       | Relationship Between ASCK Pin Input Frequency and Baud Rate (When BRGC00 Is Set to 80H) |      |
| 9-7       | Receive Error Causes                                                                    | 138  |
| 10-1      | Interrupt Source List                                                                   | 146  |
| 10-2      | Flags Corresponding to Interrupt Request Signal Names                                   | 148  |

## LIST OF TABLES (2/2)

| Table No. | Title                                                           | Page |
|-----------|-----------------------------------------------------------------|------|
| 10-3      | Time from Generation of Maskable Interrupt Request to Servicing | 156  |
| 11-1      | HALT Mode Operating Status                                      | 163  |
| 11-2      | Operation After Release of HALT Mode                            | 165  |
| 11-3      | STOP Mode Operating Status                                      |      |
| 11-4      | Operation After Release of STOP Mode                            |      |
| 12-1      | Hardware Status After Reset                                     | 171  |
| 13-1      | Differences Between $\mu$ PD78F9026A and Mask ROM Versions      | 172  |
| 13-2      | Communication Mode List                                         | 174  |
| 13-3      | Pin Connection List                                             | 176  |
| 14-1      | Operand Identifiers and Writing Methods                         |      |
| 18-1      | Surface Mounting Type Soldering Conditions                      | 207  |

## CHAPTER 1 GENERAL

## 1.1 Features

• ROM and RAM capacity

| Item Part Number | Program Me   | emory | Data Memory |
|------------------|--------------|-------|-------------|
| μPD789022        | ROM          | 4 KB  | 256 bytes   |
| μPD789024        |              | 8 KB  |             |
| μPD789025        |              | 12 KB | 512 bytes   |
| μPD789026        |              | 16 KB |             |
| μPD78F9026A      | Flash memory | 16 KB |             |

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: 34 lines
- Serial interface: 1 channel
  - 3-wire serial I/O mode/UART mode selectable
- Timer: 3 channels
  - 16-bit timer: 1 channel
  - 8-bit timer/event counter: 1 channel
  - Watchdog timer: 1 channel
- Vectored interrupts: 10
- Supply voltage: VDD = 1.8 to 5.5 V
- Operating ambient temperature:  $T_A = -40$  to  $+85^{\circ}C$

## **1.2 Applications**

Home appliances, car accessories, air conditioners, game machines, etc.

## 1.3 Ordering Information

\* \* \* \* \*

| Part Number            | Package                             | Internal ROM |
|------------------------|-------------------------------------|--------------|
| μPD789022GB-×××-8ES    | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789024GB-×××-8ES    | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789025GB-×××-8ES    | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789026GB-×××-8ES    | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| $\mu$ PD78F9026AGB-8ES | 44-pin plastic LQFP (10 $	imes$ 10) | Flash memory |
| μPD789022GB-×××-8ES-A  | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789024GB-×××-8ES-A  | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789025GB-×××-8ES-A  | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD789026GB-×××-8ES-A  | 44-pin plastic LQFP (10 $	imes$ 10) | Mask ROM     |
| μPD78F9026AGB-8ES-A    | 44-pin plastic LQFP (10 $	imes$ 10) | Flash memory |
|                        |                                     |              |

**Remarks 1.** ××× indicates ROM code suffix.

2. Products that have the part numbers suffixed by "-A" are lead-free products.

## 1.4 Pin Configuration (Top View)



Caution Connect the IC pin directly to Vsso or Vss1.

**Remarks** 1. The item in parentheses applies to the  $\mu$ PD78F9026A only.

2. Products that have the part numbers suffixed by "-A" are lead-free products.

| ASCK:           | Asynchronous serial clock  | RESET:      | Reset                    |
|-----------------|----------------------------|-------------|--------------------------|
| CPT2:           | Capture trigger input      | RxD:        | Receive data             |
| IC:             | Internally connected       | SCK0:       | Serial clock             |
| INTP0 to INTP2: | Interrupt from peripherals | SIO:        | Serial input             |
| KR0 to KR7:     | Key return                 | SO0:        | Serial output            |
| NC:             | Non-connection             | TIO:        | Timer input              |
| P00 to P07:     | Port 0                     | TO0, TO2:   | Timer output             |
| P10 to P17:     | Port 1                     | TxD:        | Transmit data            |
| P20 to P22:     | Port 2                     | VDD0, VDD1: | Power supply             |
| P30 to P32:     | Port 3                     | Vpp:        | Programming power supply |
| P40 to P47:     | Port 4                     | Vsso, Vss1: | Ground                   |
| P50 to P53:     | Port 5                     | X1, X2:     | Crystal                  |

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





**Remark** VFD (Vacuum Fluorescent Display) is referred to as FIP<sup>™</sup> (Fluorescent Indicator Panel) in some documents, but the functions of the two are the same.

The major functional differences between the subseries are listed below.

|                                                                | Function   |                   |       | Tir    | ner   |        | 8-Bit |      |                                              | I/O      | VDD                   | Remarks                |
|----------------------------------------------------------------|------------|-------------------|-------|--------|-------|--------|-------|------|----------------------------------------------|----------|-----------------------|------------------------|
| Subseries Name                                                 |            | Capacity          | 8-Bit | 16-Bit | Watch | WDT    | A/D   | A/D  | Interface                                    |          | MIN.<br>Value         |                        |
| Small-scale<br>package,<br>general-<br>purpose<br>applications | μPD789046  | 16 KB             | 1 ch  |        | 1 ch  | 1 ch – | -     | _    | 1 ch<br>(UART: 1 ch)                         | 34<br>24 | 1.8 V                 | -                      |
|                                                                | μPD789026  | 4 KB to 16 KB     |       |        | _     |        |       |      |                                              |          |                       |                        |
|                                                                | μPD789088  | 16 KB to<br>32 KB | 3 ch  |        |       |        |       |      |                                              |          | _                     |                        |
|                                                                | μPD789074  | 2 KB to 8 KB      | 1 ch  |        |       |        |       |      |                                              |          |                       |                        |
|                                                                | μPD789062  | 4 KB              | 2 ch  | -      |       |        |       |      | - 14                                         | 14       |                       | RC oscillation version |
|                                                                | μPD789052  |                   |       |        |       |        |       |      |                                              |          |                       | _                      |
| Small-scale                                                    | μPD789177  | 16 KB to          | 3 ch  | 1 ch   | 1 ch  | 1 ch   | -     | 8 ch | 1 ch<br>(UART: 1 ch)                         | 31       | 1.8 V                 | _                      |
| package,                                                       | μPD789167  | 24 KB             |       |        |       |        | 8 ch  | -    |                                              |          |                       |                        |
| general-<br>purpose                                            | μPD789134A |                   | 1 ch  |        | _     |        | _     | 4 ch |                                              | 20       |                       | RC oscillation         |
| applications                                                   | μPD789124A |                   |       |        |       |        | 4 ch  | _    |                                              |          |                       | version                |
| and A/D<br>converter                                           | μPD789114A |                   |       |        |       |        | _     | 4 ch |                                              |          |                       | _                      |
|                                                                | μPD789104A |                   |       |        |       |        | 4 ch  | -    |                                              |          |                       |                        |
| LCD drive                                                      | μPD789835B | 24 KB to<br>60 KB | 6 ch  | -      | 1 ch  | 1 ch   | 3 ch  | -    | 1 ch<br>(UART: 1 ch)<br>2 ch<br>(UART: 1 ch) | 37       | 1.8 V <sup>Note</sup> | Dot LCD<br>supported   |
|                                                                | μPD789830  | 24 KB             | 1 ch  | - 1    |       |        | -     |      |                                              | 30       | 2.7 V                 |                        |
|                                                                | μPD789489  | 32 KB to<br>48 KB | 3 ch  |        |       |        |       | 8 ch |                                              | 45       | 1.8 V                 | -                      |
|                                                                | μPD789479  | 24 KB to<br>48 KB |       |        |       |        | 8 ch  | -    |                                              | 43       |                       |                        |
|                                                                | μPD789417A | 12 KB to          |       |        |       |        | _     | 7 ch | 1 ch                                         |          |                       |                        |
|                                                                | μ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 | 2 ch<br>(UART: 1 ch)                         | 40       | 1                     |                        |
|                                                                | μPD789426  |                   |       |        |       |        | 6 ch  | -    |                                              |          |                       |                        |
|                                                                | μPD789316  | 8 KB to 16 KB     |       |        |       |        | -     |      |                                              | 23       |                       | RC oscillation version |
|                                                                | μPD789306  |                   |       |        |       |        |       |      |                                              |          |                       | _                      |
|                                                                | μPD789467  | 4 KB to 24 KB     |       | _      |       |        | 1 ch  |      | _                                            | 18       |                       |                        |
|                                                                | μPD789327  | 1                 |       |        |       |        | _     |      | 1 ch                                         | 21       |                       |                        |

| Series for General-purpose applications and LCD drive |
|-------------------------------------------------------|
|-------------------------------------------------------|

Note Flash memory version: 3.0 V

| Function                  |            | ROM               |       | Tir    | mer   |      | 8-Bit | 10-Bit | Serial               | I/O | Vdd                     | Remarks                                       |
|---------------------------|------------|-------------------|-------|--------|-------|------|-------|--------|----------------------|-----|-------------------------|-----------------------------------------------|
| Subseries Name            |            | Capacity          | 8-Bit | 16-Bit | Watch | WDT  | A/D   | A/D    | Interface            |     | MIN.<br>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                                        |
| Sensor                    | μPD789864  | 4 KB              | 1 ch  | Note 2 | _     | 1 ch | _     | 4 ch   | _                    | 5   | 1.9 V                   | On-chip<br>EEPROM                             |
|                           | μPD789863  |                   |       |        |       |      |       |        |                      |     |                         | RC oscillation<br>version, on-<br>chip 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 3</sup> | -                                             |

Notes 1. 10-bit timer: 1 channel

2. 12-bit timer: 1 channel

3. Flash memory version: 3.0 V

## 1.6 Block Diagram



**Remarks 1.** The internal ROM and internal high-speed RAM capacities differ depending on the product. **2.** The item in parentheses applies to the  $\mu$ PD78F9026A only.

## 1.7 Overview of Functions

|                    | Part Number      | μPD789022                                                                                                                    | μPD789024          | μPD789025          | μPD789026 | μPD78F9026A |  |  |  |
|--------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|-----------|-------------|--|--|--|
| Item               |                  |                                                                                                                              |                    |                    |           |             |  |  |  |
| Internal memory    | ROM              | Mask ROM                                                                                                                     | Flash memory       |                    |           |             |  |  |  |
|                    |                  | 4 KB 8 KB                                                                                                                    |                    | 12 KB              | 16 KB     | 16 KB       |  |  |  |
|                    | High-speed RAM   | 256 bytes                                                                                                                    |                    | 512 bytes          |           |             |  |  |  |
| Minimum instructio | n execution time | 0.4/1.6 <i>µ</i> s (when a                                                                                                   | operated at 5.0 MI | Hz with system clo | ock)      |             |  |  |  |
| Instruction set    |                  | <ul><li>16-bit operations</li><li>Bit manipulation (set, reset, test), etc.</li></ul>                                        |                    |                    |           |             |  |  |  |
| I/O ports          |                  | Total:         34           • CMOS I/O:         34                                                                           |                    |                    |           |             |  |  |  |
| Serial interface   |                  | 3-wire serial I/O mode/UART mode selectable: 1 channel                                                                       |                    |                    |           |             |  |  |  |
| Timer              |                  | <ul> <li>16-bit timer: 1 channel</li> <li>8-bit timer/event counter: 1 channel</li> <li>Watchdog timer: 1 channel</li> </ul> |                    |                    |           |             |  |  |  |
| Timer outputs      |                  | 2                                                                                                                            |                    |                    |           |             |  |  |  |
| Vectored interrupt | Maskable         | Internal: 5, External: 4                                                                                                     |                    |                    |           |             |  |  |  |
| sources            | Non-maskable     | Internal: 1                                                                                                                  |                    |                    |           |             |  |  |  |
| Power supply volta | ige              | V <sub>DD</sub> = 1.8 to 5.5 V                                                                                               |                    |                    |           |             |  |  |  |
| Operating ambient  | temperature      | $T_{A} = -40 \text{ to } +85^{\circ}\text{C}$                                                                                |                    |                    |           |             |  |  |  |
| Package            |                  | 44-pin plastic LQFP (10 $\times$ 10)                                                                                         |                    |                    |           |             |  |  |  |

The outline of the timer is as follows.

|           |                        | 16-Bit Timer 20 | 8-Bit Timer/Event<br>Counter 00 | Watchdog Timer            |
|-----------|------------------------|-----------------|---------------------------------|---------------------------|
| Operating | Interval timer         | _               | 1 channel                       | 1 channel <sup>Note</sup> |
| mode      | External event counter | _               | 1 channel                       | -                         |
| Function  | Timer output           | 1 output        | 1 output                        | -                         |
|           | Capture                | 1 input         | _                               | -                         |
|           | Interrupt source       | 1               | 1                               | 2                         |

Note The watchdog timer has watchdog timer and interval timer functions. Select one of them.

## **CHAPTER 2 PIN FUNCTIONS**

## 2.1 List of Pin Functions

## (1) Port pins

| Pin Name   | I/O | Function                                                                                                                                                                                                                                               | After Reset | Alternate Function |
|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| P00 to P07 | I/O | Port 0<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | _                  |
| P10 to P17 | I/O | Port 1<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | _                  |
| P20        | I/O | Port 2                                                                                                                                                                                                                                                 | Input       | SCK0/ASCK          |
| P21        |     | 3-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | SO0/TxD            |
| P22        |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | SI0/RxD            |
| P30        | I/O | Port 3                                                                                                                                                                                                                                                 | Input       | INTP0              |
| P31        |     | 3-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | INTP1              |
| P32        |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | INTP2/CPT2         |
| P40 to P47 | I/O | Port 4<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | KR0 to KR7         |
| P50        | I/O | Port 5                                                                                                                                                                                                                                                 | Input       | Т10/ТО0            |
| P51        |     | 4-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | TO2                |
| P52, P53   |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | _                  |

## (2) Non-port pins

| Pin Name         | I/O    | Function                                                                                                 | After Reset | Alternate Function |
|------------------|--------|----------------------------------------------------------------------------------------------------------|-------------|--------------------|
| INTP0            | Input  | External interrupt request input for which the valid edge (rising                                        | Input       | P30                |
| INTP1            |        | edge, falling edge, or both rising and falling edges) can be specified                                   |             | P31                |
| INTP2            |        | specified                                                                                                |             | P32/CPT2           |
| KR0 to KR7       | Input  | Key return signal detection                                                                              | Input       | P40 to P47         |
| SI0              | Input  | 3-wire serial interface serial data input                                                                | Input       | P22/RxD            |
| SO0              | Output | 3-wire serial interface serial data output                                                               | Input       | P21/TxD            |
| SCK0             | I/O    | 3-wire serial interface serial clock input/output                                                        | Input       | P20/ASCK           |
| ASCK             | Input  | Asynchronous serial interface serial clock input                                                         | Input       | P20/SCK0           |
| RxD              | Input  | Asynchronous serial interface serial data input                                                          | Input       | P22/SI0            |
| TxD              | Output | Asynchronous serial interface serial data output                                                         | Input       | P21/SO0            |
| TO2              | Output | 16-bit timer 20 output                                                                                   | Input       | P51                |
| CPT2             | Input  | 16-bit timer capture edge input                                                                          | Input       | P32/INTP2          |
| TI0              | Input  | External count clock input to 8-bit timer/event counter 00                                               | Input       | P50/TO0            |
| TO0              | Output | 8-bit timer/event counter 00 output                                                                      | Input       | P50/TI0            |
| X1               | Input  | Connection of crystal for system clock oscillation                                                       | -           | _                  |
| X2               | -      |                                                                                                          | _           | -                  |
| RESET            | Input  | System reset input                                                                                       | Input       | _                  |
| NC               | _      | Not connected internally. Connect this pin to the $V_{SS0}$ or $V_{SS1}$ pin (it can also be left open). | _           | -                  |
| VDD0             | -      | Positive power supply for ports                                                                          | -           | -                  |
| V <sub>DD1</sub> | -      | Positive power supply (except for ports)                                                                 | -           | _                  |
| Vsso             | -      | Ground potential for ports                                                                               | -           | _                  |
| V <sub>SS1</sub> | -      | Ground potential (except for ports)                                                                      | -           | _                  |
| IC               | _      | Internally connected. Connect this pin directly to the Vsso or Vsso pin.                                 | _           | _                  |
| VPP              | _      | Flash memory programming mode setting.<br>Apply high voltage during program write/verify.                | -           | -                  |

## 2.2 Description of Pin Functions

## 2.2.1 P00 to P07 (Port 0)

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

This port can drive LEDs directly.

## 2.2.2 P10 to P17 (Port 1)

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

This port can drive LEDs directly.

## 2.2.3 P20 to P22 (Port 2)

These pins constitute a 3-bit I/O port. In addition, they also function as the data and clock I/O of the serial interface.

This port can drive LEDs directly.

Port 2 can be specified in the following operation modes in 1-bit units.

## (1) Port mode

In this mode, port 2 functions as a 3-bit I/O port. Port 2 can be set to input or output port mode in 1-bit units by using port mode register 2 (PM2). When the port is used as an input port, an on-chip pull-up resistor can be used by setting the pull-up resistor option register (PUO).

## (2) Control mode

In this mode, port 2 functions as the data I/O and the clock I/O of the serial interface.

#### (a) SI0, SO0

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

#### (b) **SCK0**

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

#### (c) RxD, TxD

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

#### (d) ASCK

This is the serial clock input pin of the asynchronous serial interface.

Caution When using port 2 as serial interface pins, the I/O mode and output latch must be set according to the function to be used. For details of the setting, see Table 9-2 Operating Mode Settings of Serial Interface 00.

## 2.2.4 P30 to P32 (Port 3)

These pins constitute a 3-bit I/O port. In addition, they also function as external interrupt and capture edge inputs. This port can drive LEDs directly.

Port 3 can be specified in the following operation modes in 1-bit units.

## (1) Port mode

In this mode, port 3 functions as a 3-bit I/O port. Port 3 can be set to input or output port mode in 1-bit units by using port mode register 3 (PM3). When the port is used as an input port, an on-chip pull-up resistor can be used by setting the pull-up resistor option register (PUO).

## (2) Control mode

In this mode, port 3 functions as the external interrupt input pins.

## (a) INTP0 to INTP2

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

## (b) CPT2

This is the capture edge input pin.

## 2.2.5 P40 to P47 (Port 4)

These pins constitute an 8-bit I/O port. In addition, they also function as key return signal detection pins. This port can drive LEDs directly.

Port 4 can be specified in the following operation modes in 1-bit units.

## (1) Port mode

In this mode, port 4 functions as an 8-bit I/O port. Port 4 can be set to input or output port mode in 1-bit units by using port mode register 4 (PM4). When the port is used as an input port, an on-chip pull-up resistor can be used by setting the pull-up resistor option register (PUO).

## (2) Control mode

In this mode, port 4 functions as the key return signal detection pins (KR0 to KR7).

## 2.2.6 P50 to P53 (Port 5)

These pins constitute a 4-bit I/O port. In addition, they also function as timer I/O pins. This port can drive LEDs directly. Port 5 can be specified in the following operation modes in 1-bit units.

## (1) Port mode

In this mode, port 5 functions as a 4-bit I/O port. Port 5 can be set to input or output port mode in 1-bit units by using port mode register 5 (PM5). When the port is used as an input port, an on-chip pull-up resistor can be used by setting the pull-up resistor option register (PUO).

#### (2) Control mode

In this mode, port 5 functions as the timer I/O.

## (a) TI0

This is the external clock input pin for 8-bit timer/event counter 00.

## (b) TO0

This is the 8-bit timer/event counter 00 output pin.

## (c) TO2

This is the 16-bit timer 20 output pin.

## 2.2.7 **RESET**

This pin inputs an active-low system reset signal.

#### 2.2.8 X1, X2

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

## 2.2.9 NC

The NC (non-connection) pin is not connected internally. Connect this pin to the Vsso or Vss1 pin (it can also be left open).

## 2.2.10 VDD

This is the positive power supply pin.

## 2.2.11 Vss

This is the ground potential pin.

## 2.2.12 VPP (µPD78F9026A only)

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

Handle the pins in either of the following ways.

- Independently connect a 10 k $\Omega$  pull-down resistor.
- Switch this pin to be directly connected to the dedicated flash programmer in programming mode or to V<sub>SS0</sub> or V<sub>SS1</sub> in normal operation mode using a jumper on the board.

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

## 2.2.13 IC (mask ROM version only)

\*

The IC (internally connected) pin is used to set the  $\mu$ PD789026 Subseries in the test mode for testing before shipment. In the normal operating mode, directly connect the IC pin to the Vsso or Vss1 pin with as short a wire as possible.

If a potential difference is generated between the IC pin and V<sub>SS0</sub> or V<sub>SS1</sub> pin due to a long wiring length between these pins, or external noise is superimposed on the IC pin, the user program may not run correctly.



• Connect the IC pin directly to the Vsso or Vss1 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, see Figure 2-1.

| Pin Name                      | I/O Circuit Type | I/O   | Recommended Connection of Unused Pins                                                             |
|-------------------------------|------------------|-------|---------------------------------------------------------------------------------------------------|
| P00 to P07                    | 5-X              | I/O   | Input: Independently connect to VDD0, VDD1, VSS0, or VSS1                                         |
| P10 to P17                    |                  |       | via a resistor.                                                                                   |
| P20/ASCK/SCK0                 | 8-J              |       | Output: Leave open.                                                                               |
| P21/TxD/SO0                   | 5-X              |       |                                                                                                   |
| P22/RxD/SI0                   | 8-J              |       |                                                                                                   |
| P30/INTP0                     |                  |       |                                                                                                   |
| P31/INTP1                     | -                |       |                                                                                                   |
| P32/INTP2/CPT2                | -                |       |                                                                                                   |
| P40/KR0 to P47/KR7            | -                |       |                                                                                                   |
| P50/TI0/TO0                   | -                |       |                                                                                                   |
| P51/TO2                       | 5-X              |       |                                                                                                   |
| P52, P53                      |                  |       |                                                                                                   |
| RESET                         | 2                | Input | _                                                                                                 |
| NC                            |                  | _     | Connect directly to V <sub>SS0</sub> or V <sub>SS1</sub> (can also be left open).                 |
| IC (mask ROM version)         |                  |       | Connect directly to Vsso or Vss1.                                                                 |
| V <sub>PP</sub> (µPD78F9026A) |                  |       | Independently connect to a 10 $k\Omega$ pull-down resistor or directly to $V_{SS0}$ or $V_{SS1}.$ |

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



Figure 2-1. Pin I/O Circuits

# CHAPTER 3 CPU ARCHITECTURE

# 3.1 Memory Space

The  $\mu$ PD789026 Subseries can access 64 KB of memory space. Figures 3-1 through 3-5 show the memory maps.



Figure 3-1. Memory Map (*µ*PD789022)







Figure 3-3. Memory Map (*µ*PD789025)







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

## 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  $\mu$ PD789026 Subseries provides internal ROM (or flash memory) with the following capacities for each product.

| Part Number | Interna      | I ROM                  |
|-------------|--------------|------------------------|
|             | Structure    | Capacity               |
| μPD789022   | Mask ROM     | 4,096 $\times$ 8 bits  |
| μPD789024   |              | $8,192 \times 8$ bits  |
| μPD789025   |              | 12,288 $\times$ 8 bits |
| μPD789026   |              | 16,384 $\times$ 8 bits |
| μPD78F9026A | Flash memory | 16,384 $\times$ 8 bits |

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

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

# (1) Vector table area

A 44-byte area of addresses 0000H to 002BH 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 program address, the lower 8 bits are stored in an even address, and the higher 8 bits are stored in an odd address.

| Vector Table Address | Interrupt Request | Vector Table Address | Interrupt Request |
|----------------------|-------------------|----------------------|-------------------|
| 0000H                | RESET input       | 000CH                | INTSR/INTCSI0     |
| 0004H                | INTWDT            | 000EH                | INTST             |
| 0006H                | INTP0             | 0010H                | INTTMO            |
| 0008H                | INTP1             | 0014H                | INTTM2            |
| 000AH                | INTP2             | 002AH                | INTKR             |

# (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 (internal high-speed RAM) space

The  $\mu$ PD789026 Subseries provides internal high-speed RAM with the following capacities for each product. The internal high-speed RAM cannot be used as a program area for writing and executing instructions. The internal high-speed RAM can also be used as a stack memory.

# Table 3-3. Internal High-Speed RAM Capacity

| Part Number | Capacity            |
|-------------|---------------------|
| μPD789022   | $256 \times 8$ bits |
| μPD789024   |                     |
| μPD789025   | $512 \times 8$ bits |
| μPD789026   |                     |
| μPD78F9026A |                     |

# 3.1.3 Special function register (SFR) area

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

## 3.1.4 Data memory addressing

The  $\mu$ PD789026 Subseries provides a variety of addressing modes which take account of memory manipulability, etc. Especially at addresses corresponding to data memory area (FE00H to FFFH<sup>Note 1</sup>, FD00H to FFFFH<sup>Note 2</sup>), particular addressing modes can be realized to meet the functions of the special function registers (SFR) and other registers. Figures 3-6 through 3-10 show the data memory addressing modes.

## **Notes 1.** With *μ*PD789022 or *μ*PD789024

2. With µPD789025, µPD789026, or µPD78F9026A



Figure 3-6. Data Memory Addressing (µPD789022)



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







Figure 3-9. Data Memory Addressing (µPD789026)



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

## 3.2 Processor Registers

The  $\mu$ PD789026 Subseries provides 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. A program counter, a program status word, and a stack pointer make up the control registers.

## (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-11. | 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 the PSW to 02H.

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

## (a) Interrupt enable flag (IE)

This flag controls interrupt request acknowledgment 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 and interrupt request acknowledgment is controlled with an interrupt mask flag for each interrupt source.

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 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 used to hold the start address of the memory stack area. Only the internal high-speed RAM area can be set as the stack area.

Figure 3-13. Stack Pointer Configuration

| SP         SP15         SP14         SP13         SP12         SP11         SP10         SP9         SP8         SP7         SP6         SP5         SP4         SP2         SP1         SP1 | SP11 SP10 SP9 SP8 SP7 SP6 SP5 SP4 SP3 SP2 | '8 SP7 S | SP8 | SP9 | SP10 | SP11 | SP12 | SP13 | SP14 | SP15 | SP |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------|-----|-----|------|------|------|------|------|------|----|

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

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

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



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

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



# 3.2.2 General-purpose registers

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

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

These registers can be written in terms of functional 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-16. General-Purpose Register Configuration (a) Absolute names



## (b) Functional names

| 16-bit processing |   | 8-bit processing |
|-------------------|---|------------------|
| HL                |   | н                |
| TIL.              |   | L                |
| DE                |   | D                |
| DE                |   | E                |
| DC.               |   | В                |
| BC                |   | С                |
| AX                |   | A                |
| AA                |   | х                |
| 15 C              | ) | 7 0              |

## 3.2.3 Special function registers (SFR)

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

Special function registers are allocated in the 256-byte area FF00H to FFFFH.

Special function registers can be manipulated, like general-purpose registers, with operation, transfer, and bit manipulation instructions. The 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

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

• 8-bit manipulation

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

• 16-bit manipulation

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

Table 3-4 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 are reserved for the assembler and are defined as an sfr variable by the #pragma sfr directive for 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
- Bit units for manipulation

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             | Sym    | ibol  | R/W | Bit Units for Manipulation |                 |                 | After Reset |
|---------|--------------------------------------------------|--------|-------|-----|----------------------------|-----------------|-----------------|-------------|
|         |                                                  |        |       |     | 1 Bit                      | 8 Bits          | 16 Bits         |             |
| FF00H   | Port 0                                           | P0     |       | R/W | $\checkmark$               | $\checkmark$    | _               | 00H         |
| FF01H   | Port 1                                           | P1     |       |     | $\checkmark$               |                 | _               |             |
| FF02H   | Port 2                                           | P2     |       |     | $\checkmark$               | $\checkmark$    | _               |             |
| FF03H   | Port 3                                           | P3     |       |     | $\checkmark$               | $\checkmark$    | _               |             |
| FF04H   | Port 4                                           | P4     |       |     | $\checkmark$               | $\checkmark$    | _               |             |
| FF05H   | Port 5                                           | P5     |       |     | $\checkmark$               | $\checkmark$    | _               |             |
| FF10H   | Transmit shift register 00                       | TXS00  | SIO00 | W   | _                          | $\checkmark$    | -               | FFH         |
|         | Receive buffer register 00                       | RXB00  |       | R   | _                          | $\checkmark$    | _               | Undefined   |
| FF16H   | 16-bit compare register 20                       | CR20   |       | W   | _                          | √Note 1         | $\sqrt{Note 2}$ | FFFFH       |
| FF17H   |                                                  |        |       |     |                            |                 |                 |             |
| FF18H   | 16-bit timer counter 20                          | TM20   |       | R   | _                          | $\sqrt{Note 1}$ | √Note 2         | 0000H       |
| FF19H   |                                                  |        |       |     |                            |                 |                 |             |
| FF1AH   | 16-bit capture register 20                       | TCP20  |       |     | _                          | $\sqrt{Note 1}$ | $\sqrt{Note 2}$ | Undefined   |
| FF1BH   |                                                  |        |       |     |                            |                 |                 |             |
| FF20H   | Port mode register 0                             | PM0    |       | R/W | $\checkmark$               |                 | _               | FFH         |
| FF21H   | Port mode register 1                             | PM1    |       |     | $\checkmark$               |                 | _               |             |
| FF22H   | Port mode register 2                             | PM2    |       |     |                            | $\checkmark$    | -               |             |
| FF23H   | Port mode register 3                             | PM3    |       |     |                            | $\checkmark$    | -               |             |
| FF24H   | Port mode register 4                             | PM4    |       |     |                            | $\checkmark$    | -               |             |
| FF25H   | Port mode register 5                             | PM5    |       |     |                            | $\checkmark$    | -               |             |
| FF42H   | Timer clock select register 2                    | TCL2   |       |     | _                          | $\checkmark$    | -               | 00H         |
| FF50H   | 8-bit compare register 00                        | CR00   |       | W   | _                          | $\checkmark$    | -               | Undefined   |
| FF51H   | 8-bit timer counter 00                           | TM00   |       | R   | _                          | $\checkmark$    | -               | 00H         |
| FF53H   | 8-bit timer mode control register 00             | TMC00  |       | R/W |                            | $\checkmark$    | -               |             |
| FF5BH   | 16-bit timer mode control register 20            | TMC20  |       |     |                            | $\checkmark$    | -               |             |
| FF70H   | Asynchronous serial interface mode register 00   | ASIM00 |       |     | $\checkmark$               | $\checkmark$    | -               |             |
| FF71H   | Asynchronous serial interface status register 00 | ASIS00 |       | R   | $\checkmark$               | $\checkmark$    | _               |             |
| FF72H   | Serial operation mode register 00                | CSIM00 |       | R/W |                            | $\checkmark$    | _               |             |
| FF73H   | Baud rate generator control register 00          | BRGC0  | 0     |     | _                          | $\checkmark$    | -               |             |

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

**Notes 1.** CR20, TM20, and TCP20 are designed for 16-bit access, but they can also be accessed in 8-bit mode. In 8-bit access mode, use direct addressing.

2. 16-bit access is allowed only with short direct addressing.

| Address | Special Function Register (SFR) Name           | Symbol | R/W | Bit Un       | Bit Units for Manipulation |         | After Reset |
|---------|------------------------------------------------|--------|-----|--------------|----------------------------|---------|-------------|
|         |                                                |        |     | 1 Bit        | 8 Bits                     | 16 Bits |             |
| FFE0H   | Interrupt request flag register 0              | IF0    | R/W | $\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         |
| FFF5H   | Key return mode register 00                    | KRM00  |     | $\checkmark$ | $\checkmark$               | -       |             |
| FFF7H   | Pull-up resistor option register               | PUO    |     | $\checkmark$ | $\checkmark$               | -       |             |
| FFF9H   | Watchdog timer mode register                   | WDTM   |     | $\checkmark$ | $\checkmark$               | -       |             |
| FFFAH   | Oscillation stabilization time select register | OSTS   |     | _            | $\checkmark$               | _       | 04H         |
| FFFBH   | Processor clock control register               | PCC    |     |              | $\checkmark$               | -       | 02H         |

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

# 3.3 Instruction Address Addressing

An instruction address is determined by program counter (PC) contents. 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 information is set to the PC and branched by the following 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 a 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 or BR !addr16 instruction is executed. CALL !addr16 and BR !addr16 instructions can branch to all the memory spaces.

# [Illustration]

In case of CALL !addr16 or BR !addr16 instruction



## 3.3.3 Table indirect addressing

# [Function]

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 reference the address stored in the memory table 40H to 7FH and branch to all the memory spaces.

## [Illustration]



## 3.3.4 Register addressing

#### [Function]

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

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

# [Illustration]



# 3.4 Operand Address Addressing

The following methods are available to specify the register and memory (addressing) which 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 |  |

# [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 8-bit data in an instruction word.

The fixed space to which this addressing is applied is the 256-byte space FE20H to FF1FH. An internal highspeed RAM and special function registers (SFR) are mapped at FE20H to FEFFH and FF00H to FF1FH, respectively.

The SFR area (FF00H to FF1FH) where short direct addressing is applied is a part of the total SFR areas. In this area, ports which are frequently accessed in a program and a compare register of the timer/event 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].

# [Operand format]

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

# [Example]

MOV FE30H, #50H; When setting saddr to FE30H 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 8-bit immediate data in an instruction word. This addressing is applied to the 240-byte spaces FF00H to FFCFH and FFE0H to FFFFH. However, the SFRs mapped at FF00H to FF1FH can also be accessed with short direct addressing.

## [Operand format]

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

## [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 by the register specification 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 written 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).

# [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 specification code in the instruction code. This addressing can be carried out for all the memory spaces.

## [Operand format]

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

#### [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]   |

## [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 generation of an interrupt request. Stack addressing can be used to access the internal high-speed RAM area only.

# [Example]

In the case of PUSH DE



# **CHAPTER 4 PORT FUNCTIONS**

# 4.1 Functions of Ports

The µPD789026 Subseries provides the ports shown in Figure 4-1, enabling various methods of control. Alternate functions are provided in addition to the digital I/O port function. For more information on these alternate functions, see **CHAPTER 2 PIN FUNCTIONS**.





| Pin Name   | I/O | Function                                                                                                                                                                                                                                               | After Reset | Alternate Function |
|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| P00 to P07 | I/O | Port 0<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | _                  |
| P10 to P17 | I/O | Port 1<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | _                  |
| P20        | I/O | Port 2                                                                                                                                                                                                                                                 | Input       | SCK0/ASCK          |
| P21        |     | 3-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | SO0/TxD            |
| P22        |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | SI0/RxD            |
| P30        | I/O | Port 3                                                                                                                                                                                                                                                 | Input       | INTP0              |
| P31        |     | 3-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | INTP1              |
| P32        |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | INTP2/CPT2         |
| P40 to P47 | I/O | Port 4<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly. | Input       | KR0 to KR7         |
| P50        | I/O | Port 5                                                                                                                                                                                                                                                 | Input       | TI0/TO0            |
| P51        |     | 4-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                        |             | TO2                |
| P52, P53   |     | When used as an input port, use of an on-chip pull-up resistor can<br>be specified by setting the pull-up resistor option register (PUO).<br>LEDs can be driven directly.                                                                              |             | _                  |

Table 4-1. Port Functions

# 4.2 Port Configuration

Ports consist of the following hardware.

| ltem              | Configuration                                                                  |
|-------------------|--------------------------------------------------------------------------------|
| Control registers | Port mode register (PMm: m = 0 to 5)<br>Pull-up resistor option register (PUO) |
| Ports             | Total: 34 (I/O: 34)                                                            |
| Pull-up resistors | Total: 34 (on-chip pull-up resistors can be connected by software)             |

#### 4.2.1 Port 0

This is an 8-bit I/O port with an output latch. Port 0 can be specified in the input or output mode in 1-bit units by using port mode register 0 (PM0). When using the P00 to P07 pins as input port pins, on-chip pull-up resistors can be connected in 8-bit units by using the pull-up resistor option register (PUO).

RESET input sets port 0 to input mode.

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





PUO: Pull-up resistor option register

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

# 4.2.2 Port 1

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

RESET input sets port 1 to input mode.

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





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

# 4.2.3 Port 2

This is a 3-bit I/O port with an output latch. Port 2 can be specified in the input or output mode in 1-bit units by using port mode register 2 (PM2). When using the P20 to P22 pins as input port pins, on-chip pull-up resistors can be connected in 3-bit units by using the pull-up resistor option register (PUO).

The pins of this port are also used as the data I/O and clock I/O pins of the serial interface.

RESET input sets port 2 to input mode.

Figures 4-4 through 4-6 show the block diagrams of port 2.

Caution When using the pins of port 2 as the serial interface, the I/O mode and output latch must be set according to the function to be used. For details of the settings, see Table 9-2 Operating Mode Settings of Serial Interface 00.





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



Figure 4-5. Block Diagram of P21



- PUO: Pull-up resistor option register
- PM: Port mode register
- RD: Port 2 read signal
- WR: Port 2 write signal
Figure 4-6. Block Diagram of P22



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

# 4.2.4 Port 3

This is a 3-bit I/O port with an output latch. Port 3 can be specified in input or output mode in 1-bit units by using port mode register 3 (PM3). When using the P30 to P32 pins as input port pins, on-chip pull-up resistors can be connected in 3-bit units by using the pull-up resistor option register (PUO).

The pins of this port are also used as the external interrupt input and capture edge input.

RESET input sets port 3 to input mode.

Figure 4-7 shows the block diagram of port 3.





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

## 4.2.5 Port 4

This is an 8-bit I/O port with an output latch. Port 4 can be specified in the input or output mode in 1-bit units by using port mode register 4 (PM4). When using the P40 to P47 pins as input port pins, on-chip pull-up resistors can be connected in 8-bit units by using the pull-up resistor option register (PUO).

The pins of this port are also used as the key return input.

RESET input sets port 4 to input mode.

Figure 4-8 shows the block diagram of port 4.

# Caution When using port 4 for the key return function, it is necessary to set key return mode register 00. For details of the settings, see 10.3 (5) Key return mode register 00 (KRM00).



Figure 4-8. Block Diagram of P40 to P47

KRM00: Key return mode register 00

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

## 4.2.6 Port 5

This is a 4-bit I/O port with an output latch. Port 5 can be specified in the input or output mode in 1-bit units by using port mode register 5 (PM5). When using the P50 to P53 pins as input port pins, on-chip pull-up resistors can be connected in 4-bit units by using the pull-up resistor option register (PUO).

The pins of this port are also used as the data I/O pins of the timer.

RESET input sets port 5 to input mode.

Figures 4-9 through 4-11 show the block diagrams of port 5.





PUO: Pull-up resistor option register

PM: Port mode register

RD: Port 5 read signal

WR: Port 5 write signal

Figure 4-10. Block Diagram of P51



- PUO: Pull-up resistor option register
- PM: Port mode register

 $\star$ 

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

Figure 4-11. Block Diagram of P52 and P53

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

## 4.3 Registers Controlling Port Function

The following two types of registers control the ports.

- Port mode registers (PM0 to PM5)
- Pull-up resistor option register (PUO)

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

These registers are used to set port input/output in 1-bit units.

Port mode registers are independently set with 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 4-3.

Caution As port 3 has an alternate function as the external interrupt input, 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    |     |   |
| P30                        | INTP0              | Input  | 1   | × |
| P31                        | INTP1              | Input  | 1   | × |
| P32                        | INTP2              | Input  | 1   | × |
|                            | CPT2               | Input  | 1   | × |
| P40 to P47 <sup>Note</sup> | KR0 to KR7         | Input  | 1   | × |
| P50                        | ТІО                | Input  | 1   | × |
|                            | ТОО                | Output | 0   | 0 |
| P51                        | TO2                | Output | 0   | 0 |

Table 4-3. Port Mode Register and Output Latch Settings When Using Alternate Functions

- Note When an alternate function is used, set key return mode register 00 (KRM00) to 1 (see 10.3 (5) Key return mode register 00 (KRM00)).
- Caution When port 2 is used as serial interface pins, the I/O mode and output latch must be set according to the function to be used. For details of the settings, see Table 9-2 Operating Mode Settings of Serial Interface 00.
- Remark ×: Don't care

PM XX: Port mode register

Pxx: Output latch of port

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Address | After reset | R/W |
|--------|------|------|------|------|------|------|------|------|---------|-------------|-----|
| PM0    | PM07 | PM06 | PM05 | PM04 | PM03 | PM02 | PM01 | PM00 | FF20H   | FFH         | R/W |
|        |      |      |      |      |      |      |      |      |         |             |     |
| PM1    | PM17 | PM16 | PM15 | PM14 | PM13 | PM12 | PM11 | PM10 | FF21H   | FFH         | R/W |
| I      |      |      |      |      |      |      |      |      |         |             |     |
| PM2    | 1    | 1    | 1    | 1    | 1    | PM22 | PM21 | PM20 | FF22H   | FFH         | R/W |
|        |      | 1    |      |      |      |      |      |      |         |             |     |
| PM3    | 1    | 1    | 1    | 1    | 1    | PM32 | PM31 | PM30 | FF23H   | FFH         | R/W |
|        |      |      |      |      |      |      |      |      |         |             |     |
| PM4    | PM47 | PM46 | PM45 | PM44 | PM43 | PM42 | PM41 | PM40 | FF24H   | FFH         | R/W |
| I      |      |      | 1    |      |      |      |      |      |         |             |     |
| PM5    | 1    | 1    | 1    | 1    | PM53 | PM52 | PM51 | PM50 | FF25H   | FFH         | R/W |
|        |      | 1    | 1    |      |      |      |      |      |         |             |     |

## Figure 4-12. Format of Port Mode Register

| PMmn | $ \begin{array}{c} \mbox{Pmn pin I/O mode selection} \\ m = \ 0, \ 1, \ 4: \ n = 0 \ to \ 7 \\ m = 2, \ 3: \ n = 0 \ to \ 2 \\ m = 5: \ n = 0 \ to \ 3 \end{array} \right) $ |  |  |  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0    | Output mode (output buffer on)                                                                                                                                               |  |  |  |
| 1    | Input mode (output buffer off)                                                                                                                                               |  |  |  |

## (2) Pull-up resistor option register (PUO)

The pull-up resistor option register (PUO) sets whether an on-chip pull-up resistor is used on each port or not.

On the port specified by PUO to use an on-chip pull-up resistor, the pull-up resistor can be internally used only for the bits set in the input mode. No on-chip pull-up resistors can be used for the bits set in the output mode regardless of the setting of PUO. On-chip pull-up resistors cannot be used when the pins are used as the alternate-function output pins.

PUO is set with a 1-bit or 8-bit memory manipulation instruction.

RESET input clears PUO to 00H.

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

| Symbol | 7 | 6 | <5>  | <4>  | <3>  | <2>  | <1>  | <0>  | Address | After reset | R/W |
|--------|---|---|------|------|------|------|------|------|---------|-------------|-----|
| PUO    | 0 | 0 | PUO5 | PUO4 | PUO3 | PUO2 | PUO1 | PUO0 | FFF7H   | 00H         | R/W |

| PUOm | Port m on-chip pull-up resistor selection<br>( $m = 0$ to 5) |
|------|--------------------------------------------------------------|
| 0    | On-chip pull-up resistor not used                            |
| 1    | On-chip pull-up resistor used                                |

## 4.4 Operation of Port Functions

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

#### 4.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.

Once data is written to the output latch, it 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.

Once data is written to the output latch, it 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 a port consisting both of inputs and outputs, therefore, the contents of the output latch of the pin that is set in the input mode and not subject to manipulation become undefined.

#### 4.4.2 Reading from I/O port

#### (1) In output mode

The contents of an 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.

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

#### (1) In output mode

An arithmetic operation can be performed on the contents of an 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. Once data is written to the output latch, it 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 a port consisting both of inputs and outputs, 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 5 CLOCK GENERATOR

## 5.1 Function of Clock Generator

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 oscillator

This circuit oscillates at frequencies of 1.0 to 5.0 MHz. Oscillation can be stopped by executing the STOP instruction.

# 5.2 Configuration of Clock Generator

The clock generator consists of the following hardware.

| Table 5-1. | Configuration | of Clock | Generator |
|------------|---------------|----------|-----------|
|------------|---------------|----------|-----------|

| Item             | Configuration                          |  |  |  |
|------------------|----------------------------------------|--|--|--|
| Control register | Processor clock control register (PCC) |  |  |  |
| Oscillator       | System clock oscillator                |  |  |  |





# 5.3 Register Controlling Clock Generator

The clock generator is controlled by the following register.

• Processor clock control register (PCC)

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

PCC sets CPU clock selection and the division ratio. PCC is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets PCC to 02H.

## Figure 5-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 | 0 | FFFBH   | 02H         | R/W |

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

#### Caution Be sure to set bits 0 and 2 to 7 to 0.

**Remark** fx: System clock oscillation frequency

# 5.4 System Clock Oscillator

## 5.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.

An external clock can also be input to the circuit. In this case, input the clock signal to the X1 pin, and input the inverted signal to the X2 pin.

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

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

(a) Crystal or ceramic oscillation

(b) External clock





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

## 5.4.2 Examples of incorrect resonator connection

Figure 5-4 shows examples of incorrect resonator connection.



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



(c) Wiring near high fluctuating current



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







#### 5.4.3 Divider circuit

The divider circuit divides the output of the system clock oscillator (fx) to generate various clocks.

## 5.5 Operation of Clock Generator

The clock generator generates the following clocks and controls the operation modes of the CPU, such as the 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) Two types of minimum instruction execution time (0.4  $\mu$ s and 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 to the peripheral hardware is supplied by dividing the system clock. The other peripheral hardware is stopped when the system clock is stopped (except, however, the external input clock operation).

# 5.6 Changing Setting of System Clock and CPU Clock

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

The CPU clock can be selected by using bit 1 (PCC1) of the processor clock control register (PCC).

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

| Table 5-2. Maximum Time Required for Switching CPU Cloc | k |
|---------------------------------------------------------|---|
|---------------------------------------------------------|---|

| Set Value Before Switching | Set Value Af | ter Switching |
|----------------------------|--------------|---------------|
| PCC1                       | PCC1         | PCC1          |
|                            | 0            | 1             |
| 0                          |              | 4 clocks      |
| 1                          | 2 clocks     |               |



#### 5.6.2 Switching CPU clock

The following figure illustrates how the CPU clock switches.





<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>15</sup>/fx) is automatically secured.

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

<2> After the time during which the VDD voltage rises 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 mode can be selected.

# CHAPTER 6 16-BIT TIMER 20

# 6.1 Functions of 16-Bit Timer 20

16-bit timer 20 has the following functions.

# • Timer interrupt

- Timer output
- Count value capture

# (1) Timer interrupt

An interrupt is generated when the count value and compare value match.

# (2) Timer output

Timer output control is possible when the count value and compare value match.

# (3) Count value capture

The TM20 count value is latched into a capture register in synchronization with the capture trigger and retained.

# 6.2 Configuration of 16-Bit Timer 20

16-bit timer 20 consists of the following hardware.

## Table 6-1. Configuration of 16-Bit Timer 20

| Item              | Configuration                                                                         |
|-------------------|---------------------------------------------------------------------------------------|
| Timer counter     | 16 bits × 1 (TM20)                                                                    |
| Registers         | Compare register:16 bits $\times$ 1 (CR20)Capture register:16 bits $\times$ 1 (TCP20) |
| Timer outputs     | 1 (TO2)                                                                               |
| Control registers | 16-bit timer mode control register 20 (TMC20)<br>Port mode register 5 (PM5)           |

## Figure 6-1. Block Diagram of 16-Bit Timer 20



## (1) 16-bit compare register 20 (CR20)

This register compares the value set to CR20 with the count value of 16-bit timer counter 20 (TM20), and when they match, generates an interrupt request (INTTM2). CR20 is set with a 16-bit memory manipulation instruction. Values from 0000H to FFFFH can be set. RESET input sets this register to FFFFH.

- Cautions 1. This register is manipulated with a 16-bit memory manipulation instruction; however, an 8-bit memory manipulation instruction can be used. When manipulated with an 8-bit memory manipulation instruction, the accessing method should be direct addressing. This register can be accessed only in short direct addressing mode when a 16-bit memory manipulation instruction is used.
  - When rewriting CR20 during a count operation, set CR20 to interrupt disabled using interrupt mask flag register 1 (MK1) beforehand. Also, set the timer output data to inversion disabled using 16-bit timer mode control register 20 (TMC20).
     If CR20 is rewritten with interrupts enabled, an interrupt request may be issued immediately.

## (2) 16-bit timer counter 20 (TM20)

This is a 16-bit register that counts count pulses.

TM20 is read with a 16-bit memory manipulation instruction.

This register is in free-running mode during count clock input.

RESET input clears this register to 0000H, after which it enters free-running mode again.

- Cautions 1. The count value after releasing stop becomes undefined because the count operation is executed during the oscillation stabilization time.
  - 2. This register is manipulated with a 16-bit memory manipulation instruction; however, an 8-bit memory manipulation instruction can be used. When manipulated with an 8-bit memory manipulation instruction, the accessing method should be direct addressing. This register can be accessed only in short direct addressing mode when a 16-bit memory manipulation instruction is used.
  - 3. When manipulated with an 8-bit memory manipulation instruction, readout should be performed in order from lower byte to higher byte and must be in pairs.

## (3) 16-bit capture register 20 (TCP20)

This is a 16-bit register that captures the contents of 16-bit timer counter 20 (TM20). TCP20 is set with a 16-bit memory manipulation instruction. RESET input makes this register undefined.

Caution This register is manipulated with a 16-bit memory manipulation instruction; however, an 8bit memory manipulation instruction can be used. When manipulated with an 8-bit memory manipulation instruction, the accessing method should be direct addressing. This register can be accessed only in short direct addressing mode when a 16-bit memory manipulation instruction is used.

#### (4) 16-bit counter read buffer

This buffer latches the counter value and retains the count value of 16-bit timer counter 20 (TM20).

# 6.3 Registers Controlling 16-Bit Timer 20

The following two registers control 16-bit timer 20 (TM20).

- 16-bit timer mode control register 20 (TMC20)
- Port mode register 5 (PM5)

## (1) 16-bit timer mode control register 20 (TMC20)

16-bit timer mode control register 20 (TMC20) controls the setting of the count clock, capture edge, etc. TMC20 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input clears TMC20 to 00H.

# Figure 6-2. Format of 16-Bit Timer Mode Control Register 20

| Symbol | 7     | <6>   | 5      | 4      | 3     | 2      | 1      | <0>   | Address | After reset | R/W                 |
|--------|-------|-------|--------|--------|-------|--------|--------|-------|---------|-------------|---------------------|
| TMC20  | TOD20 | TOF20 | CPT201 | CPT200 | TOC20 | TCL201 | TCL200 | TOE20 | FF5BH   | 00H         | R/W <sup>Note</sup> |

| TOD20 | Timer output data       |  |  |  |  |  |
|-------|-------------------------|--|--|--|--|--|
| 0     | Timer output data is 0. |  |  |  |  |  |
| 1     | Timer output data is 1. |  |  |  |  |  |

| TOF20 | Overflow flag set               |  |  |  |  |  |
|-------|---------------------------------|--|--|--|--|--|
| 0     | Clear by reset and software     |  |  |  |  |  |
| 1     | Set by overflow of 16-bit timer |  |  |  |  |  |

| CPT201 | CPT200 | Capture edge selection     |  |  |  |  |  |  |
|--------|--------|----------------------------|--|--|--|--|--|--|
| 0      | 0      | Capture operation disabled |  |  |  |  |  |  |
| 0      | 1      | Rising edge of CPT2        |  |  |  |  |  |  |
| 1      | 0      | Falling edge of CPT2       |  |  |  |  |  |  |
| 1      | 1      | Both edges of CPT2         |  |  |  |  |  |  |

| TOC20 | Timer output data inversion control |
|-------|-------------------------------------|
| 0     | Inversion disabled                  |
| 1     | Inversion enabled                   |

| TCL201           | TCL200 | 16-bit timer counter 20 count clock selection |
|------------------|--------|-----------------------------------------------|
| 0                | 0      | fx/2² (1.25 MHz)                              |
| 0                | 1      | fx/2 <sup>6</sup> (78.1 kHz)                  |
| Other than above |        | Setting prohibited                            |

| TOE20 | 16-bit timer 20 output control |  |  |  |  |
|-------|--------------------------------|--|--|--|--|
| 0     | Output disabled (port mode)    |  |  |  |  |
| 1     | Output enabled                 |  |  |  |  |

Note Bit 7 is read-only.

Remarks 1. fx: System clock oscillation frequency

**2.** The parenthesized values apply to operation at fx = 5.0 MHz.

# (2) Port mode register 5 (PM5)

This register sets the input/output of port 5 in 1-bit units. To use the P51/TO2 pin for timer output, set PM51 and the output latch of P51 to 0. PM5 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets PM5 to FFH.

# Figure 6-3. Format of Port Mode Register 5



| PM51 | P51 pin I/O mode selection     |  |  |  |  |
|------|--------------------------------|--|--|--|--|
| 0    | Output mode (output buffer on) |  |  |  |  |
| 1    | Input mode (output buffer off) |  |  |  |  |

# 6.4 Operation of 16-Bit Timer 20

## 6.4.1 Operation as timer interrupt

16-bit timer 20 can generate interrupts repeatedly each time the free-running counter value reaches the value set to CR20. Since this counter is not cleared and holds the count even after an interrupt is generated, the interval time is equal to one cycle of the count clock set in TCL201 and TCL200.

To operate 16-bit timer 20 as a timer interrupt, the following settings are required.

- Set count values in CR20
- Set 16-bit timer mode control register 20 (TMC20) as shown in Figure 6-4.

## Figure 6-4. Settings of 16-Bit Timer Mode Control Register 20 for Timer Interrupt Operation



#### Caution If both the CPT201 and CPT200 flags are set to 0, the operation of the capture edge is disabled.

When the count value of 16-bit timer counter 20 (TM20) matches the value set to CR20, counting of TM20 continues and an interrupt request signal (INTTM2) is generated.

Table 6-2 shows the interval time, and Figure 6-5 shows the timing of the timer interrupt operation.

## Caution Perform the following processing when rewriting CR20 during a count operation.

- <1> Disable interrupts (TMMK20 (bit 7 of interrupt mask flag register 1 (MK1)) = 1).
- <2> Disable inversion control of timer output data (TOC20 = 0).
  - If CR20 is rewritten with interrupts enabled, an interrupt request may be generated immediately.

| TCL201           | TCL200 | Count Clock                  | Interval Time                  |
|------------------|--------|------------------------------|--------------------------------|
| 0                | 0      | 2²/fx (0.8 μs)               | 2 <sup>18</sup> /fx (52.4 ms)  |
| 0                | 1      | 2 <sup>6</sup> /fx (12.8 μs) | 2 <sup>22</sup> /fx (838.9 ms) |
| Other than above |        | Setting prohibited           |                                |

#### Table 6-2. Interval Time of 16-Bit Timer 20

Remarks 1. fx: System clock oscillation frequency

2. The parenthesized values apply to operation at fx = 5.0 MHz.



Figure 6-5. Timer Interrupt Operation Timing



## 6.4.2 Operation as timer output

16-bit timer 20 can invert the timer output repeatedly each time the free-running counter value reaches the value set to CR20. Since this counter is not cleared and holds the count even after the timer output is inverted, the interval time is equal to one cycle of the count clock set in TCL201 and TCL200.

To operate 16-bit timer 20 as a timer output, the following settings are required.

- Set P51 to output mode (PM51 = 0).
- Set 0 to the output latch of P51.
- Set the count value in CR20.
- Set 16-bit timer mode control register 20 (TMC20) as shown in Figure 6-6.

#### Figure 6-6. Settings of 16-Bit Timer Mode Control Register 20 for Timer Output Operation



## Caution If both the CPT201 and CPT200 flags are set to 0, the operation of the capture edge is disabled.

When the count value of 16-bit timer counter 20 (TM20) matches the value set in CR20, the output status of the TO2/P51 pin is inverted. This enables timer output. At that time, TM20 counting continues and an interrupt request signal (INTTM2) is generated.

Figure 6-7 shows the timing of timer output (see Table 6-2 for the interval time of the 16-bit timer).



Figure 6-7. Timer Output Timing

Note The TO2 initial value becomes low level during output enable (TOE20 = 1).

**Remark** N = 0000H to FFFFH

## 6.4.3 Capture operation

The capture operation functions to capture and latch the count value of 16-bit timer counter 20 (TM20) synchronized with a capture trigger.

Set as shown in Figure 6-8 to allow 16-bit timer 20 to start the capture operation.

#### Figure 6-8. Settings of 16-Bit Timer Mode Control Register 20 for Capture Operation



16-bit capture register 20 (TCP20) starts a capture operation after the CPT2 capture trigger edge is detected, and latches and retains the count value of 16-bit timer counter 20. TCP20 fetches the count value within 2 clocks and retains the count value until the next capture edge detection.

Table 6-3 and Figure 6-9 show the settings of the capture edge and the capture operation timing, respectively.

# CPT201CPT200Capture Edge Selection00Capture operation disabled01CPT2 pin rising edge10CPT2 pin falling edge11CPT2 pin both edges

#### Table 6-3. Settings of Capture Edge

Caution Because TCP20 is rewritten when a capture trigger edge is detected during TCP20 read, disable capture trigger edge detection during TCP20 read.

Figure 6-9. Capture Operation Timing (Both Edges of CPT2 Pin Are Specified)



## 6.4.4 16-bit timer counter 20 readout

The count value of 16-bit timer counter 20 (TM20) is read out by a 16-bit manipulation instruction.

TM20 readout is performed via a counter read buffer. The counter read buffer latches the TM20 count value. The buffer operation is then held pending at the CPU clock falling edge after the read signal of the TM20 lower byte rises and the count value is retained. The counter read buffer value in the retention state can be read out as the count value.

Cancellation of pending is performed at the CPU clock falling edge after the read signal of the TM20 higher byte falls.

RESET input clears TM20 to 0000H and starts freerunning.

Figure 6-10 shows the timing of 16-bit timer counter 20 readout.

- Cautions 1. The count value after releasing stop becomes undefined because the count operation is executed during the oscillation stabilization time.
  - 2. Though TM20 is a dedicated 16-bit transfer instruction register, an 8-bit transfer instruction can be used.

When using an 8-bit transfer instruction, execute by direct addressing.

3. When using an 8-bit transfer instruction, execute in order from lower byte to higher byte in pairs. If the only lower byte is read, the pending state of the counter read buffer is not canceled, and if the only higher byte is read, an undefined count value is read.

| CPU clock         |                   |
|-------------------|-------------------|
| Count clock       |                   |
| TM20              | <u> </u>          |
| Count read buffer |                   |
| TM20 read signal  |                   |
|                   | Read signal latch |

Figure 6-10. Readout Timing of 16-Bit Timer Counter 20

## 6.5 Notes on Using 16-Bit Timer 20

#### 6.5.1 Restrictions when rewriting 16-bit compare register 20

(1) Disable interrupts (TMMK20 = 1) and the inversion control of timer output (TOC20 = 0) before rewriting the compare register (CR20).

If CR20 is rewritten with interrupts enabled, an interrupt request may be generated immediately.

(2) Depending on the timing of rewriting the compare register (CR20), the interval time may become twice as long as the intended time. Similarly, a shorter waveform or twice-longer waveform than the intended timer output waveform may be output.

To avoid this problem, rewrite the compare register using either of the following procedures.

<Countermeasure A> When rewriting using 8-bit access

- <1> Disable interrupts (TMMK20 = 1) and the inversion control of timer output (TOC20 = 0).
- <2> First rewrite the higher 1 byte of CR20 (16 bits).
- <3> Then rewrite the lower 1 byte of CR20 (16 bits).
- <4> Clear the interrupt request flag (TMIF20).
- <5> Enable timer interrupts/timer output inversion after half a cycle or more of the count clock has elapsed from the beginning of the interrupt.

#### <Program example A> (count clock = 64/fx, CPU clock = fx)

| TM20_VCT: SET1 | TMMK20    | ; | Disable timer interrupts (6 clocks)             |   |                      |
|----------------|-----------|---|-------------------------------------------------|---|----------------------|
| CLR1           | TMC20.3   | ; | Disable timer output inversion (6 clocks)       |   |                      |
| MOV            | A,#xxH    | ; | Set the rewrite value of higher byte (6 clocks) |   |                      |
| MOV            | !0FF17H,A | ; | Rewrite CR20 higher byte (8 clocks)             |   | Total: 32 clocks or  |
| MOV            | A,#yyH    | ; | Set the rewrite value of lower byte (6 clocks)  |   | more <sup>Note</sup> |
| MOV            | !OFF16H,A | ; | Rewrite CR20 lower byte (8 clocks)              |   |                      |
| CLR1           | TMIF20    | ; | Clear interrupt request flag (6 clocks)         |   |                      |
| CLR1           | TMMK20    | ; | Enable timer interrupts (6 clocks)              |   |                      |
| SET1           | TMC20.3   | ; | Enable timer output inversion                   | J |                      |

**Note** Because the INTTM2 signal becomes high level for half a cycle of the count clock after an interrupt is generated, the output is inverted if TOC20 is set to 1 during this period.

- <Countermeasure B> When rewriting using 16-bit access
- <1> Disable interrupts (TMMK20 = 1) and the inversion control of timer output (TOC20 = 0).
- <2> Rewrite CR20 (16 bits).
- <3> Wait for one cycle or more of the count clock.
- <4> Clear the interrupt request flag (TMIF20).
- <5> Enable timer interrupts/timer output inversion.

<Program example B> (count clock = 64/fx, CPU clock = fx)

| TM20_VCT | SET1 | TMMK20    |   | Disable timer interrupts                                |
|----------|------|-----------|---|---------------------------------------------------------|
|          | CLR1 | TMC20.3   | ; | Disable timer output inversion                          |
|          | MOVW | AX,#xxyyH | ; | Set the rewrite value of CR20                           |
|          | MOVW | CR20,AX   | ; | Rewrite CR20                                            |
|          | NOP  | )         |   |                                                         |
|          | NOP  |           |   |                                                         |
|          | :    | >         | ; | 32 NOP instructions (wait for $64/fx$ ) <sup>Note</sup> |
|          | NOP  |           |   |                                                         |
|          | NOP  | J         |   |                                                         |
|          | CLR1 | TMIF20    | ; | Clear interrupt request flag                            |
|          | CLR1 | TMMK20    | ; | Enable timer interrupts                                 |
|          | SET1 | TMC20.3   | ; | Enable timer output inversion                           |

**Note** Clear the interrupt request flag (TMIF20) after waiting for one cycle or more of the count clock from the instruction rewriting CR20 (MOVW CR20, AX).

# CHAPTER 7 8-BIT TIMER/EVENT COUNTER 00

## 7.1 Functions of 8-Bit Timer/Event Counter 00

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

- Interval timer
- External event counter
- Square wave output

#### (1) 8-bit interval timer

When 8-bit timer/event counter 00 is used as an interval timer, it generates an interrupt at any time interval set in advance.

#### Table 7-1. Interval Time of 8-Bit Timer/Event Counter 00

| Minimum Interval Time  | Maximum Interval Time         | Resolution                  |  |
|------------------------|-------------------------------|-----------------------------|--|
| 1/fx (200 ns)          | 2 <sup>8</sup> /fx (51.2 μs)  | 1/fx (200 ns)               |  |
| 2⁵/fx (6.4 <i>μ</i> s) | 2 <sup>13</sup> /fx (1.64 ms) | 2 <sup>5</sup> /fx (6.4 μs) |  |

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

**2.** The parenthesized values apply to operation at fx = 5.0 MHz.

#### (2) External event counter

The number of pulses of an externally input signal can be measured.

#### (3) Square wave output

A square wave of arbitrary frequency can be output.

#### Table 7-2. Square Wave Output Range of 8-Bit Timer/Event Counter 00

| Minimum Pulse Width         | Maximum Pulse Width           | Resolution                  |  |
|-----------------------------|-------------------------------|-----------------------------|--|
| 1/fx (200 ns)               | 2 <sup>8</sup> /fx (51.2 μs)  | 1/fx (200 ns)               |  |
| 2 <sup>5</sup> /fx (6.4 μs) | 2 <sup>13</sup> /fx (1.64 ms) | 2 <sup>5</sup> /fx (6.4 μs) |  |

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

**2.** The parenthesized values apply to operation at  $f_x = 5.0$  MHz.

# 7.2 Configuration of 8-Bit Timer/Event Counter 00

8-bit timer/event counter 00 consists of the following hardware.

| Item                                                                                         | Configuration                              |  |  |  |
|----------------------------------------------------------------------------------------------|--------------------------------------------|--|--|--|
| Timer counter                                                                                | 8 bits × 1 (TM00)                          |  |  |  |
| Register                                                                                     | Compare register: 8 bits $\times$ 1 (CR00) |  |  |  |
| Timer outputs                                                                                | 1 (TO0)                                    |  |  |  |
| Control registers 8-bit timer mode control register 00 (TMC00)<br>Port mode register 5 (PM5) |                                            |  |  |  |





# (1) 8-bit compare register 00 (CR00)

This is an 8-bit register that compares the value set to CR00 with the 8-bit timer register 00 (TM00) count value, and if they match, generates an interrupt request (INTTM0).

CR00 is written with an 8-bit memory manipulation instruction. Values from 00H to FFH can be set. RESET input makes CR00 undefined.

Caution Before rewriting CR00, stop the timer operation. If CR00 is rewritten while the timer operation is enabled, the match interrupt request signal may be generated immediately.

## (2) 8-bit timer counter 00 (TM00)

This is an 8-bit register that counts pulses. TM00 is read with an 8-bit memory manipulation instruction. RESET input clears TM00 to 00H.

# 7.3 Registers Controlling 8-Bit Timer/Event Counter 00

The following two registers are used to control 8-bit timer/event counter 00.

- 8-bit timer mode control register 00 (TMC00)
- Port mode register 5 (PM5)

## (1) 8-bit timer mode control register 00 (TMC00)

TMC00 determines whether to enable or disable 8-bit timer counter 00 (TM00), specifies the count clock for TM00, and controls the operation of the output controller of 8-bit timer/event counter 00. TMC00 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input clears TMC00 to 00H.

## Figure 7-2. Format of 8-Bit Timer Mode Control Register 00

| Symbol | <7>   | 6 | 5 | 4 | 3 | 2      | 1      | <0>   | Address | After reset | R/W |
|--------|-------|---|---|---|---|--------|--------|-------|---------|-------------|-----|
| TMC00  | TCE00 | 0 | 0 | 0 | 0 | TCL001 | TCL000 | TOE00 | FF53H   | 00H         | R/W |

| TCE00 | 8-bit timer counter 00 operation control  |  |  |
|-------|-------------------------------------------|--|--|
| 0     | Operation disabled (TM00 is cleared to 0) |  |  |
| 1     | Operation enabled                         |  |  |

| TCL001 | TCL000 | 8-bit timer counter 00 count clock selection |
|--------|--------|----------------------------------------------|
| 0      | 0      | fx (5.0 MHz)                                 |
| 0      | 1      | fx/2 <sup>5</sup> (156 kHz)                  |
| 1      | 0      | Rising edge of TI0 <sup>Note</sup>           |
| 1      | 1      | Falling edge of TI0 <sup>Note</sup>          |

| TOE00 | 8-bit timer/event counter 00 output control |
|-------|---------------------------------------------|
| 0     | Output disabled (port mode)                 |
| 1     | Output enabled                              |

Note When inputting a clock signal externally, timer output cannot be used.

#### Caution Always stop the timer before setting TMC00.

Remarks 1. fx: System clock oscillation frequency

**2.** The parenthesized values apply to operation at fx = 5.0 MHz.

# (2) Port mode register 5 (PM5)

This register sets port 5 input/output in 1-bit units. When using the P50/TI0/TO0 pin for timer output, set PM50 and the output latch of P50 to 0. PM5 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets PM5 to FFH.

## Figure 7-3. Format of Port Mode Register 5



| PM50 | P50 pin I/O mode selection     |  |  |
|------|--------------------------------|--|--|
| 0    | Output mode (output buffer on) |  |  |
| 1    | Input mode (output buffer off) |  |  |

## 7.4 Operation of 8-Bit Timer/Event Counter 00

#### 7.4.1 Operation as interval timer

The interval timer repeatedly generates an interrupt at time intervals specified by the count value set to 8-bit compare register 00 (CR00) in advance.

To operate 8-bit timer/event counter 00 as an interval timer, the following settings are required.

- <1> Disable the operation of 8-bit timer counter 00 (TM00) (TCE00 (bit 7 of 8-bit timer mode control register 00 (TMC00)) = 0).
- <2> Set the count clock of 8-bit timer/event counter 00 (see Table 7-4).
- <3> Set a count value in CR00.
- <4> Enable the operation of TM00 (TCE00 = 1).

When the count value of 8-bit timer counter 00 (TM00) matches the value set to CR00, the value of TM00 is cleared to 0 and TM00 continues counting. At the same time, an interrupt request signal (INTTM0) is generated. Table 7-4 shows the interval time, and Figure 7-4 shows the timing of interval timer operation.

- Cautions 1. Before rewriting CR00, stop the timer operation. If CR00 is rewritten while the timer operation is enabled, the match interrupt request signal may be generated immediately.
  - 2. If setting the count clock in TMC00 and enabling the operation of TM00 are performed at the same time with an 8-bit memory manipulation instruction, the error one cycle after the timer has been started may exceed one clock. To use 8-bit timer/event counter 00 as an interval timer, therefore, perform the setting in the above sequence.

| TCL001 | TCL000 | Minimum Interval Time       | Maximum Interval Time         | Resolution                  |
|--------|--------|-----------------------------|-------------------------------|-----------------------------|
| 0      | 0      | 1/fx (200 ns)               | 2 <sup>8</sup> /fx (51.2 μs)  | 1/fx (200 ns)               |
| 0      | 1      | 2 <sup>5</sup> /fx (6.4 μs) | 2 <sup>13</sup> /fx (1.64 ms) | 2 <sup>5</sup> /fx (6.4 μs) |
| 1      | 0      | TI0 input cycle             | $2^8 \times TI0$ input cycle  | TI0 input edge cycle        |
| 1      | 1      | TI0 input cycle             | $2^8 \times TI0$ input cycle  | TI0 input edge cycle        |

Table 7-4. Interval Time of 8-Bit Timer/Event Counter 00

Remarks 1. fx: System clock oscillation frequency

**2.** The parenthesized values apply to operation at fx = 5.0 MHz.



Figure 7-4. Interval Timer Operation Timing

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

## 7.4.2 Operation as external event counter

The external event counter counts the number of external clock pulses input to the TI0/P50/TO0 pin by using timer counter 00 (TM00).

To operate 8-bit timer/event counter 00 as an external event counter, the following settings are required.

- **<1>** Set P50 to input mode (PM50 = 1).
- <2> Disable the operation of 8-bit timer counter 00 (TM00) (TCE00 (bit 7 of 8-bit timer mode control register 00 (TMC00)) = 0).
- <3> Specify the rising or falling edge of TI0 (see Table 7-4).
- <4> Set a count value in CR00.
- **<5>** Enable the operation of TM00 (TCE00 = 1).

Each time the valid edge specified by the bit 1 or 2 (TCL001 or TCL000) of TMC00 is input, the value of 8-bit timer counter 00 (TM00) is incremented.

When the count value of TM00 matches the value set to CR00, the value of TM00 is cleared to 0 and TM00 continues counting. At the same time, an interrupt request signal (INTTM0) is generated.

Figure 7-5 shows the timing of external event counter operation (with rising edge specified).

- Cautions 1. Before rewriting CR00, stop the timer operation. If CR00 is rewritten while the timer operation is enabled, the match interrupt request signal may be generated immediately.
  - 2. If setting the count clock in TMC00 and enabling the operation of TM00 are performed at the same time with an 8-bit memory manipulation instruction, the error one cycle after the timer has been started may exceed one clock. To use 8-bit timer/event counter 00 as an external event counter, therefore, perform the setting in the above sequence.



Figure 7-5. External Event Counter Operation Timing (with Rising Edge Specified)

**Remark** N = 00H to FFH
#### 7.4.3 Operation as square wave output

8-bit timer/event counter 00 can generate a square wave output of arbitrary frequency at intervals specified by the count value set to 8-bit compare register 00 (CR00) in advance.

To operate 8-bit timer/event counter 00 as a square wave output, the following settings are required.

- **<1>** Set P50 to output mode (PM50 = 0).
- <2> Set 0 to the output latch of P50.
- <3> Disable the operation of 8-bit timer counter 00 (TM00) (TCE00 (bit 7 of 8-bit timer mode control register 00 (TMC00)) = 1).
- <4> Set the count clock for 8-bit timer/event counter 00 and enable output of TO0 (TOE00 (bit 0 of TMC00) = 1).
- <5> Set a count value in CR00.
- <6> Enable the operation of TM00 (TCE00 = 1).

When the count value of 8-bit timer counter 00 (TM00) matches the value set in CR00, the TO0/P50/TI0 pin output is inverted. Through application of this mechanism, square waves of any frequency can be output. As soon as a match occurs, the TM00 value is cleared to 0 then TM00 resumes counting, generating an interrupt request signal (INTTM0).

Setting bit 7 in TMC00 (TCE00) to 0 clears the square-wave output to 0.

Table 7-5 lists the square wave output range, and Figure 7-6 shows the timing of square wave output.

# Cautions 1. Before rewriting CR00, stop the timer operation. If CR00 is rewritten while the timer operation is enabled, the match interrupt request signal may be generated immediately.

2. If setting the count clock in TMC00 and enabling the operation of TM00 are performed at the same time with an 8-bit memory manipulation instruction, the error one cycle after the timer has been started may exceed one clock. To use 8-bit timer/event counter 00 as a square wave output, therefore, perform the setting in the above sequence.

| TCL001 | TCL000 | Minimum Pulse Width    | Maximum Pulse Width           | Resolution             |  |
|--------|--------|------------------------|-------------------------------|------------------------|--|
| 0      | 0      | 1/fx (200 ns)          | 2 <sup>8</sup> /fx (51.2 μs)  | 1/fx (200 ns)          |  |
| 0      | 1      | 2⁵/fx (6.4 <i>µ</i> s) | 2 <sup>13</sup> /fx (1.64 ms) | 2⁵/fx (6.4 <i>μ</i> s) |  |

 Table 7-5.
 Square Wave Output Range of 8-Bit Timer/Event Counter 00

Remarks 1. fx: System clock oscillation frequency

2. The parenthesized values apply to operation at fx = 5.0 MHz.



Figure 7-6. Square Wave Output Timing

Note The initial value of TO0 at output enable (TOE00 = 1) becomes low level.

# 7.5 Notes on Using 8-Bit Timer/Event Counter 00

### (1) Error on starting timer

An error of up to 1 clock occurs after the timer has been started until a match signal is generated. This is because 8-bit timer counter 00 (TM00) is started asynchronously to the count pulse.





### (2) Setting of 8-bit compare register

8-bit compare register 00 (CR00) can be set to 00H.

Therefore, one pulse can be counted when 8-bit timer/event counter 00 operates as an event counter.



### Figure 7-8. One Pulse Count Operation Timing

# **CHAPTER 8 WATCHDOG TIMER**

# 8.1 Functions of Watchdog Timer

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 RESET signal can be generated.

| Inadvertent Loop<br>Detection Time | At fx = 5.0 MHz |
|------------------------------------|-----------------|
| $2^{11} \times 1/fx$               | 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/fx$               | 26.2 ms         |

#### Table 8-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 |
|-----------------------|-----------------|
| $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 8-2. Interval Time

fx: System clock oscillation frequency

# 8.2 Configuration of Watchdog Timer

The watchdog timer consists of the following hardware.

### Table 8-3. Configuration of Watchdog Timer

| Item              | Configuration                        |  |  |  |  |
|-------------------|--------------------------------------|--|--|--|--|
| Control registers | Timer clock select register 2 (TCL2) |  |  |  |  |
|                   | Watchdog timer mode register (WDTM)  |  |  |  |  |





# 8.3 Registers Controlling Watchdog Timer

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

- Timer clock select register 2 (TCL2)
- Watchdog timer mode register (WDTM)

# (1) Timer clock select register 2 (TCL2)

This register sets the watchdog timer count clock. TCL2 is set with an 8-bit memory manipulation instruction. RESET input clears TCL2 to 00H.

# Figure 8-2. Format of Timer Clock Select Register 2

| Symbol | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|-------|-------|-------|---------|-------------|-----|
| TCL2   | 0 | 0 | 0 | 0 | 0 | TCL22 | TCL21 | TCL20 | FF42H   | 00H         | R/W |

| TCL22            | TCL21 | TCL20 | Watchdog timer count clock selection | Interval time                 |
|------------------|-------|-------|--------------------------------------|-------------------------------|
| 0                | 0     | 0     | fx/2 <sup>4</sup> (312.5 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) |
| Other than above |       |       | Setting prohibited                   |                               |

Remarks 1. fx: System clock oscillation frequency

**2.** The parenthesized values apply to operation at 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 with a 1-bit or 8-bit memory manipulation instruction. RESET input clears WDTM to 00H.

#### Figure 8-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 |

| RUN | Watchdog timer operation selection <sup>Note 1</sup> |  |  |  |
|-----|------------------------------------------------------|--|--|--|
| 0   | Stop counting.                                       |  |  |  |
| 1   | Clear counter and start counting.                    |  |  |  |

| WDTM4 | WDTM3 | Watchdog timer operation mode selection <sup>Note 2</sup>           |
|-------|-------|---------------------------------------------------------------------|
| 0     | 0     | Operation stop                                                      |
| 0     | 1     | Interval 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 operation 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 timer clock select register 2 (TCL2).
  - 2. In watchdog timer mode 1 or 2, set WDTM4 to 1 after confirming that TMIF4 (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 TMIF4 is 1, a non-maskable interrupt occurs at the completion of rewriting.

# 8.4 Operation of Watchdog Timer

#### 8.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 (TCL20 to TCL22) of timer clock select register 2 (TCL2). 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 by the 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.

| TCL22 | TCL21 | TCL20 | Inadvertent Loop Detection Time | At fx = 5.0 MHz |
|-------|-------|-------|---------------------------------|-----------------|
| 0     | 0     | 0     | $2^{11} \times 1/fx$            | 410 <i>µ</i> s  |
| 0     | 1     | 0     | $2^{13} \times 1/fx$            | 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 8-4. Inadvertent Loop Detection Time of Watchdog Timer

fx: System clock oscillation frequency

#### 8.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 (TCL20 to TCL22) of timer clock select register 2 (TCL2). 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 (TMMK4) 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.

| TCL22 | TCL21 | TCL20 | 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/fx$  | 26.2 ms         |

 Table 8-5.
 Interval Time of Interval Timer

fx: System clock oscillation frequency

# CHAPTER 9 SERIAL INTERFACE 00

# 9.1 Functions of Serial Interface 00

Serial interface 00 employs the following three modes.

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

#### (1) Operation stop mode

This mode is used when serial transfer is not carried out. It enables power consumption reduction.

#### (2) Asynchronous serial interface (UART) mode

In this mode, one byte of data following the start bit is transmitted/received, and full-duplex operation is possible.

A UART-dedicated baud rate generator is incorporated, allowing communication over a wide range of baud rates. In addition, the baud rate can be defined by dividing the clock input to the ASCK pin.

#### (3) 3-wire serial I/O mode (MSB/LSB start bit switchable)

In this mode, 8-bit data transfer is carried out with three lines, one for the serial clock (SCK0) and two for serial data (SI0, SO0).

The 3-wire serial I/O mode supports simultaneous transmit and receive operations, reducing data transfer processing time.

It is possible to switch the start bit of 8-bit data to be transmitted between the MSB and the LSB, thus allowing connection to devices with either start bit.

The 3-wire serial I/O mode is effective for connecting display controllers and peripheral I/Os such as the 75XL Series, 78K Series, and 17K Series, which have a conventional on-chip synchronous serial interface.

#### 9.2 Configuration of Serial Interface 00

Serial interface 00 consists of the following hardware.

| Item              | Configuration                                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | Transmit shift register 00 (TXS00)<br>Receive shift register 00 (RXS00)<br>Receive buffer register 00 (RXB00)                                                                                                          |
| Control registers | Serial operation mode register 00 (CSIM00)<br>Asynchronous serial interface mode register 00 (ASIM00)<br>Asynchronous serial interface status register 00 (ASIS00)<br>Baud rate generator control register 00 (BRGC00) |

# Table 9-1. Configuration of Serial Interface 00



Figure 9-1. Block Diagram of Serial Interface 00



#### (1) Transmit shift register 00 (TXS00)

This register is used to specify data to be transmitted. Data written to TXS00 is transmitted as serial data. If the data length is specified as 7 bits, bits 0 to 6 of the data written to TXS00 are transferred as the transmit data. The transmit operation is started by writing data to TXS00.

TXS00 is written to with an 8-bit memory manipulation instruction. It cannot be read. RESET input sets TXS00 to FFH.

#### Caution Do not write to TXS00 during transmission.

TXS00 and receive buffer register 00 (RXB00) are allocated to the same address, and when reading is performed, RXB00 values are read.

#### (2) Receive shift register 00 (RXS00)

This register is used to convert serial data input to the RxD pin into parallel data. Each time one byte of data is received, it is transferred to receive buffer register 00 (RXB00). RXS00 cannot be manipulated directly by program.

#### (3) Receive buffer register 00 (RXB00)

This register is used to hold received data. Each time one byte of data is received, a new byte of data is transferred from receive shift register 00 (RXS00).

If the data length is specified as 7 bits, receive data is transferred to bits 0 to 6 of RXB00, and the MSB of RXB00 always becomes 0.

RXB00 can be read with an 8-bit memory manipulation instruction. It cannot be written to. RESET input makes RXB00 undefined.

# Caution RXB00 and transmit shift register 00 (TXS00) are allocated to the same address, and when writing is performed, the values are written to TXS00.

#### (4) Transmit controller

This circuit controls transmit operations by adding a start bit, parity bit, and stop bit to data written to transmit shift register 00 (TXS00), according to the data set to asynchronous serial interface mode register 00 (ASIM00).

#### (5) Receive controller

This circuit controls receive operations according to the data set to asynchronous serial interface mode register 00 (ASIM00). It performs also parity error check, etc., during receive operations, and when an error is detected, it sets the value to asynchronous serial interface status register 00 (ASIS00) depending on the nature of the error.

# 9.3 Registers Controlling Serial Interface 00

The following four registers are used to control serial interface 00.

- Serial operation mode register 00 (CSIM00)
- Asynchronous serial interface mode register 00 (ASIM00)
- Asynchronous serial interface status register 00 (ASIS00)
- Baud rate generator control register 00 (BRGC00)

# (1) Serial operation mode register 00 (CSIM00)

This register is set when using serial interface 00 in the 3-wire serial I/O mode. CSIM00 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input clears CSIM00 to 00H.

#### Figure 9-3. Format of Serial Operation Mode Register 00

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2     | 1      | 0 | Address | After reset | R/W |
|--------|--------|---|---|---|---|-------|--------|---|---------|-------------|-----|
| CSIM00 | CSIE00 | 0 | 0 | 0 | 0 | DIR00 | CSCK00 | 0 | FF72H   | 00H         | R/W |

| CSIE | E00 | Operation control in 3-wire serial I/O mode |
|------|-----|---------------------------------------------|
| 0    |     | Operation stopped                           |
| 1    |     | Operation enabled                           |

| DIR00 | Start bit specification |
|-------|-------------------------|
| 0     | MSB                     |
| 1     | LSB                     |

| CSCK00 | Clock selection in 3-wire serial I/O mode |  |  |  |  |  |  |  |  |  |
|--------|-------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0      | Input clock to SCK0 pin from external     |  |  |  |  |  |  |  |  |  |
| 1      | Dedicated baud rate generator output      |  |  |  |  |  |  |  |  |  |

#### Cautions 1. Be sure to set bits 0 and 3 to 6 to 0.

2. Set CSIM00 to 00H in the UART mode.

# (2) Asynchronous serial interface mode register 00 (ASIM00)

This register is set when using serial interface 00 in the asynchronous serial interface mode. ASIM00 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input clears ASIM00 to 00H.

### Figure 9-4. Format of Asynchronous Serial Interface Mode Register 00

| Symbol | <7>   | <6>   | 5     | 4     | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|------|------|---|---|---------|-------------|-----|
| ASIM00 | TXE00 | RXE00 | PS001 | PS000 | CL00 | SL00 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE00 | Transmit operation control |
|-------|----------------------------|
| 0     | Transmit operation stopped |
| 1     | Transmit operation enabled |

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

| PS001 | PS000 | 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                                                                                                |

| CL00 | Character length specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

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

Cautions 1. Be sure to set bits 0 and 1 to 0.

- 2. Set ASIM00 to 00H in the 3-wire serial I/O mode.
- 3. Switching operating modes must be performed after the serial transmit/receive operation has been stopped.

# Table 9-2. Operating Mode Settings of Serial Interface 00

# (1) Operation stop mode

| ASI              | ASIM00 CSIM00 |        |       | PM22   | P22                      | PM21                   | P21                      | PM20                   | P20                    | Start                    | Shift | P22/SI0/RxD | P21/SO0/TxD  | P20/SCK0/ASCK |              |
|------------------|---------------|--------|-------|--------|--------------------------|------------------------|--------------------------|------------------------|------------------------|--------------------------|-------|-------------|--------------|---------------|--------------|
| TXE00            | RXE00         | CSIE00 | DIR00 | CSCK00 |                          |                        |                          |                        |                        |                          | Bit   | Clock       | Pin Function | Pin Function  | Pin Function |
| 0                | 0             | 0      | ×     | ×      | $\times^{\rm Note \; 1}$ | $\times^{\rm Note  1}$ | $\times^{\rm Note \; 1}$ | $\times^{\rm Note  1}$ | $\times^{\rm Note  1}$ | $\times^{\rm Note \; 1}$ | Ι     | Ι           | P22          | P21           | P20          |
| Other than above |               |        |       |        |                          |                        |                          |                        |                        |                          | Setti | ng pro      | hibited      |               |              |

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

| ASI   | ASIM00 CSIM00    |        | PM22  | P22    | PM21                | P21                 | PM20 | P20 | Start | Shift | P22/SI0/RxD | P21/SO0/TxD       | P20/SCK0/ASCK         |                      |              |
|-------|------------------|--------|-------|--------|---------------------|---------------------|------|-----|-------|-------|-------------|-------------------|-----------------------|----------------------|--------------|
| TXE00 | RXE00            | CSIE00 | DIR00 | CSCK00 |                     |                     |      |     |       |       | Bit         | Clock             | Pin Function          | Pin Function         | Pin Function |
| 0     | 0                | 1      | 0     | 0      | 1 <sup>Note 2</sup> | × <sup>Note 2</sup> | 0    | 1   | 1     | ×     |             | External<br>clock | SI0 <sup>Note 2</sup> | SO0<br>(CMOS output) | SCK0 input   |
|       |                  |        |       | 1      |                     |                     |      |     | 0     | 1     |             | Internal<br>clock |                       |                      | SCK0 output  |
|       |                  | 1      | 1     | 0      |                     |                     |      |     | 1     | ×     |             | External<br>clock |                       |                      | SCK0 input   |
|       |                  |        |       | 1      |                     |                     |      |     | 0     | 1     |             | Internal<br>clock |                       |                      | SCK0 output  |
|       | Other than above |        |       |        |                     |                     |      |     |       |       |             | ng pro            | hibited               |                      |              |

# (3) Asynchronous serial interface mode

| ASI   | M00   |        | CSIM00 |          | PM22                   | P22                    | PM21                   | P21                    | PM20                     | P20                      | Start | Shift    | P22/SI0/RxD  | P21/SO0/TxD   | P20/SCK0/ASCK |  |
|-------|-------|--------|--------|----------|------------------------|------------------------|------------------------|------------------------|--------------------------|--------------------------|-------|----------|--------------|---------------|---------------|--|
| TXE00 | RXE00 | CSIE00 | DIR00  | CSCK00   |                        |                        |                        |                        |                          |                          | Bit   | Clock    | Pin Function | Pin Function  | Pin Function  |  |
| 1     | 0     | 0      | 0      | 0        | $\times^{\rm Note  1}$ | $\times^{\rm Note  1}$ | 0                      | 1                      | 1                        | ×                        | LSB   | External | P22          | TxD           | ASCK input    |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              | (CMOS output) |               |  |
|       |       |        |        |          |                        |                        |                        |                        | $\times^{\rm Note \; 1}$ | $\times^{\rm Note \; 1}$ |       | Internal |              |               | P20           |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              |               |               |  |
| 0     | 1     | 0      | 0      | 0        | 1                      | ×                      | $\times^{\rm Note  1}$ | $\times^{\rm Note  1}$ | 1                        | ×                        |       | External | RxD          | P21           | ASCK input    |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              |               |               |  |
|       |       |        |        |          |                        |                        |                        |                        | $\times^{\rm Note \; 1}$ | $\times^{\rm Note \; 1}$ |       | Internal |              |               | P20           |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              |               |               |  |
| 1     | 1     | 0      | 0      | 0        | 1                      | ×                      | 0                      | 1                      | 1                        | ×                        |       | External |              | TxD           | ASCK input    |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              | (CMOS output) |               |  |
|       |       |        |        |          |                        |                        |                        |                        | × <sup>Note 1</sup>      | $\times^{\rm Note  1}$   |       | Internal |              |               | P20           |  |
|       |       |        |        |          |                        |                        |                        |                        |                          |                          |       | clock    |              |               |               |  |
|       |       |        | (      | Other th | an abo                 | Other than above       |                        |                        |                          |                          |       |          |              |               |               |  |

Notes 1. Can be used as port function.

2. If used only for transmission, can be used as P22 (CMOS I/O).

**Remark** ×: Don't care

# (3) Asynchronous serial interface status register 00 (ASIS00)

This register indicates the type of error when a reception error occurs in the asynchronous serial interface mode.

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

The contents of ASIS00 become undefined in the 3-wire serial I/O mode.

RESET input clears ASIS00 to 00H.

#### Figure 9-5. Format of Asynchronous Serial Interface Status Register 00

| Symbol | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|------|------|-------|---------|-------------|-----|
| ASIS00 | 0 | 0 | 0 | 0 | 0 | PE00 | FE00 | OVE00 | FF71H   | 00H         | R   |

| PE00 | Parity error flag                                                                 |  |  |  |  |  |  |  |
|------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | Parity error did not occur                                                        |  |  |  |  |  |  |  |
| 1    | Parity error occurred (when the transmit parity did not match the receive parity) |  |  |  |  |  |  |  |

| FE00 | Framing error flag                                                        |  |  |  |  |  |  |  |
|------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | Framing error did not occur                                               |  |  |  |  |  |  |  |
| 1    | Framing error occurred (when stop bit was not detected) <sup>Note 1</sup> |  |  |  |  |  |  |  |

| OVE00 | Overrun error flag                                                                                                                                    |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Overrun error did not occur                                                                                                                           |
| 1     | Overrun error occurred <sup>Note 2</sup><br>(when the next receive operation was completed before the data was read from the receive buffer register) |

- **Notes 1.** Even when the stop bit length is set to 2 bits by setting bit 2 (SL00) of asynchronous serial interface mode register 00 (ASIM00), stop bit detection in the case of reception is performed with 1 bit.
  - **2.** When an overrun error occurs, be sure to read out receive buffer register 00 (RXB00). Unless RXB00 is read out, overrun errors occur at each data reception.

### (4) Baud rate generator control register 00 (BRGC00)

This register is used to set the serial clock of serial interface 00. BRGC00 is set with an 8-bit memory manipulation instruction. RESET input clears BRGC00 to 00H.

#### Figure 9-6. Format of Baud Rate Generator Control Register 00

| Symbol | 7      | 6      | 5      | 4      | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|--------|--------|--------|--------|---|---|---|---|---------|-------------|-----|
| BRGC00 | TPS003 | TPS002 | TPS001 | TPS000 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS003 | TPS002           | TPS001 | TPS000 | Selection of baud rate generator source clock         | 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      | Clock input from external to ASCK pin <sup>Note</sup> | - |  |  |  |
|        | Other than above |        |        | Setting prohibited                                    |   |  |  |  |

Note Only used in UART mode.

- Cautions 1. When writing to BRGC00 is performed during a communication operation, the baud rate generator output is disrupted and communications cannot be performed normally. Be sure not to write to BRGC00 during a communication operation.
  - 2. Be sure not to select n = 1 during operation at  $f_x > 2.5$  MHz in UART mode because the resulting baud rate exceeds the rated range.
  - 3. When selecting the clock input from an external source, set port mode register 2 (PM2) to the input mode.

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

- **2.** n: Value determined by setting TPS000 to TPS003 ( $1 \le n \le 8$ )
- **3.** The parenthesized values apply to operation at fx = 5.0 MHz.

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

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

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

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

\*

fx: System clock oscillation frequency

n: Value determined by values of TPS000 to TPS003 as shown in Figure 9-6 ( $2 \le n \le 8$ )

| Baud Rate (bps) | n | BRGC00 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              |              |                 |

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

Caution Be sure not to select n = 1 during operation at fx > 2.5 MHz because the resulting baud rate exceeds the rated range.

#### (b) Generation of baud rate transmit/receive clock from external clock of ASCK pin

The transmit/receive clock is generated by dividing the clock input from the ASCK pin. The baud rate generated from the clock input from the ASCK pin is found from the following expression.

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

fASCK: Frequency of clock input to the ASCK pin

| Baud Rate (bps) | ASCK 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                          |

# Table 9-4. Relationship Between ASCK Pin Input Frequency and Baud Rate (When BRGC00 Is Set to 80H)

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

The serial clock is generated by dividing the system clock. The frequency of the serial clock can be obtained by the following expression. If the serial clock is externally input to the SCK0 pin, it is unnecessary to set BRGC00.

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

fx: System clock oscillation frequency

n: Values in Figure 9-6 determined by the settings of TPS000 to TPS003 ( $1 \le n \le 8$ )

# 9.4 Operation of Serial Interface 00

Serial interface 00 provides the following three modes.

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

#### 9.4.1 Operation stop mode

In the operation stop mode, serial transfer is not executed; therefore, the power consumption can be reduced. The P20/SCK0/ASCK, P21/SO0/TxD, and P22/SI0/RxD pins can be used as normal I/O ports.

#### (1) Register setting

Operation stop mode is set by serial operation mode register 00 (CSIM00) and asynchronous serial interface mode register 00 (ASIM00).

#### (a) Serial operation mode register 00 (CSIM00)

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

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2     | 1      | 0 | Address | After reset | R/W |
|--------|--------|---|---|---|---|-------|--------|---|---------|-------------|-----|
| CSIM00 | CSIE00 | 0 | 0 | 0 | 0 | DIR00 | CSCK00 | 0 | FF72H   | 00H         | R/W |

| CSIE00 | Operation control in 3-wire serial I/O mode |
|--------|---------------------------------------------|
| 0      | Operation stopped                           |
| 1      | Operation enabled                           |

Caution Be sure to set bits 0 and 3 to 6 to 0.

# (b) Asynchronous serial interface mode register 00 (ASIM00)

ASIM00 is set with a 1-bit or 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input clears ASIM00 to 00H.

| Symbol | <7>   | <6>   | 5     | 4     | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|------|------|---|---|---------|-------------|-----|
| ASIM00 | TXE00 | RXE00 | PS001 | PS000 | CL00 | SL00 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE00 | Transmit operation control |  |
|-------|----------------------------|--|
| 0     | ransmit operation stopped  |  |
| 1     | Transmit operation enabled |  |

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

Caution Be sure to set bits 0 and 1 to 0.

#### 9.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 communications at the desired transfer rate from many options. In addition, the baud rate can also be defined by dividing the clock input to the ASCK pin.

The UART-dedicated baud rate generator also can output the 31.25 kbps baud rate that complies with the MIDI standard.

#### (1) Register setting

The UART mode is set by serial operation mode register 00 (CSIM00), asynchronous serial interface mode register 00 (ASIM00), asynchronous serial interface status register 00 (ASIS00), and baud rate generator control register 00 (BRGC00).

#### (a) Serial operation mode register 00 (CSIM00)

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

Set CSIM00 to 00H when UART mode is selected.

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2     | 1      | 0 | Address | After reset | R/W |
|--------|--------|---|---|---|---|-------|--------|---|---------|-------------|-----|
| CSIM00 | CSIE00 | 0 | 0 | 0 | 0 | DIR00 | CSCK00 | 0 | FF72H   | 00H         | R/W |

| CSIE00 | Operation control in 3-wire serial I/O mode |
|--------|---------------------------------------------|
| 0      | Operation stopped                           |
| 1      | Operation enabled                           |

| DIR00 | Start bit specification |
|-------|-------------------------|
| 0     | MSB                     |
| 1     | LSB                     |

| CSCK00 | Clock selection in 3-wire serial I/O mode |  |  |  |
|--------|-------------------------------------------|--|--|--|
| 0      | ock input to SCK0 pin from external       |  |  |  |
| 1      | Dedicated baud rate generator output      |  |  |  |

Caution Be sure to set bits 0 and 3 to 6 to 0.

# (b) Asynchronous serial interface mode register 00 (ASIM00)

ASIM00 is set with a 1-bit or 8-bit memory manipulation instruction.  $\overline{\text{RESET}}$  input clears ASIM00 to 00H.

| Symbol | <7>   | <6>   | 5     | 4     | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|------|------|---|---|---------|-------------|-----|
| ASIM00 | TXE00 | RXE00 | PS001 | PS000 | CL00 | SL00 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE00 | Transmit operation control |
|-------|----------------------------|
| 0     | Transmit operation stopped |
| 1     | Transmit operation enabled |

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

| PS001 | PS000 | 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                                                                                                |

| CL00 | Character length specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

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

# Cautions 1. Be sure to set bits 0 and 1 to 0.

2. Switching operating modes must be performed after the serial transmit/receive operation has been stopped.

# (c) Asynchronous serial interface status register 00 (ASIS00)

ASIS00 is read with a 1-bit or 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input clears ASIS00 to 00H.

| Symbol | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|------|------|-------|---------|-------------|-----|
| ASIS00 | 0 | 0 | 0 | 0 | 0 | PE00 | FE00 | OVE00 | FF71H   | 00H         | R   |

| PE00 | Parity error flag                                                                 |
|------|-----------------------------------------------------------------------------------|
| 0    | Parity error did not occur                                                        |
| 1    | Parity error occurred (when the transmit parity did not match the receive parity) |

| FE00 | Framing error flag                                                        |
|------|---------------------------------------------------------------------------|
| 0    | Framing error did not occur                                               |
| 1    | Framing error occurred (when stop bit was not detected) <sup>Note 1</sup> |

| OVE00 | Overrun error flag                                                                                                                                    |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Overrun error did not occur                                                                                                                           |
| 1     | Overrun error occurred <sup>Note 2</sup><br>(when the next receive operation was completed before the data was read from the receive buffer register) |

- **Notes 1.** Even when the stop bit length is set to 2 bits by setting bit 2 (SL00) of asynchronous serial interface mode register 00 (ASIM00), stop bit detection in the case of reception is performed with 1 bit.
  - **2.** When an overrun error occurs, be sure to read out receive buffer register 00 (RXB00). Unless RXB00 is read out, overrun errors occur at each data reception.

# (d) Baud rate generator control register 00 (BRGC00)

BRGC00 is set with an 8-bit memory manipulation instruction. RESET input clears BRGC00 to 00H.

| Symbol | 7      | 6      | 5      | 4      | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|--------|--------|--------|--------|---|---|---|---|---------|-------------|-----|
| BRGC00 | TPS003 | TPS002 | TPS001 | TPS000 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS003 | TPS002           | TPS001 | TPS000 | Selection of baud rate generator source clock | 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      | Clock input from external to ASCK pin         | - |
|        | Other than above |        |        | Setting prohibited                            |   |

- Cautions 1. When writing to BRGC00 is performed during a communication operation, the baud rate generator output is disrupted and communications cannot be performed normally. Be sure not to write to BRGC00 during a communication operation.
  - 2. Be sure not to select n = 1 during operation at  $f_x > 2.5$  MHz because the resulting baud rate exceeds the rated range.
  - 3. When selecting the clock input from an external source, set port mode register 2 (PM2) to the input mode.

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

- 2. n: Value determined by setting TPS000 to TPS003 (1  $\leq$  n  $\leq$  8)
- **3.** The parenthesized values apply to operation at fx = 5.0 MHz.

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

#### (i) Generation of baud rate transmit/receive clock from 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.

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

- fx: System clock oscillation frequency
- n: Value determined by setting TPS000 to TPS003 as shown in the above table  $(2 \le n \le 8)$

×

| Baud Rate (bps) | n | BRGC00 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              |              |                 |

Table 9-5. Example of Relationship Between System Clock and Baud Rate

Caution Be sure not to select n = 1 during operation at  $f_x > 2.5$  MHz because the resulting baud rate exceeds the rated range.

#### (ii) Generation of baud rate transmit/receive clock from external clock of ASCK pin

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

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

÷

fASCK: Frequency of clock input to the ASCK pin

| Baud Rate (bps) | ASCK 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                          |

# Table 9-6. Relationship Between ASCK Pin Input Frequency and Baud Rate (When BRGC00 Is Set to 80H)

#### (2) Communication operation

#### (a) Data format

The transmit/receive data format is as shown in Figure 9-7. One data frame consists of a start bit, character bits, parity bit, and stop bit(s).

The specification of character bit length, parity selection, and specification of stop bit length for one data frame is carried out using asynchronous serial interface mode register 00 (ASIM00).

#### Figure 9-7. Format of Asynchronous Serial Interface Transmit/Receive Data

|                  |    |    |    | -  |    | ta fram |    |    |               |          |  |
|------------------|----|----|----|----|----|---------|----|----|---------------|----------|--|
| <br>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 bit..... Even parity/odd parity/0 parity/no parity
- Stop bit..... 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 ASIM00 and baud rate generator control register 00 (BRGC00).

If a serial data receive error occurs, the receive error contents can be determined by reading the status of asynchronous serial interface status register 00 (ASIS00).

#### (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

#### • At transmission

The parity bit is determined 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

#### At 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

#### At transmission

Conversely to the even parity, the parity bit is determined 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

#### • At 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 00 (TXS00). The start bit, parity bit, and stop bit(s) are added automatically.

When the transmit operation starts, the data in TXS00 is shifted out, and when TXS00 is empty, a transmission completion interrupt (INTST) is generated.



(a) Stop bit length: 1



Caution Do not rewrite asynchronous serial interface mode register 00 (ASIM00) during a transmit operation. If the ASIM00 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 (INTST) or the interrupt request flag (STIF00) set by INTST.

#### (d) Reception

When bit 6 (RXE00) of asynchronous serial interface mode register 00 (ASIM00) is set to 1, a receive operation is enabled and sampling of the RxD pin input is performed.

RxD pin input sampling is performed using the serial clock specified by ASIM00.

When the RxD 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 RxD 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 00 (RXB00), and a reception completion interrupt (INTSR) is generated.

If an error occurs, the receive data in which the error occurred is still transferred to RXB00, and INTSR is generated.

If the RXE00 bit is reset to 0 during the receive operation, the receive operation is stopped immediately. In this case, the contents of RXB00 and asynchronous serial interface status register 00 (ASIS00) are not changed, and INTSR is not generated.



Figure 9-9. Asynchronous Serial Interface Reception Completion Interrupt Timing

Caution Be sure to read receive buffer register 00 (RXB00) even if a receive error occurs. If RXB00 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. Upon data reception, an error flag is set in asynchronous serial interface status register 00 (ASIS00). Receive error causes are shown in Table 9-7.

It is possible to determine what kind of error occurred during reception by reading the contents of ASIS00 in the reception error interrupt servicing (see **Table 9-7** and **Figure 9-10**).

The contents of ASIS00 are reset to 0 by reading receive buffer register 00 (RXB00) or receiving the next data (if there is an error in the next data, the corresponding error flag is set).

| Receive Error | 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 |

Table 9-7. Receive Error Causes



- Cautions 1. The contents of the ASIS00 register are reset to 0 by reading receive buffer register 00 (RXB00) or receiving the next data. To ascertain the error contents, read ASIS00 before reading RXB00.
  - 2. Be sure to read receive buffer register 00 (RXB00) even if a receive error occurred. If RXB00 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

When the reception completion interrupt (INTSR) is generated, receive data can be read by reading the value of receive buffer register 00 (RXB00).

To read the receive data stored in receive buffer register 00 (RXB00), read while reception is enabled (RXE00 = 1).

- **Remark** However, if it is necessary to read receive data after reception has stopped (RXE00 = 0), read using either of the following methods.
  - (a) Read after setting RXE00 = 0 after waiting for one cycle or more of the source clock selected by BRGC00.
  - (b) Read after bit 2 (DIR00) of serial operation mode register 00 (CSIM00) is set to 1.

Program example of (a) (BRGC00 = 00H (source clock = fx/2))

| INTRXE:     |     |            | ; < Reception completion interrupt routine>                     |
|-------------|-----|------------|-----------------------------------------------------------------|
| NO          | Ρ   |            | ; 2 clocks                                                      |
| CLI         | R1  | RXE00      | ; Reception stopped                                             |
| MO          | V   | A,RXB00    | ; Read receive data                                             |
|             |     |            |                                                                 |
| Program exa | ımp | ole of (b) |                                                                 |
| INTRXE:     |     |            | ; <reception completion="" interrupt="" routine=""></reception> |
| SE          | г1  | CSIM00.2   | ; DIR00 flag is set to LSB first                                |
| CLI         | R1  | RXE00      | ; Reception stopped                                             |
| MO          | V   | A,RXB00    | ; Read receive data                                             |

#### (3) Cautions related to UART mode

- (a) When bit 7 (TXE00) of asynchronous serial interface mode register 00 (ASIM00) is cleared during transmission, be sure to set transmit shift register 00 (TXS00) to FFH, then set TXE00 to 1 before executing the next transmission.
- (b) When bit 6 (RXE00) of asynchronous serial interface mode register 00 (ASIM00) is cleared during reception, receive buffer register 00 (RXB00) and reception completion interrupt (INTSR) are as follows.



When RXE00 is set to 0 at the time indicated by <1>, RXB00 holds the previous data and INTSR is not generated.

When RXE00 is set to 0 at the time indicated by <2>, RXB00 renews the data and INTSR is not generated. When RXE00 is set to 0 at the time indicated by <3>, RXB00 renews the data and INTSR is generated.

#### 9.4.3 3-wire serial I/O mode

The 3-wire serial I/O mode is useful for connection of peripheral I/Os and display controllers, etc., which incorporate a conventional synchronous serial interface, such as the 75X/XL Series, 78K Series, 17K Series, etc.

Communication is performed using three lines: the serial clock (SCK0), serial output (SO0), and serial input (SI0).

#### (1) Register setting

3-wire serial I/O mode settings are performed using serial operation mode register 00 (CSIM00), asynchronous serial interface mode register 00 (ASIM00), and baud rate generator control register 00 (BRGC00).

#### (a) Serial operation mode register 00 (CSIM00)

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

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2     | 1      | 0 | Address | After reset | R/W |
|--------|--------|---|---|---|---|-------|--------|---|---------|-------------|-----|
| CSIM00 | CSIE00 | 0 | 0 | 0 | 0 | DIR00 | CSCK00 | 0 | FF72H   | 00H         | R/W |

| CSIE00 | Operation control in 3-wire serial I/O mode |  |  |  |  |  |
|--------|---------------------------------------------|--|--|--|--|--|
| 0      | Operation stopped                           |  |  |  |  |  |
| 1      | Operation enabled                           |  |  |  |  |  |

| DIR00 | Start bit specification |
|-------|-------------------------|
| 0     | MSB                     |
| 1     | LSB                     |

| CSCK00 | Clock selection in 3-wire serial I/O mode |  |  |  |  |
|--------|-------------------------------------------|--|--|--|--|
| 0      | Clock input to SCK0 pin from external     |  |  |  |  |
| 1      | Dedicated baud rate generator output      |  |  |  |  |

Caution Be sure to set bits 0 and 3 to 6 to 0.

# (b) Asynchronous serial interface mode register 00 (ASIM00)

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

When the 3-wire serial I/O mode is selected, ASIM00 must be set to 00H.

| Symbol | <7>   | <6>   | 5     | 4     | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|-------|-------|-------|-------|------|------|---|---|---------|-------------|-----|
| ASIM00 | TXE00 | RXE00 | PS001 | PS000 | CL00 | SL00 | 0 | 0 | FF70H   | 00H         | R/W |

| TXE00 | Transmit operation control |  |  |  |
|-------|----------------------------|--|--|--|
| 0     | Fransmit operation stopped |  |  |  |
| 1     | Transmit operation enabled |  |  |  |

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

| PS001 | PS000 | 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                                                                                                |

| CL00 | Character length specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

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

# Cautions 1. Be sure to set bits 0 and 1 to 0.

2. Switching operating modes must be performed after the serial transmit/receive operation has been stopped.
### (c) Baud rate generator control register 00 (BRGC00) BRGC00 is set with an 8-bit memory manipulation instruction. RESET input clears BRGC00 to 00H.

| Symbol | 7      | 6      | 5      | 4      | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|--------|--------|--------|--------|---|---|---|---|---------|-------------|-----|
| BRGC00 | TPS003 | TPS002 | TPS001 | TPS000 | 0 | 0 | 0 | 0 | FF73H   | 00H         | R/W |

| TPS003 | TPS002           | TPS001 | TPS000 | Selection of baud rate generator source clock | 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 |
|        | Other than above |        |        | Setting prohibited                            |   |

- Cautions 1. When writing to BRGC00 is performed during a communication operation, the baud rate generator output is disrupted and communications cannot be performed normally. Be sure not to write to BRGC00 during a communication operation.
  - 2. When selecting the clock input from an external source, set port mode register 2 (PM2) to the input mode.

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

- **2.** n: Value determined by setting TPS000 to TPS003 ( $1 \le n \le 8$ )
- **3.** The parenthesized values apply to operation at fx = 5.0 MHz.

If the internal clock is used as the serial clock for 3-wire serial I/O mode, set the TPS000 to TPS003 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 external, setting BRGC00 is not necessary.

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

- fx: System clock oscillation frequency
- n: Value determined by setting TPS000 to TPS003 as shown in the above table ( $1 \le n \le 8$ )

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

Transmit shift register 00 (TXS00/SIO00) and receive shift register 00 (RXS00) shift operations are performed in synchronization with the fall of the serial clock ( $\overline{SCK0}$ ). Then transmit data is held in the SO0 latch and output from the SO0 pin. Also, receive data input to the SI0 pin is latched in receive buffer register 00 (RXB00/SIO00) on the rise of  $\overline{SCK0}$ .

At the end of an 8-bit transfer, the operations of TXS00/SIO00 and RXS00 stop automatically, and the interrupt request signal (INTCSI0) is generated.



### Figure 9-11. 3-Wire Serial I/O Mode Timing

### (3) Transfer start

Serial transfer is started by setting transfer data to transmit shift register 00 (TXS00/SIO00) when the following two conditions are satisfied.

- Serial operation mode register 00 (CSIM00) bit 7 (CSIE00) = 1
- Internal serial clock is stopped or SCK0 is at high level after 8-bit serial transfer.

### Caution If CSIE00 is set to 1 after data write to TXS00/SIO00, transfer does not start.

A termination of 8-bit transfer stops the serial transfer automatically and generates the interrupt request signal (INTCSI0).

### **CHAPTER 10 INTERRUPT FUNCTIONS**

### **10.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 interrupt from the watchdog timer is the one non-maskable interrupt source.

### (2) Maskable interrupts

These interrupts undergo mask control. If two or more interrupts are simultaneously generated, each interrupt has a predetermined priority as shown in Table 10-1. A standby release signal is generated.

Maskable interrupts have four external interrupt and five internal interrupt sources.

### **10.2 Interrupt Sources and Configuration**

There are a total of ten non-maskable and maskable interrupt sources (see Table 10-1).

| Interrupt Type | Priority <sup>Note 1</sup> |         | Interrupt Source                                         | Internal/ | Vector           | Basic                                   |
|----------------|----------------------------|---------|----------------------------------------------------------|-----------|------------------|-----------------------------------------|
|                |                            | Name    | Trigger                                                  | External  | Table<br>Address | Configuration<br>Type <sup>Note 2</sup> |
| Non-maskable   | _                          | INTWDT  | Watchdog timer overflow (watchdog timer mode 1 selected) | Internal  | 0004H            | (A)                                     |
| Maskable       | 0                          | INTWDT  | Watchdog timer overflow (interval timer mode selected)   |           |                  | (B)                                     |
|                | 1                          | INTP0   | Pin input edge detection                                 | External  | 0006H            | (C)                                     |
|                | 2                          | INTP1   |                                                          |           | 0008H            |                                         |
|                | 3                          | INTP2   |                                                          |           | 000AH            |                                         |
|                | 4                          | INTSR   | End of serial interface 00 UART reception                | Internal  | 000CH            | (B)                                     |
|                |                            | INTCSI0 | End of serial interface 00 3-wire transfer               | ]         |                  |                                         |
|                | 5                          | INTST   | End of serial interface 00 UART transmission             |           | 000EH            |                                         |
|                | 6                          | INTTMO  | Generation of 8-bit timer/event counter 00 match signal  |           | 0010H            |                                         |
|                | 7                          | INTTM2  | Generation of 16-bit timer 20 match signal               |           | 0014H            |                                         |
|                | 8                          | INTKR   | Key return signal detection                              | External  | 002AH            | (C)                                     |

 Table 10-1. Interrupt Source List

- **Notes 1.** The priority is the priority applicable when two or more maskable interrupts are generated simultaneously. 0 is the highest priority and 8 is the lowest.
  - 2. Basic configuration types (A) to (C) correspond to (A) to (C) in Figure 10-1.

### Figure 10-1. Basic Configuration of Interrupt Function

### (A) Internal non-maskable interrupt



### (B) Internal maskable interrupt



### (C) External maskable interrupt



- INTMO: External interrupt mode register 0
- KRM00: Key return mode register 00
- IF: Interrupt request flag
- IE: Interrupt enable flag
- MK: Interrupt mask flag

### **10.3 Registers Controlling Interrupt Function**

The following five registers are used to control the interrupt functions.

- Interrupt request flag registers (IF0 and IF1)
- Interrupt mask flag registers (MK0 and MK1)
- External interrupt mode register 0 (INTM0)
- Program status word (PSW)
- Key return mode register 00 (KRM00)

Table 10-2 lists the interrupt request flag and interrupt mask flag names corresponding to interrupt requests.

| Interrupt Request Signal Name | Interrupt Request Flag | Interrupt Mask Flag |
|-------------------------------|------------------------|---------------------|
| INTWDT                        | TMIF4                  | TMMK4               |
| INTP0                         | PIF0                   | PMK0                |
| INTP1                         | PIF1                   | PMK1                |
| INTP2                         | PIF2                   | PMK2                |
| INTSR/INTCSI0                 | SRIF00                 | SRMK00              |
| INTST                         | STIF00                 | STMK00              |
| INTTMO                        | TMIF00                 | ТММК00              |
| INTTM2                        | TMIF20                 | ТММК20              |
| INTKR                         | KRIF00                 | KRMK00              |

### Table 10-2. Flags Corresponding to Interrupt Request Signal Names

### (1) Interrupt request flag registers (IF0 and 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 upon acknowledgement of an interrupt request, upon  $\overrightarrow{\text{RESET}}$  input, or when an instruction is executed.

IF0 and IF1 are set with a 1-bit or 8-bit memory manipulation instruction. RESET input clears IF0 and IF1 to 00H.

| Symbol | 7      | <6>    | <5>    | <4>    | <3>  | <2>  | <1>  | <0>    | Address | After reset | R/W |
|--------|--------|--------|--------|--------|------|------|------|--------|---------|-------------|-----|
| IF0    | 0      | TMIF00 | STIF00 | SRIF00 | PIF2 | PIF1 | PIF0 | TMIF4  | FFE0H   | 00H         | R/W |
|        |        |        |        |        |      |      |      |        |         |             |     |
|        | <7>    | 6      | 5      | 4      | 3    | 2    | 1    | <0>    |         |             |     |
| IF1    | TMIF20 | 0      | 0      | 0      | 0    | 0    | 0    | KRIF00 | FFE1H   | 00H         | R/W |

### Figure 10-2. Format of Interrupt Request Flag Register

| [ | ∞×IF× | Interrupt request flag                                         |
|---|-------|----------------------------------------------------------------|
|   | 0     | No interrupt request signal is generated                       |
|   | 1     | Interrupt request signal is generated; interrupt request state |

Cautions 1. Be sure to clear bit 7 of IF0 and bits 1 to 6 of IF1 to 0.

- 2. The TMIF4 flag is R/W enabled only when the watchdog timer is used as an interval timer. If watchdog timer mode 1 or 2 is used, set the TMIF4 flag to 0.
- 3. Because port 3 has an alternate function as an 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.
- 4. If an interrupt is acknowledged, the interrupt request flag is automatically cleared before the interrupt routine is entered.

### (2) Interrupt mask flag registers (MK0 and MK1)

The interrupt mask flag is used to enable/disable the corresponding maskable interrupt servicing. MK0 and MK1 are set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets MK0 and MK1 to FFH.

### Figure 10-3. Format of Interrupt Mask Flag Register

| Symbol | 7      | <6>    | <5>    | <4>    | <3>  | <2>  | <1>  | <0>    | Address | After reset | R/W |
|--------|--------|--------|--------|--------|------|------|------|--------|---------|-------------|-----|
| MK0    | 1      | ТММК00 | STMK00 | SRMK00 | PMK2 | PMK1 | PMK0 | TMMK4  | FFE4H   | FFH         | R/W |
|        |        | -      |        |        |      | -    | -    |        |         |             |     |
|        | <7>    | 6      | 5      | 4      | 3    | 2    | 1    | <0>    |         |             |     |
| MK1    | TMMK20 | 1      | 1      | 1      | 1    | 1    | 1    | KRMK00 | FFE5H   | FFH         | R/W |

| ××МК× | Interrupt servicing control  |
|-------|------------------------------|
| 0     | Interrupt servicing enabled  |
| 1     | Interrupt servicing disabled |

Cautions 1. Be sure to set bit 7 of MK0 and bits 1 to 6 of MK1 to 1.

- 2. If the TMMK4 flag is read when the watchdog timer is used in watchdog timer mode 1 or 2, its value becomes undefined.
- 3. Because port 3 has an alternate function as an 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 to INTP2. INTM0 is set with an 8-bit memory manipulation instruction. RESET input clears INTM0 to 00H.

### Figure 10-4. Format of External Interrupt Mode Register 0

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1 | 0 | Address | After reset | R/W |
|--------|------|------|------|------|------|------|---|---|---------|-------------|-----|
| INTM0  | ES21 | ES20 | ES11 | ES10 | ES01 | ES00 | 0 | 0 | FFECH   | 00H         | R/W |

| ES21 | ES20 | INTP2 valid edge selection    |
|------|------|-------------------------------|
| 0    | 0    | Falling edge                  |
| 0    | 1    | Rising edge                   |
| 1    | 0    | Setting prohibited            |
| 1    | 1    | Both rising and falling edges |

| 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 and 1 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$ ) to 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 of the interrupt requests. The IE flag to set maskable interrupt enable/disable is mapped to the PSW.

Besides 8-bit unit read/write, this register can carry out operations with bit manipulation instructions and dedicated instructions (EI and DI). When a vectored interrupt request is acknowledged, the PSW is automatically saved into a stack, and the IE flag is reset to 0. It is restored from the stack with the RETI and POP PSW instructions.

RESET input sets the PSW to 02H.

#### After reset Symbol 7 6 5 4 3 2 1 0 PSW 02H ΙE Ζ 1 СҮ 0 AC 0 0 Used when normal instruction is executed IΕ Interrupt acknowledge enable/disable Disable 0 1 Enable

### Figure 10-5. Configuration of Program Status Word

### (5) Key return mode register 00 (KRM00)

KRM00 is used to specify the pin at which a key return signal is detected.

KRM00 is set with a 1-bit or 8-bit memory manipulation instruction.

Bit 0 (KRM000) is set for the four pins from KR0/P40 to KR3/P43. Bits 4 to 7 (KRM004 to KRM007) are set in 1-bit units for pins KR4/P44 to KR7/P47, respectively.

RESET input clears KRM00 to 00H.

### Figure 10-6. Format of Key Return Mode Register 00

| Symbol | 7      | 6      | 5      | 4      | 3 | 2 | 1 | 0      | Address | After reset | R/W |
|--------|--------|--------|--------|--------|---|---|---|--------|---------|-------------|-----|
| KRM00  | KRM007 | KRM006 | KRM005 | KRM004 | 0 | 0 | 0 | KRM000 | FFF5H   | 00H         | R/W |

| KRM00n | Key return signal detection selection    |
|--------|------------------------------------------|
| 0      | Undetected                               |
| 1      | Detected (at the falling edge of port 4) |

Cautions 1. Be sure to set bits 1 to 3 to 0.

- 2. When KRM00n is set to 1, the corresponding pin is connected to a pull-up resistor unless it is in output mode. In output mode, the pull-up resistor is not connected.
- Before setting KRM00, set bit 0 of MK1 (KRMK00 = 1) to disable interrupts. To enable interrupts, clear bit 0 of IF1 (KRIF00 = 0), then bit 0 of MK1 (KRMK00 = 0).

**Remark** n = 0, 4 to 7





Note Selector used to select the pin to be used for falling edge input

### **10.4 Interrupt Servicing Operation**

### 10.4.1 Non-maskable interrupt request acknowledgement operation

The 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 the 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 10-8 shows the flowchart from non-maskable interrupt request generation to acknowledgement. Figure 10-9 shows the timing of non-maskable interrupt request acknowledgement. Figure 10-10 shows the acknowledgement operation if multiple non-maskable interrupts are generated.

# Caution During non-maskable interrupt service program execution, do not input another non-maskable interrupt request; if it is input, the service program will be interrupted and the new interrupt request will be acknowledged.





WDTM: Watchdog timer mode register WDT: Watchdog timer









### 10.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 10-3.

See Figures 10-12 and 10-13 for the interrupt request acknowledgement timing.

Table 10-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 the status in which it can be acknowledged is set.

Figure 10-11 shows the algorithm of acknowledging interrupt requests.

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 10-11. 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 10-12 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 within 3 clocks after the execution starts, the interrupt acknowledgement processing is performed after the MOV A, r instruction is completed.





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 10-13 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 are held pending while the interrupt request flag register (IF0 or IF1) or the interrupt mask flag register (MK0 or MK1) is being accessed.

### 10.4.3 Nesting processing

Nesting processing in which another interrupt is acknowledged while an interrupt is serviced can be executed by priority. 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 10-1**).

### Figure 10-14. Example of Nesting

Example 1. Nesting is acknowledged



During interrupt INTxx servicing, interrupt request INTyy is acknowledged, and nesting occurs. The EI instruction is issued before each interrupt request acknowledgement, and the interrupt request acknowledgement enable state is set.





Because interrupts are not enabled in interrupt INTxx servicing (the El instruction is not issued), interrupt request INTyy is not acknowledged, and nesting does not occur. The INTyy request is held pending and acknowledged after the INTxx servicing is performed.

IE = 0: Interrupt request acknowledgement disabled

### 10.4.4 Interrupt request hold

Some instructions may hold the acknowledgement of an interrupt request pending 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 of that instruction. These instructions (interrupt request hold instructions) are shown below.

- Manipulation instruction for interrupt request flag registers 0 and 1 (IF0 and IF1)
- Manipulation instruction for interrupt mask flag registers 0 and 1 (MK0 and MK1)

### **CHAPTER 11 STANDBY FUNCTION**

### 11.1 Standby Function and Configuration

### 11.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. The 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 the 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. The STOP mode stops the system clock oscillator and stops the entire system. The current consumption of the CPU can be substantially reduced in this mode.

Data memory can be retained at a low voltage ( $V_{DD} = 1.8 V \text{ min.}$ ). Therefore, this mode is useful for retaining the contents of the data memory with an extremely low current consumption.

The STOP mode can be released by an interrupt request, so that this mode can be used for intermittent operation. However, some time is required until the system clock oscillator stabilizes after the 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 latch of the I/O ports and output buffer are also retained.

## Caution To set the STOP mode, be sure to stop the operations of the peripheral hardware, and then execute the STOP instruction.

### 11.1.2 Standby function control register

The wait time after the STOP mode is released upon interrupt request until the oscillation stabilizes is controlled by the oscillation stabilization time select register (OSTS).

OSTS is set with an 8-bit memory manipulation instruction.

RESET input sets OSTS to 04H. However, the oscillation stabilization time after RESET input is  $2^{15}/fx$ , instead of  $2^{17}/fx$ .

Figure 11-1. Format of Oscillation Stabilization Time Select Register

| 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> /fx (819 μs)              |
| 0     | 1          | 0     | 2 <sup>15</sup> /f <sub>x</sub> (6.55 ms) |
| 1     | 0          | 0     | 2 <sup>17</sup> /fx (26.2 ms)             |
| Oth   | er than ab | ove   | Setting prohibited                        |

Caution The wait time after the 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
  - **2.** The parenthesized values apply to operation at fx = 5.0 MHz.

### 11.2 Operation of Standby Function

### 11.2.1 HALT mode

### (1) HALT mode

HALT mode is set by executing the HALT instruction. The operation status in the HALT mode is shown in the following table.

### Table 11-1. HALT Mode Operating Status

| Item                      | HALT Mode Operating Status                                      |
|---------------------------|-----------------------------------------------------------------|
| Clock generator           | System clock oscillation enabled<br>Clock supply to CPU stopped |
| CPU                       | Operation stopped                                               |
| Port (output latch)       | Retains the status before setting the HALT mode                 |
| 16-bit timer              | Operation enabled                                               |
| 8-bit timer/event counter | Operation enabled                                               |
| Watchdog timer            | Operation enabled                                               |
| Serial interface          | Operation enabled                                               |
| External interrupt        | Operation enabled                                               |
| Key return                | Only the pin set to key return mode is enabled                  |

### (2) Releasing HALT mode

The HALT mode can be released by the following three sources.

### (a) Releasing by unmasked interrupt request

The HALT mode is released by an unmasked interrupt request. In this case, if the interrupt request is enabled to be acknowledged, 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 the 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

The HALT mode is released regardless of whether interrupts are enabled or disabled, and vectored interrupt servicing is performed.

### (c) Releasing by RESET input

When the HALT mode is released by the  $\overrightarrow{\text{RESET}}$  signal, execution branches to the reset vector address in the same manner as the ordinary reset operation, and program execution is started.





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

**2.** The parenthesized values apply to operation at fx = 5.0 MHz.

| Table 11-2. | Operation | After Release | of 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

### 11.2.2 STOP mode

### (1) Setting and operation status of STOP mode

The STOP mode is set by executing the STOP instruction.

Caution Because the standby mode can be released by an interrupt request signal, the 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. When the STOP mode is set, therefore, the HALT mode is set immediately after the STOP instruction has been executed, the wait time set by the oscillation stabilization time select register (OSTS) elapses, and then operation mode is set.

The operation status in the STOP mode is shown in the following table.

| Item                      | STOP Mode Operating Status                                                           |
|---------------------------|--------------------------------------------------------------------------------------|
| Clock generator           | Stops system clock oscillation                                                       |
| CPU                       | Stops operation                                                                      |
| Port (output latch)       | Retains the status before setting the STOP mode                                      |
| 16-bit timer              | Stops operation                                                                      |
| 8-bit timer/event counter | Operation is enabled only when TI0 is selected as the count clock                    |
| Watchdog timer            | Stops operation                                                                      |
| Serial interface          | Operation is enabled only when clock input from external is selected as serial clock |
| External interrupt        | Operation enabled                                                                    |
| Key return                | Only the pin set to key return mode is enabled                                       |

### Table 11-3. STOP Mode Operating Status

### (2) Releasing STOP mode

The STOP mode can be released by the following two types of sources.

### (a) Releasing by unmasked interrupt request

The STOP mode can be released by an unmasked interrupt request. In this case, if the interrupt is enabled to be acknowledged, vectored interrupt servicing is performed, 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 the standby mode is acknowledged.

### (b) Releasing by RESET input

When the STOP mode is released by the RESET signal, the reset operation is performed after the oscillation stabilization time has elapsed.

Wait STOP (2<sup>15</sup>/fx: 6.55 ms) instruction RESET signal Oscillation stabilization Reset Operation Operation STOP mode wait status mode period mode Oscillation Oscillation Oscillation stop Clock



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

2. The parenthesized values apply to operation at fx = 5.0 MHz.

### Table 11-4. Operation After Release of 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                 |
| RESET input                | -    | -  | Reset processing                  |

×: Don't care

### **CHAPTER 12 RESET FUNCTION**

The following two operations are available to generate reset signals.

- (1) External reset input via RESET pin
- (2) Internal reset by program loop time detected by watchdog timer

External 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 or the watchdog timer overflows, a reset is applied and each hardware is set to the status shown in Table 12-1. Each pin is high impedance during reset input or during oscillation stabilization time just after reset release.

When a high level is input to the  $\overrightarrow{\text{RESET}}$  pin, the reset is released and program execution is started after the oscillation stabilization time (2<sup>15</sup>/fx) 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 (2<sup>15</sup>/fx) has elapsed (see **Figures 12-2** through **12-4**).

Cautions 1. For an external reset, input a low level for 10  $\mu$ s or more to the RESET pin.

2. When the STOP mode is released by reset, the STOP mode contents are held during reset input. However, the port pins become high impedance.







### Figure 12-2. Reset Timing by RESET Input

|                                        | Hardware                                               | Status After Reset                                             |
|----------------------------------------|--------------------------------------------------------|----------------------------------------------------------------|
| Program counter (PC) <sup>Note 1</sup> |                                                        | The contents of reset vector tables (0000H and 0001H) are set. |
| Stack pointer (SP)                     |                                                        | Undefined                                                      |
| Program status word (PSW)              |                                                        | 02H                                                            |
| RAM                                    | Data memory                                            | Undefined <sup>Note 2</sup>                                    |
|                                        | General-purpose registers                              | Undefined <sup>Note 2</sup>                                    |
| Ports (P0 to P5) (output latch)        |                                                        | 00H                                                            |
| Port mode registers (PM0 to PM         | 15)                                                    | FFH                                                            |
| Pull-up resistor option register (     | PUO)                                                   | 00H                                                            |
| Processor clock control register       | (PCC)                                                  | 02H                                                            |
| Oscillation stabilization time sel     | ect register (OSTS)                                    | 04H                                                            |
| 16-bit timer 20                        | Timer counter (TM20)                                   | 0000H                                                          |
|                                        | Compare register (CR20)                                | FFFFH                                                          |
|                                        | Mode control register (TMC20)                          | 00H                                                            |
|                                        | Capture register (TCP20)                               | Undefined                                                      |
| 8-bit timer/event counter 00           | Timer counter (TM00)                                   | 00H                                                            |
|                                        | Compare register (CR00)                                | Undefined                                                      |
|                                        | Mode control register (TMC00)                          | 00H                                                            |
| Watchdog timer                         | Timer clock select register (TCL2)                     | 00H                                                            |
|                                        | Mode register (WDTM)                                   | 00H                                                            |
| Serial interface                       | Mode register (CSIM00)                                 | 00H                                                            |
|                                        | Asynchronous serial interface mode register (ASIM00)   | 00H                                                            |
|                                        | Asynchronous serial interface status register (ASIS00) | 00H                                                            |
|                                        | Baud rate generator control register (BRGC00)          | 00H                                                            |
|                                        | Transmit shift register (TXS00)                        | FFH                                                            |
|                                        | Receive buffer register (RXB00)                        | Undefined                                                      |
| Interrupts                             | Request flag registers (IF0, IF1)                      | 00H                                                            |
|                                        | Mask flag registers (MK0, MK1)                         | FFH                                                            |
|                                        | External interrupt mode register (INTM0)               | 00H                                                            |
|                                        | Key return mode register (KRM00)                       | 00H                                                            |

### Table 12-1. Hardware Status After Reset

- Notes 1. During reset input and oscillation stabilization time wait, only the PC contents among the hardware statuses become undefined. All other hardware remains unchanged after reset.
  - 2. The post-reset values are retained in the standby mode.

### CHAPTER 13 µPD78F9026A

The  $\mu$ PD78F9026A is a version with the internal ROM of the mask ROM versions replaced with a flash memory. The differences between the  $\mu$ PD78F9026A and the mask ROM versions are shown in Table 13-1.

| Item                |                             | Flash Memory Version    | Flash Memory Version Mask ROM Versions |      |           |           |  |  |
|---------------------|-----------------------------|-------------------------|----------------------------------------|------|-----------|-----------|--|--|
|                     |                             | μPD78F9026A             | μPD789022 μPD789024                    |      | μPD789025 | μPD789026 |  |  |
| Internal<br>memory  | ROM                         | 16 KB<br>(flash memory) | 4 KB                                   | 8 KB | 12 KB     | 16 KB     |  |  |
|                     | Internal high-<br>speed RAM | 512 bytes               | 256 bytes                              |      | 512 bytes |           |  |  |
| IC pin              |                             | Not provided            | Provided                               |      |           |           |  |  |
| V <sub>PP</sub> pin |                             | Provided                | Not provided                           |      |           |           |  |  |
| Electrical sp       | ecifications                | Refer to CHAPTER 15     | CHAPTER 15 ELECTRICAL SPECIFICATIONS.  |      |           |           |  |  |

Table 13-1. Differences Between  $\mu$ PD78F9026A and Mask ROM Versions

Caution There are differences in noise immunity and noise radiation between the flash memory and mask ROM versions. When pre-producing an application set with the flash memory version and then mass-producing it with the mask ROM version, be sure to conduct sufficient evaluations for the commercial samples (not engineering samples) of the mask ROM version.

### **13.1 Flash Memory Characteristics**

Flash memory programming is performed by connecting a dedicated flash programmer (Flashpro III (part no. FL-PR3, PG-FP3)/Flashpro IV (part no. FL-PR4, PG-FP4)) to the target system with the *µ*PD78F9026A mounted on the target system (on-board). A flash memory program adapter (FA adapter), which is a target board used exclusively for programming, is also provided.

**Remark** FL-PR3, FL-PR4, and the program adapter are products made by Naito Densei Machida Mfg. Co., Ltd. (TEL +81-45-475-4191).

Programming using flash memory 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

### 13.1.1 Programming environment

The following shows the environment required for  $\mu$ PD78F9026A flash memory 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.



### Figure 13-1. Environment for Writing Program to Flash Memory

### 13.1.2 Communication mode

Use the communication mode shown in Table 13-2 to perform communication between the dedicated flash programmer and  $\mu$ PD78F9026A.

| Communication        |                               |                                         | Pins Used                               | Number of VPP                      |          |                                             |        |
|----------------------|-------------------------------|-----------------------------------------|-----------------------------------------|------------------------------------|----------|---------------------------------------------|--------|
| Mode                 | COMM PORT                     | SIO Clock                               | CPU Clock                               |                                    | Multiple |                                             | Pulses |
|                      |                               |                                         | In Flashpro                             | On Target Board                    | Rate     |                                             |        |
| 3-wire serial<br>I/O | SIO ch-0<br>(3-wire, sync.)   | 100 Hz to<br>1.25 MHz <sup>Note 2</sup> | 1, 2, 4, 5<br>MHz <sup>Notes 2, 3</sup> | 1 to 5 MHz <sup>Note 2</sup>       | 1.0      | SI0/RxD/P22<br>SO0/TxD/P21<br>SCK0/ASCK/P20 | 0      |
| UART                 | UART ch-0<br>(Async.)         | 4,800 to<br>76,800 bps<br>Notes 2, 4    | 5 MHz <sup>Note 5</sup>                 | 4.91 or<br>5 MHz <sup>Note 2</sup> | 1.0      | RxD/SI0/P22<br>TxD/SO0/P21                  | 8      |
| Pseudo 3-wire        | Port A<br>(Pseudo-<br>3 wire) | 100 Hz to<br>1 kHz                      | 1, 2, 4, 5<br>MHz <sup>Notes 2, 3</sup> | 1 to 5 MHz <sup>Note 2</sup>       | 1.0      | P02<br>P01<br>P00                           | 12     |
|                      | Port B<br>(Pseudo-<br>3 wire) |                                         |                                         |                                    |          | P40/KR0<br>P41/KR1<br>P42/KR2               | 13     |

### Table 13-2. Communication Mode List

- 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. The possible setting range differs depending on the voltage. For details, refer to CHAPTER 15 ELECTRICAL SPECIFICATIONS.
  - 3. 2 or 4 MHz only for Flashpro III
  - **4.** Because signal wave slew also affects UART communication, in addition to the baud rate error, thoroughly evaluate the slew and baud rate error.
  - **5.** Only for Flashpro IV. However, when using Flashpro III, be sure to select the clock of the resonator on the board. UART cannot be used with the clock supplied by Flashpro III.



### Figure 13-2. Communication Mode Selection Format

### Figure 13-3. Example of Connection with Dedicated Flash Programmer



#### (a) 3-wire serial I/O









- **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 V<sub>DD</sub> 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$ PD78F9026A. 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<br>3-Wire |
|-------------|--------|-----------------------------------------------|-----------------|-------------------|-----------|------------------|
| VPP1        | Output | Write voltage                                 | Vpp             | Ø                 | Ø         | O                |
| VPP2        | _      | _                                             | _               | ×                 | ×         | ×                |
| VDD         | I/O    | VDD voltage generation/<br>voltage monitoring | Vddo, Vdd1      | Note<br>©         | Note<br>O | Note<br>O        |
| GND         | -      | Ground                                        | Vsso, Vss1      | Ø                 | Ø         | O                |
| CLK         | Output | Clock output                                  | X1              | 0                 | 0         | 0                |
| RESET       | Output | Reset signal                                  | RESET           | Ø                 | Ø         | Ø                |
| SI          | Input  | Receive signal                                | SO0/TxD/P01/P41 | Ø                 | Ø         | Ø                |
| SO          | Output | Transmit signal                               | SI0/RxD/P02/P42 | Ø                 | Ø         | Ø                |
| SCK         | Output | Transfer clock                                | SCK0/P00/P40    | O                 | ×         | O                |
| HS          | Input  | Handshake signal                              | _               | ×                 | ×         | ×                |

**Note** VDD voltage must be supplied before programming is started.

- Remark O: Pin must be connected.
  - ○: If the signal is supplied on the target board, pin does not need to be connected.
  - x: Pin does not need to be connected.

### 13.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 flash memory programming mode may be required in some cases.

### <VPP pin>

In normal operation mode, input 0 V to the VPP pin. In flash memory 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 \text{ k}\Omega$ ) to the  $V_{PP}$  pin.
- (2) Use the jumper on the board to switch the VPP pin input to either the writer or directly to GND.

A VPP pin connection example is shown below.





### <Serial interface pin>

The following shows the pins used by the serial interface.

| Serial Interface  | Pins Used      |  |  |
|-------------------|----------------|--|--|
| 3-wire serial I/O | SI0, SO0, SCK0 |  |  |
| UART              | RxD, TxD       |  |  |
| Pseudo 3-wire     | P00, P01, P02  |  |  |
|                   | P40, P41, P42  |  |  |

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.





In the flash memory 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 input signals to the other device are ignored.









If the signal output by the dedicated flash programmer affects another device in the flash memory 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 flash memory programming mode, a normal programming operation cannot be performed. Therefore, do not input reset signals from other than the dedicated flash programmer.





The signal output by the reset signal generator and the signal output from the dedicated flash programmer conflict in the flash memory programming mode, so isolate the signal of the reset signal generator.

#### <Port pins>

When the  $\mu$ PD78F9026A enters the flash memory programming mode, all the pins other than those that communicate with 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 VDD0, VDD1, VSS0, or VSS1 via a resistor.

#### <Resonator>

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 main resonator on-board, and leave the X2 pin open.

#### <Power supply>

To use the power output from the flash programmer, connect the V<sub>DD0</sub> or V<sub>DD1</sub> pin to VDD of the flash programmer, and V<sub>SS0</sub> or V<sub>SS1</sub> pin to GND of the flash programmer.

To use the on-board power supply, make connections in accordance with the normal operation mode. However, because the voltage is monitored by the flash programmer, be sure to connect VDD of the flash programmer.

#### 13.1.4 Connection of adapter for flash writing

The following figure shows an example of recommended connection when the adapter for flash writing is used.







Figure 13-9. Wiring Example for Flash Writing Adapter with UART





#### CHAPTER 14 INSTRUCTION SET

This chapter lists the instruction set of the  $\mu$ PD789026 Subseries. For details of the operation and machine language (instruction code) of each instruction, refer to **78K/OS Series Instructions User's Manual (U11047E)**.

#### 14.1 Operation

#### 14.1.1 Operand identifiers and writing methods

Operands are written in the Operands column of each instruction in accordance with the writing method of the instruction operand identifier (refer to the assembler specifications for details). When there are two or more writing methods, select one of them. Uppercase letters and the symbols #, !, \$, and [] are keywords and are written as they are. Each symbol has the following meaning.

- #: Immediate data specification
- !: Absolute address specification
- \$: Relative address specification
- []: Indirect address specification

In the case of immediate data, write an appropriate numeric value or a label. When using a label, be sure to write the #, !, \$ and [] symbols.

For operand register identifiers r and rp, either functional names (X, A, C, etc.) or absolute names (names in parentheses in the table below, R0, R1, R2, etc.) can be used.

| Identifier | Writing 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 label                                                             |
| saddrp     | FE20H to FF1FH Immediate data or label (even addresses only)                                       |
| addr16     | 0000H to FFFFH Immediate data or label (only even addresses for 16-bit data transfer instructions) |
| addr5      | 0040H to 007FH Immediate data or label (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 14-1. Operand Identifiers and Writing Methods

Remark See Table 3-4 Special Function Registers for symbols of special function registers.

#### 14.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
- (): Memory contents indicated by address or register contents in parentheses
- A: Logical product (AND)
- v: Logical sum (OR)
- ∀: Exclusive logical sum (exclusive OR)
- -: Inverted data
- addr16: 16-bit immediate data or label
- jdisp8: Signed 8-bit data (displacement value)

#### 14.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 restored

# 14.2 Operation List

| Mnemonic | Operands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Bytes | Clocks | Operation                     |   | Flag                              | J  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------------------------|---|-----------------------------------|----|
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |        |                               | Z | AC                                | CY |
| MOV      | r, #byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3     | 6      | $r \leftarrow byte$           |   |                                   |    |
|          | saddr, #byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3     | 6      | (saddr) ← byte                |   |                                   |    |
|          | sfr, #byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3     | 6      | $sfr \leftarrow byte$         |   |                                   |    |
|          | A, r <sup>Note 1</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2     | 4      | $A \leftarrow r$              |   |                                   |    |
|          | r, A <sup>Note 1</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2     | 4      | $r \leftarrow A$              |   |                                   |    |
|          | A, saddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2     | 4      | $A \leftarrow (saddr)$        |   |                                   |    |
|          | saddr, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2     | 4      | $(saddr) \leftarrow A$        |   |                                   |    |
|          | r, #byte       3       6 $r \leftarrow byte$ saddr, #byte       3       6       (saddr) $\leftarrow byte$ sfr, #byte       3       6       sfr $\leftarrow byte$ A, r <sup>boos1</sup> 2       4       A $\leftarrow r$ r, A <sup>boos1</sup> 2       4       A $\leftarrow r$ A, staddr       2       4       A $\leftarrow (saddr)$ saddr, A       2       4       A $\leftarrow sfr$ saddr16       3       8       A (addr16)         laddr16       3       8       (addr16) $\leftarrow A$ PSW, #byte       3       6       PSW $\leftarrow$ byte         A, Iaddr16       3       8       (addr16) $\leftarrow A$ PSW, #byte       3       6       PSW $\leftarrow$ byte         A, PSW       2       4       A $\leftarrow$ PSW         PSW, A       2       4       A $\leftarrow$ DE         [DE], A       1       6       (DE) $\leftarrow$ A         A, [DE]       1       6       A ( $\leftarrow$ (LL)         [HL], A       1 |       |        |                               |   |                                   |    |
|          | sfr, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2     | 4      | $sfr \leftarrow A$            |   |                                   |    |
|          | A, !addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3     | 8      | $A \leftarrow (addr16)$       |   |                                   |    |
|          | !addr16, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3     | 8      | $(addr16) \leftarrow A$       |   | Flag         Z       AC         I |    |
|          | PSW, #byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3     | 6      | $PSW \leftarrow byte$         | × | ×                                 | ×  |
|          | A, PSW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2     | 4      | $A \leftarrow PSW$            |   |                                   |    |
|          | PSW, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2     | 4      | $PSW \gets A$                 | × | ×                                 | ×  |
|          | A, [DE]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1     | 6      | $A \gets (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$      |   |                                   |    |
| ХСН      | Α, Χ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1     | 4      | $A \leftrightarrow X$         |   |                                   |    |
|          | A, r <sup>Note 2</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 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 | Operands               | Bytes | Clocks | Operation                                    |   | Flag | J  |
|----------|------------------------|-------|--------|----------------------------------------------|---|------|----|
|          |                        |       |        |                                              | 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 <sup>Note</sup> | 1     | 4      | AX ← rp                                      |   |      |    |
|          | rp, AX <sup>Note</sup> | 1     | 4      | $rp \leftarrow AX$                           |   |      |    |
| XCHW     | AX, rp <sup>Note</sup> | 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 \gets 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 | Operands                                                                              | Bytes | Clocks | Operation                                    | Flag   |
|----------|---------------------------------------------------------------------------------------|-------|--------|----------------------------------------------|--------|
|          |                                                                                       |       |        |                                              | Z AC C |
| 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 \gets 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]16 $A \leftarrow A \land (HL)$ A, [HL+byte]26 $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, laddr16                                                                            | 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 \gets A \curlyvee (HL)$                   | ×      |
|          | A, [HL+byte]                                                                          | 2     | 6      | $A \leftarrow A \lor (HL+byte)$              | ×      |

| Mnemonic | Operands     | Bytes | Clocks | Operation                                                                   |   | Flag | 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 $\leftarrow$ 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 ← 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 \leftarrow 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 $\leftarrow$ 0                                                        |   |      |    |
|          | PSW.bit      | 3     | 6      | $PSW.bit \gets 0$                                                           | × | ×    | ×  |
|          | [HL].bit     | 2     | 10     | (HL).bit $\leftarrow 0$                                                     |   |      |    |
| SET1     | CY           | 1     | 2      | CY ← 1                                                                      |   |      | 1  |
| CLR1     | CY           | 1     | 2      | $CY \leftarrow 0$                                                           |   |      | 0  |
| NOT1     | CY           | 1     | 2      | $CY \leftarrow \overline{CY}$                                               |   |      | ×  |

| Mnemonic | Operands            | Bytes | Clocks | Operation                                                                                                                                                            |   | Flag |    |
|----------|---------------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
|          |                     |       |        |                                                                                                                                                                      | Z | AC   | CY |
| 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    | [addr5]             | 1     | 8      | $(SP-1) \leftarrow (PC+1)_{H}, (SP-2) \leftarrow (PC+1)_{L},$<br>PCH $\leftarrow$ (00000000, addr5+1),<br>PCL $\leftarrow$ (00000000, addr5), SP $\leftarrow$ SP - 2 |   |      |    |
| RET      |                     | 1     | 6      | $PC_{H} \leftarrow (SP\text{+}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 \end{array}$                                      | R | R    | R  |
| PUSH     | PSW                 | 1     | 2      | $(SP1) \gets PSW,  SP \gets SP1$                                                                                                                                     |   |      |    |
|          | rp                  | 1     | 4      | $(SP1) \gets rp\text{H},(SP2) \gets rp\text{L},SP \gets SP2$                                                                                                         |   |      |    |
| 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 \leftarrow 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$ 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      | $(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     |                     | 1     | 2      | Set STOP Mode                                                                                                                                                        |   |      |    |

# 14.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 |       |     |                     |     |       |         |     |      |      |           |          |      |      |
| А           | 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 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 15 ELECTRICAL SPECIFICATIONS**

#### Absolute Maximum Ratings (T<sub>A</sub> = 25°C)

| Parameter                     | Symbol | Conditions                      | Ratings                       | Unit |
|-------------------------------|--------|---------------------------------|-------------------------------|------|
| Supply voltage                | Vdd    |                                 | -0.3 to +6.5                  | V    |
|                               | VPP    | μPD78F9026A only <b>Note</b>    | -0.3 to +10.5                 | V    |
| Input voltage                 | Vı     |                                 | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output voltage                | Vo     |                                 | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output current, high          | Іон    | Per pin                         | -10                           | mA   |
|                               |        | Total for all pins              | -30                           | mA   |
| Output current, low           | lo∟    | Per pin                         | 30                            | mA   |
|                               |        | Total for all pins              | 160                           | mA   |
| Operating ambient temperature | TA     | In normal operation mode        | -40 to +85                    | °C   |
|                               |        | During flash memory programming | 10 to 40                      | °C   |
| Storage temperature           | Tstg   | Mask ROM version                | -65 to +150                   | °C   |
|                               |        | μPD78F9026A                     | -40 to +125                   | °C   |

- **Note** Make sure that the following conditions of the VPP voltage application timing are satisfied when the flash memory is written.
  - When supply voltage rises

VPP must exceed VDD 10  $\mu$ s or more after VDD has reached the lower-limit value (1.8 V) of the operating voltage range (see a in the figure below).

#### When supply voltage drops

VDD must be lowered 10  $\mu$ s or more after VPP falls below the lower-limit value (1.8 V) of the operating voltage range of VDD (see b in the figure below).



- Caution Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded.
- **Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

| Resonator            | Recommended Circuit                                    | Parameter                                           | Conditions                                                       | MIN. | TYP. | MAX. | Unit |
|----------------------|--------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------|------|------|------|------|
| Ceramic<br>resonator |                                                        | Oscillation frequency<br>(fx) <sup>Note 1</sup>     | VDD = Oscillation voltage<br>range                               | 1.0  |      | 5.0  | MHz  |
|                      |                                                        | Oscillation stabilization<br>time <sup>Note 2</sup> | After V <sub>DD</sub> reaches the oscillation voltage range MIN. |      |      | 4    | ms   |
| Crystal<br>resonator | $x_1$ $x_2$<br>$c_1 \leftarrow \square \leftarrow c_2$ | Oscillation frequency<br>(fx) <sup>Note 1</sup>     |                                                                  | 1.0  |      | 5.0  | MHz  |
|                      |                                                        | Oscillation stabilization time <sup>Note 2</sup>    | V <sub>DD</sub> = 4.5 to 5.5 V                                   |      |      | 10   | ms   |
|                      | ///                                                    |                                                     | V <sub>DD</sub> = 1.8 to 5.5 V                                   |      |      | 30   |      |
| External clock       |                                                        | X1 input frequency (fx) <sup>Note 1</sup>           |                                                                  | 1.0  |      | 5.0  | MHz  |
|                      | Å                                                      | X1 input high-/low-level<br>width (tхн, tх∟)        |                                                                  | 85   |      | 500  | ns   |
|                      | X1 X2                                                  | X1 input frequency (fx) <sup>Note 1</sup>           | V <sub>DD</sub> = 2.7 to 5.5 V                                   | 1.0  |      | 5.0  | MHz  |
|                      |                                                        | X1 input high-/low-level<br>width (txн, tx∟)        | V <sub>DD</sub> = 2.7 to 5.5 V                                   | 85   |      | 500  | ns   |

#### System Clock Oscillator Characteristics ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 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 a resonator whose oscillation is stabilized within the oscillation stabilization 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) |     | nded Circuit<br>ant (pF) |      | n Voltage<br>e (V <sub>DD</sub> ) | Remarks           |
|--------------------------|-------------------------------------|--------------------|-----|--------------------------|------|-----------------------------------|-------------------|
|                          |                                     |                    | C1  | C2                       | MIN. | MAX.                              |                   |
| Murata Mfg. Co.,<br>Ltd. | CSBLA1M00J58-<br>B0 <sup>Note</sup> | 1.0                | 100 | 100                      | 2.2  | 5.5                               | Rd = 4.7 kΩ       |
| ток                      | CCR4.19MC3                          | 4.19               | -   | -                        | 2.0  | 5.5                               | On-chip capacitor |
|                          | FCR4.19MC5                          |                    | -   | -                        |      |                                   | On-chip capacitor |
|                          | CCR5.0MC3                           | 5.0                | _   | _                        | 2.0  | 5.5                               | On-chip capacitor |
|                          | FCR5.0MC5                           |                    | _   | _                        |      |                                   | On-chip capacitor |

(1) Ceramic resonator ( $T_A = -40$  to  $+85^{\circ}C$ ) (mask ROM version)

**Note** A limiting resistor (Rd =  $4.7 \text{ k}\Omega$ ) is required when CSBLA1M00J58-B0 (1.0 MHz) manufactured by Murata Mfg. Co., Ltd. is used as the ceramic resonator (see the figure below). This is not necessary when using one of the other recommended resonators.



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$ PD78902x within the specifications of the DC and AC characteristics.

**Remark** The resonators of Murata Mfg. Co., Ltd. other than the above are currently under evaluation.

| Manufacturer     | Part Number     | Frequency<br>(MHz) |     | nded Circuit<br>ant (pF) |      | n Voltage<br>e (V <sub>DD</sub> ) | Remarks           |
|------------------|-----------------|--------------------|-----|--------------------------|------|-----------------------------------|-------------------|
|                  |                 |                    | C1  | C2                       | MIN. | MAX.                              |                   |
| Murata Mfg. Co., | CSBLA1M00J58-B0 | 1.0                | 100 | 100                      | 2.3  | 5.5                               | _                 |
| Ltd.             | CSBFB1M00J58-R1 |                    |     |                          |      |                                   |                   |
|                  | CST2.00MG       | 2.0                | -   | -                        | 2.4  | 5.5                               | On-chip capacitor |
|                  | CSTLS2M00G56-B0 |                    |     |                          | 2.0  | 5.5                               |                   |
|                  | CSTCC2M00G56-R0 |                    |     |                          | 2.1  | 5.5                               |                   |
|                  | CSTLS4M00G53-B0 | 4.0                |     |                          |      |                                   |                   |
|                  | CSTCR4M00G53-R0 |                    |     |                          | 2.0  | 5.5                               |                   |
|                  | CSTLS4M19G53-B0 | 4.194              |     |                          | 2.1  | 5.5                               |                   |
|                  | CSTCR4M19G53-R0 |                    |     |                          | 2.0  | 5.5                               |                   |
|                  | CSTLS4M91G53-B0 | 4.915              |     |                          | 2.2  | 5.5                               |                   |
|                  | CSTCR4M91G53-R0 |                    |     |                          | 2.1  | 5.5                               |                   |
|                  | CSTLS5M00G53-B0 | 5.0                |     |                          | 2.2  | 5.5                               |                   |
|                  | CSTCR5M00G53-R0 |                    |     |                          | 2.1  | 5.5                               |                   |

#### (2) Ceramic resonator (T<sub>A</sub> = -40 to $+85^{\circ}$ C) ( $\mu$ PD78F9026A)

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$ PD78F9026A within the specifications of the DC and AC characteristics.

| Parameter                       | Symbol           | Con                                                     | ditions                           | MIN.                  | TYP. | MAX.               | Unit |
|---------------------------------|------------------|---------------------------------------------------------|-----------------------------------|-----------------------|------|--------------------|------|
| Output current, high            | Іон              | Per pin                                                 |                                   |                       |      | -1                 | mA   |
|                                 |                  | Total for all pins                                      | Total for all pins                |                       |      | -15                | mA   |
| Output current, low             | lol              | Per pin                                                 |                                   |                       |      | 10                 | mA   |
|                                 |                  | Total for all pins                                      |                                   |                       | 80   | mA                 |      |
| Input voltage, high             | VIH1             | P00 to P07, P10 to P17,                                 | V <sub>DD</sub> = 2.7 to 5.5 V    | 0.7Vdd                |      | VDD                | V    |
|                                 |                  | P21, P51 to P53                                         | V <sub>DD</sub> = 1.8 to 5.5 V    | 0.9Vdd                |      | VDD                | V    |
|                                 | V <sub>IH2</sub> | P20, P22, P30 to P32, P4                                | 40 V <sub>DD</sub> = 2.7 to 5.5 V | 0.8Vdd                |      | VDD                | V    |
|                                 |                  | to P47, P50, RESET                                      | V <sub>DD</sub> = 1.8 to 5.5 V    | 0.9Vdd                |      | VDD                | V    |
|                                 | VIH3             | X1, X2                                                  | V <sub>DD</sub> = 4.5 to 5.5 V    | V <sub>DD</sub> – 0.5 |      | VDD                | V    |
|                                 |                  |                                                         | V <sub>DD</sub> = 1.8 to 5.5 V    | Vdd - 0.1             |      | VDD                | V    |
| Input voltage, low              | VIL1             | P00 to P07, P10 to P17,                                 | V <sub>DD</sub> = 2.7 to 5.5 V    | 0                     |      | 0.3V <sub>DD</sub> | V    |
|                                 |                  | P21, P51 to P53                                         | V <sub>DD</sub> = 1.8 to 5.5 V    | 0                     |      | 0.1VDD             | V    |
|                                 | VIL2             | P20, P22, P30 to P32, P4                                | 40 V <sub>DD</sub> = 2.7 to 5.5 V | 0                     |      | 0.2V <sub>DD</sub> | V    |
|                                 |                  | to P47, P50, RESET                                      | V <sub>DD</sub> = 1.8 to 5.5 V    | 0                     |      | 0.1VDD             | V    |
|                                 | VIL3             | Vil.3 X1, X2                                            | V <sub>DD</sub> = 4.5 to 5.5 V    | 0                     |      | 0.4                | V    |
|                                 |                  |                                                         | V <sub>DD</sub> = 1.8 to 5.5 V    | 0                     |      | 0.1                | V    |
| Output voltage,                 | Vон              | V <sub>DD</sub> = 4.5 to 5.5 V, I <sub>OH</sub> = -1 mA |                                   | Vdd - 1.0             |      |                    | V    |
| high                            |                  | V <sub>DD</sub> = 1.8 to 5.5 V, Iон = -                 | Vdd - 0.5                         |                       |      | V                  |      |
| Output voltage, low             | Vol              | V <sub>DD</sub> = 4.5 to 5.5 V, I <sub>OL</sub> = 1     | 0 mA                              |                       |      | 1.0                | V    |
|                                 |                  | V <sub>DD</sub> = 1.8 to 5.5 V, I <sub>OL</sub> = 4     | -00 μA                            |                       |      | 0.5                | V    |
| Input leakage                   | Ішні             | V <sub>IN</sub> = V <sub>DD</sub> F                     | ins other than X1 and X2          |                       |      | 3                  | μA   |
| current, high                   |                  | ×                                                       | 1, X2                             |                       |      | 20                 | μA   |
| Input leakage                   |                  | V <sub>IN</sub> = 0 V F                                 | ins other than X1 and X2          |                       |      | -3                 | μA   |
| current, low                    | LIL2             |                                                         | 1, X2                             |                       |      | -20                | μA   |
| Output leakage<br>current, high | Ігон             | Vout = VDD                                              |                                   |                       |      | 3                  | μA   |
| Output leakage<br>current, low  | Ilol             | Vout = 0 V                                              |                                   |                       |      | -3                 | μA   |
| Software pull-up<br>resistor    | R                | VIN = 0 V                                               |                                   | 50                    | 100  | 200                | kΩ   |

# DC Characteristics (T<sub>A</sub> = -40 to $+85^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V) (1/2)

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

| Parameter                        | Symbol | Conditio                                   | ons                                                       | MIN. | TYP. | MAX. | Unit |
|----------------------------------|--------|--------------------------------------------|-----------------------------------------------------------|------|------|------|------|
| Supply current <sup>Note 1</sup> | DD1    | 5.0 MHz crystal oscillation                | $V_{\text{DD}} = 5.0 \ \text{V}{\pm}10\%^{\text{Note 2}}$ |      | 1.3  | 2.5  | mA   |
| (mask ROM                        |        | operating mode                             | $V_{\text{DD}} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 0.26 | 0.45 | mA   |
| version)                         |        |                                            | $V_{\text{DD}} = 2.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 0.14 | 0.30 | mA   |
|                                  | IDD2   | 5.0 MHz crystal oscillation                | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Note 2}}$  |      | 0.41 | 0.85 | mA   |
|                                  |        | HALT mode                                  | $V_{\text{DD}} = 3.0 \ \text{V}{\pm}10\%^{\text{Note 3}}$ |      | 0.16 | 0.35 | mA   |
|                                  |        |                                            | $V_{\text{DD}} = 2.0 \ \text{V}{\pm}10\%^{\text{Note 3}}$ |      | 0.07 | 0.15 | mA   |
|                                  | Idd3   | STOP mode                                  | V <sub>DD</sub> = 5.0 V±10%                               |      | 0.1  | 10   | μA   |
|                                  |        |                                            | $V_{DD} = 3.0 V \pm 10\%$                                 |      | 0.05 | 5.0  | μA   |
|                                  |        |                                            | $T_A = 25^{\circ}C$                                       |      | 0.05 | 3.0  | μA   |
|                                  |        |                                            | $V_{DD} = 2.0 \ V \pm 10\%$                               |      | 0.05 | 3.0  | μA   |
| Supply current <sup>Note 1</sup> | DD1    | 5.0 MHz crystal oscillation operating mode | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Note 2}}$  |      | 4.0  | 15.0 | mA   |
| ( <i>µ</i> PD78F9026A)           |        |                                            | $V_{\text{DD}} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 1.0  | 5.0  | mA   |
|                                  |        | (C1 = C2 = 22 pF)                          | $V_{\text{DD}} = 2.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 0.8  | 3.0  | mA   |
|                                  | DD2    | 5.0 MHz crystal oscillation                | $V_{\text{DD}} = 5.0 \text{ V} \pm 10\%^{\text{Note 2}}$  |      | 0.8  | 5.0  | mA   |
|                                  |        | HALT mode                                  | $V_{\text{DD}} = 3.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 0.5  | 2.5  | mA   |
|                                  |        | (C1 = C2 = 22 pF)                          | $V_{\text{DD}} = 2.0 \text{ V} \pm 10\%^{\text{Note 3}}$  |      | 0.3  | 1.0  | mA   |
|                                  | IDD3   | STOP mode                                  | VDD = 5.0 V±10%                                           |      | 0.1  | 30   | μA   |
|                                  |        |                                            | VDD = 3.0 V±10%                                           |      | 0.05 | 10   | μA   |
|                                  |        |                                            | VDD = 2.0 V±10%                                           |      | 0.05 | 10   | μA   |

#### DC Characteristics (T<sub>A</sub> = -40 to $+85^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V) (2/2)

**Notes 1.** The current flowing to the ports (including the current flowing through the on-chip pull-up resistors) is not included.

2. High-speed mode operation (when the processor clock control register (PCC) is set to 00H)

3. Low-speed mode operation (when PCC is set to 02H)

**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 Write current<sup>Note</sup> When VPP supply voltage = VPP1 18 IDDW mΑ (VDD pin) Write current<sup>Note</sup> When VPP supply voltage = VPP1 22.5 **I**PPW mΑ (VPP pin) Erase current<sup>Note</sup> When VPP supply voltage = VPP1 18 DDE mA (VDD pin) Erase current<sup>Note</sup> **I**PPE When $V_{PP}$ supply voltage = $V_{PP1}$ 115 mΑ (VPP pin) Unit erase time 0.5 1 ter 1 s Total erase time tera 20 s Write count Erase/write are regarded as 1 cycle 20 20 20 Times VPP supply voltage VPP0 In normal operation 0 0.2VDD V V<sub>PP1</sub> 10.0 V During flash memory programming 9.7 10.3

#### Flash Memory Write/Erase Characteristics

(TA = 10 to 40°C, VDD = 1.8 to 5.5 V, in 5.0 MHz crystal oscillation operating mode)

**Note** The current flowing to the ports (including the current flowing through the on-chip pull-up resistors) is not included.

#### **AC Characteristics**

| Parameter                                   | Symbol          | Conditions                               | MIN. | TYP. | MAX. | Unit |
|---------------------------------------------|-----------------|------------------------------------------|------|------|------|------|
| Cycle time                                  | Тсү             | V <sub>DD</sub> = 2.7 to 5.5 V           | 0.4  |      | 8    | μs   |
| (minimum instruction execution time)        |                 | V <sub>DD</sub> = 1.8 to 5.5 V           | 1.6  |      | 8    | μs   |
| TI0 input high-/low-<br>level width         | t⊤ıн, t⊤ı∟      | $V_{DD} = 2.7 \text{ to } 5.5 \text{ V}$ | 0.1  |      |      | μs   |
|                                             |                 | V <sub>DD</sub> = 1.8 to 5.5 V           | 1.8  |      |      | μs   |
| TI0 input frequency                         | f⊤ı             | V <sub>DD</sub> = 2.7 to 5.5 V           | 0    |      | 4    | MHz  |
|                                             |                 | V <sub>DD</sub> = 1.8 to 5.5 V           | 0    |      | 275  | kHz  |
| Interrupt input<br>high-/low-level<br>width | tinth,<br>tintl | INTP0 to INTP2                           | 10   |      |      | μs   |
| RESET low-level width                       | t⊓s∟            |                                          | 10   |      |      | μs   |

#### (1) Basic operation ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 1.8$ to 5.5 V)





#### (2) Serial interface 00 (T<sub>A</sub> = -40 to $+85^{\circ}$ C, V<sub>DD</sub> = 1.8 to 5.5 V)

| Parameter                           | Symbol     | Conditions                                            |                                | MIN.          | TYP. | MAX. | Unit |
|-------------------------------------|------------|-------------------------------------------------------|--------------------------------|---------------|------|------|------|
| SCK0 cycle time                     | tксүı      | V <sub>DD</sub> = 2.7 to 5.5 V                        | V <sub>DD</sub> = 2.7 to 5.5 V |               |      |      | ns   |
|                                     |            | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 3200          |      |      | ns   |
| SCK0 high-/low-                     | tĸнı, tĸlı | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | tксү1/2 – 50  |      |      | ns   |
| level width                         |            | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | tксү1/2 — 150 |      |      | ns   |
| SI0 setup time                      | tsik1      | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | 150           |      |      | ns   |
| (to SCK0↑)                          |            | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 500           |      |      | ns   |
| SI0 hold time                       | tksi1      | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | 400           |      |      | ns   |
| (from SCK0↑)                        |            | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 600           |      |      | ns   |
| SO0 output delay<br>time from SCK0↓ | tkso1      | $R = 1 \text{ k}\Omega$ , $C = 100 \text{ pF}^{Note}$ | V <sub>DD</sub> = 2.7 to 5.5 V | 0             |      | 250  | ns   |
| ume nom SCK0↓                       |            | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 0             |      | 1000 | ns   |

### (i) 3-wire serial I/O mode (SCK0...Internal clock output)

Note R and C are the load resistance and load capacitance of the SO0 output line, respectively.

# (ii) 3-wire serial I/O mode (SCK0...External clock input)

| Parameter                   | Symbol        | Condition                                             | าร                             | MIN. | TYP. | MAX. | Unit |
|-----------------------------|---------------|-------------------------------------------------------|--------------------------------|------|------|------|------|
| SCK0 cycle time             | <b>t</b> ксү2 | VDD = 2.7 to 5.5 V                                    | V <sub>DD</sub> = 2.7 to 5.5 V |      |      |      | ns   |
|                             |               | VDD = 1.8 to 5.5 V                                    |                                | 3500 |      |      | ns   |
| SCK0 high-/low-             | tĸн₂, tĸ∟₂    | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | 400  |      |      | ns   |
| level width                 |               | V <sub>DD</sub> = 1.8 to 5.5 V                        | 1600                           |      |      | ns   |      |
| SI0 setup time (to          | tsik2         | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | 100  |      |      | ns   |
| SCK0↑)                      |               | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 150  |      |      | ns   |
| SI0 hold time (from         | tksi2         | V <sub>DD</sub> = 2.7 to 5.5 V                        |                                | 400  |      |      | ns   |
| SCK0↑)                      |               | V <sub>DD</sub> = 1.8 to 5.5 V                        |                                | 600  |      |      | ns   |
| SO0 output delay            | tkso2         | $R = 1 \text{ k}\Omega$ , $C = 100 \text{ pF}^{Note}$ | V <sub>DD</sub> = 2.7 to 5.5 V | 0    |      | 300  | ns   |
| time from SCK0 $\downarrow$ |               |                                                       | V <sub>DD</sub> = 1.8 to 5.5 V | 0    |      | 1000 | ns   |

Note R and C are the load resistance and load capacitance of the SO0 output line, respectively.

#### (iii) UART mode (dedicated baud rate generator output)

| Parameter     | Symbol | Conditions                     | MIN. | TYP. | MAX.  | Unit |
|---------------|--------|--------------------------------|------|------|-------|------|
| Transfer rate |        | V <sub>DD</sub> = 2.7 to 5.5 V |      |      | 78125 | bps  |
|               |        | V <sub>DD</sub> = 1.8 to 5.5 V |      |      | 19531 | bps  |

| Parameter           | Symbol     | Conditions                               | MIN. | TYP. | MAX.  | Unit |
|---------------------|------------|------------------------------------------|------|------|-------|------|
| ASCK cycle time     | tксүз      | $V_{DD} = 2.7$ to 5.5 V                  | 900  |      |       | ns   |
|                     |            | V <sub>DD</sub> = 1.8 to 5.5 V           | 3500 |      |       | ns   |
| ASCK high-/low-     | tĸнз, tĸĿз | $V_{DD} = 2.7 \text{ to } 5.5 \text{ V}$ | 400  |      |       | ns   |
| level width         |            | V <sub>DD</sub> = 1.8 to 5.5 V           | 1600 |      |       | ns   |
| Transfer rate       |            | $V_{DD} = 2.7 \text{ to } 5.5 \text{ V}$ |      |      | 39063 | bps  |
|                     |            | V <sub>DD</sub> = 1.8 to 5.5 V           |      |      | 9766  | bps  |
| ASCK rise/fall time | tr, tr     |                                          |      |      | 1     | μs   |

# (iv) UART mode (external clock input)

# AC Timing Test Points (Except X1 Input)



### **Clock Timing**



#### **TI Timing**



#### Interrupt Input Timing



# **RESET** Input Timing



#### Serial Transfer Timing

3-wire serial I/O mode:



m = 1, 2

UART mode (external clock input):



| Parameter                        | Symbol | Conditions           | MIN. | TYP.                | MAX. | Unit |
|----------------------------------|--------|----------------------|------|---------------------|------|------|
| Data retention<br>supply voltage | Vdddr  |                      | 1.8  |                     | 5.5  | V    |
| Release signal set time          | tsrel  |                      | 0    |                     |      | μs   |
| Oscillation                      | twait  | Release by RESET     |      | 2 <sup>15</sup> /fx |      | ms   |
| stabilization wait time          |        | Release by interrupt |      | Note                |      | ms   |

#### Data Memory STOP Mode Low Supply Voltage Data Retention Characteristics (T<sub>A</sub> = -40 to +85°C)

**Note** 2<sup>12</sup>/fx, 2<sup>15</sup>/fx, or 2<sup>17</sup>/fx can be selected according to the setting of bits 0 to 2 (OSTS0 to OSTS2) of the oscillation stabilization time select register.

Remark fx: System clock oscillation frequency

#### Data Retention Timing (STOP Mode Release by RESET)



#### Data Retention Timing (Standby Release Signal: STOP Mode Release by Interrupt Signal)





IDD vs VDD (system clock: 5.0 MHz, crystal resonator)

Iон vs Vdd – Vон



 $(T_{A} = 25^{\circ}C)$ 30  $V_{DD} = 5.5 V$  $V_{DD} = 3.5 V$ Low-level output current IoL (mA)  $V_{DD} = 3.0 V$ -VDD = 4.0 V -VDD = 4.5 V 20  $V_{DD} = 5.0 V$  $V_{DD} = 2.5 V$ 10  $V_{DD} = 2.0 V$ VDD = 1.8 V 0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 0 Low-level output voltage VoL (V)

IOL VS VOL

# 44 PIN PLASTIC LQFP (10x10)





Each lead centerline is located within 0.20 mm of its true position (T.P.) at maximum material condition.

| MILLIMETERS                           |
|---------------------------------------|
| 12.0±0.2                              |
| 10.0±0.2                              |
| 10.0±0.2                              |
| 12.0±0.2                              |
| 1.0                                   |
| 1.0                                   |
| $0.37 \substack{+0.08 \\ -0.07}$      |
| 0.20                                  |
| 0.8 (T.P.)                            |
| 1.0±0.2                               |
| 0.5                                   |
| $0.17^{+0.03}_{-0.06}$                |
| 0.10                                  |
| 1.4±0.05                              |
| 0.1±0.05                              |
| $3^{\circ}_{-3^{\circ}}^{+4^{\circ}}$ |
| 1.6 MAX.                              |
| 0.25 (T.P.)                           |
|                                       |

U

0.6±0.15 S44GB-80-8ES-2

detail of lead end

Т

IJ

-S ⊢P

R

Q

#### CHAPTER 18 RECOMMENDED SOLDERING CONDITIONS

The  $\mu$ PD789026 Subseries should be soldered and mounted under the following recommended conditions.

For details of the recommended soldering conditions, refer to the document **Semiconductor Device Mounting Technology Manual (C10535E)**.

For soldering methods and conditions other than those recommended below, contact an NEC Electronics sales representative.

#### Table 18-1. Surface Mounting Type Soldering Conditions (1/2)

 $\mu$ PD789022GB-xxx-8ES: 44-pin plastic LQFP (10 × 10)  $\mu$ PD789024GB-xxx-8ES: 44-pin plastic LQFP (10 × 10)  $\mu$ PD789025GB-xxx-8ES: 44-pin plastic LQFP (10 × 10)  $\mu$ PD789026GB-xxx-8ES: 44-pin plastic LQFP (10 × 10)  $\mu$ PD78F9026AGB-8ES: 44-pin plastic LQFP (10 × 10)

| Soldering Method | Soldering Conditions                                                                                                                         | Recommended<br>Condition Symbol |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow  | Package peak temperature: 235°C, Time: 30 seconds max. (at 210°C or higher), Count: Two times or less                                        | IR35-00-2                       |
| VPS              | Package peak temperature: 215°C, Time: 40 seconds max. (at 200°C or higher), Count: Two times or less                                        | VP15-00-2                       |
| Wave soldering   | Solder bath temperature: 260°C max., Time: 10 seconds max., Count:<br>Once, Preheating temperature: 120°C max. (package surface temperature) | WS60-00-1                       |
| Partial heating  | Pin temperature: 350°C max., Time: 3 seconds max. (per pin row)                                                                              | —                               |

Caution Do not use different soldering methods together (except for partial heating).

#### Table 18-1. Surface Mounting Type Soldering Conditions (2/2)

| μPD789022GB-xxx-8ES-A: | 44-pin plastic LQFP ( $10 \times 10$ ) |
|------------------------|----------------------------------------|
| μPD789024GB-xxx-8ES-A: | 44-pin plastic LQFP ( $10 \times 10$ ) |
| μPD789025GB-xxx-8ES-A: | 44-pin plastic LQFP ( $10 \times 10$ ) |
| μPD789026GB-xxx-8ES-A: | 44-pin plastic LQFP (10 × 10)          |
| μPD78F9026AGB-8ES-A:   | 44-pin plastic LQFP (10 × 10)          |

\*

| Soldering Method | Soldering Conditions                                                                                                                                                                              | Recommended Condition<br>Symbol |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow  | Package peak temperature: 260°C, Time: 60 seconds max. (at 220°C or higher), Count: Three times or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for 20 to 72 hours) | IR60-207-3                      |
| Wave soldering   | When the pin pitch of the package is 0.65 mm or more, wave soldering can also be performed.<br>For details, contact an NEC Electronics sales representative.                                      | _                               |
| Partial heating  | Pin temperature: 350°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).

**Remarks 1.** Products that have the part numbers suffixed by "-A" are lead-free products.

**2.** For soldering methods and conditions other than those recommended above, contact an NEC Electronics sales representative.

# APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for development of systems using the  $\mu$ PD789026 Subseries. Figure A-1 shows development tools.

• Support of PC98-NX Series

Unless specified otherwise, the products supported by IBM PC/AT<sup>™</sup> compatibles can be used in PC98-NX Series. When using the PC98-NX Series, refer to the explanation of IBM PC/AT compatibles.

● Windows<sup>™</sup>

Unless specified otherwise, "Windows" indicates the following operating systems.

- Windows 3.1
- Windows 95
- Windows 98
- Windows NT<sup>™</sup> Ver. 4.0
- Windows 2000
- Windows XP



#### Figure A-1. Development Tools

- Notes 1. C library source file is not included in the software package.
  - Project Manager is included in the assembler package.
     Project Manager is used only in the Windows environment.

#### A.1 Software Package

| SP78K0S<br>Software package | Software tools for development of the 78K/0S Series are combined in this package.<br>The following tools are included.<br>RA78K0S, CC78K0S, ID78K0S-NS, SM78K0S, and device files |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Part number: µSxxxxSP78K0S                                                                                                                                                        |

**Remark** ×××× in the part number differs depending on the operating system to be used.

μSxxxxSP78K0S

| XXXX | Host Machine              | OS               | Supply Medium |
|------|---------------------------|------------------|---------------|
| AB17 | PC-9800 series, IBM PC/AT | Japanese Windows | CD-ROM        |
| BB17 | compatibles               | English Windows  |               |

#### A.2 Language Processing Software

| RA78K0S<br>Assembler package                         | Program that converts program written in mnemonic into object codes that can be executed by microcontroller.         In addition, automatic functions to generate a symbol table and optimize branch instructions are also provided.         Used in combination with a device file (DF789026) (sold separately). <caution environment="" in="" pc="" used="" when="">         The assembler package is a DOS-based application but may be used in the Windows environment by using the Project Manager of Windows (included in the assembler package).         Part number: μSxxxxRA78K0S</caution> |
|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CC78K0S<br>C compiler package                        | Program that converts program written in C language into object codes that can be executed by microcontroller.         Used in combination with an assembler package (RA78K0S) and device file (DF789026) (both sold separately). <caution environment="" in="" pc="" used="" when="">         The C compiler package is a DOS-based application but may be used in the Windows environment by using the Project Manager of Windows (included in the assembler package).         Part number: μSxxxxCC78K0S</caution>                                                                                |
| DF789026 <sup>Note 1</sup><br>Device file            | File containing the information inherent to the device.         Used in combination with the RA78K0S, CC78K0S, ID78K0S-NS, and SM78K0S (all sold separately).         Part number: μSxxxxDF789026                                                                                                                                                                                                                                                                                                                                                                                                    |
| CC78K0S-L <sup>Note 2</sup><br>C library source file | Source file of functions for generating object library included in C compiler package.<br>Necessary for changing object library included in C compiler package according to<br>customer's specifications. Since this is a source file, its working environment does not<br>depend on any particular operating system.                                                                                                                                                                                                                                                                                |
|                                                      | Part number: µSxxxxCC78K0S-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Notes 1. DF789026 is a common file that can be used with RA78K0S, CC78K0S, ID78K0S-NS, and SM78K0S.
2. CC78K0S-L is not included in the software package (SP78K0S).

**Remark** ×××× in the part number differs depending on the host machine and operating system to be used.

# μS××××RA78K0S

| $\mu S \times \times$ | $\propto C$ | C7 | 8K( | US |
|-----------------------|-------------|----|-----|----|
| ,                     |             |    |     |    |

| [ | ×××× | Host Machine                   | OS                                | Supply Medium   |
|---|------|--------------------------------|-----------------------------------|-----------------|
|   | AB13 | PC-9800 series,                | Japanese Windows                  | 3.5-inch 2HD FD |
|   | BB13 | IBM PC/AT 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 <sup>™</sup>      | SunOS <sup>™</sup> (Rel. 4.1.4),  |                 |
|   |      |                                | Solaris <sup>™</sup> (Rel. 2.5.1) |                 |

### μSxxxxDF789026

 $\mu$ SxxxxCC78K0S-L

| <br>×××× | Host Machine          | OS                   | Supply Medium   |
|----------|-----------------------|----------------------|-----------------|
| AB13     | PC-9800 series,       | Japanese Windows     | 3.5-inch 2HD FD |
| BB13     | IBM PC/AT compatibles | English Windows      |                 |
| 3P16     | HP9000 series 700     | HP-UX (Rel. 10.10)   | DAT             |
| 3K13     | SPARCstation          | SunOS (Rel. 4.1.4),  | 3.5-inch 2HD FD |
| 3K15     |                       | Solaris (Rel. 2.5.1) | 1/4-inch CGMT   |

### A.3 Control Software

| PM plus         | Control software created for efficient development of the user program in the Windows                                                        |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Project Manager | environment. User program development operations such as editor startup, build, and debugger startup can be performed from the PM plus.      |
|                 | <caution><br/>The PM plus is included in the assembler package (RA78K0S).<br/>The PM plus is used only in the Windows environment.</caution> |

### A.4 Flash Memory Writing Tools

| Flashpro III (FL-PR3, PG-FP3)<br>Flashpro IV (FL-PR4, PG-FP4)<br>Flash programmer | Dedicated flash programmer for microcontrollers incorporating flash memory        |
|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| FA-44GB-8ES                                                                       | Adapter for writing to flash memory and connected to Flashpro III or Flashpro IV. |
| Flash memory writing adapter                                                      | FA-44GB-8ES: For 44-pin plastic LQFP (GB-8ES type)                                |

**Remark** The FL-PR3, FL-PR4, and FA-44GB-8ES are products made by Naito Densei Machida Mfg. Co., Ltd. (TEL +81-45-475-4191).

# A.5 Debugging Tools (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 AC adapter, emulation probe, and interface adapter for connecting the host machine. |
|----------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IE-78K0S-NS-/<br>In-circuit emula            |                                     | The IE-78K0S-NS-A provides a coverage function in addition to the IE-78K0S-NS functions, thus enhancing the debug functions, including the tracer and timer functions.                                                                                     |
| IE-70000-MC-F<br>AC adapter                  | PS-B                                | Adapter for supplying power from AC 100 to 240 V outlet.                                                                                                                                                                                                   |
| IE-70000-98-IF<br>Interface adapt            | -                                   | Adapter necessary when using PC-9800 series PC (except notebook type) as host machine (C bus supported)                                                                                                                                                    |
| IE-70000-CD-IF-A<br>PC card interface        |                                     | PC card and interface cable necessary when using notebook PC as host machine (PCMCIA socket supported)                                                                                                                                                     |
| IE-70000-PC-IF-C<br>Interface adapter        |                                     | Adapter necessary when using IBM PC/AT compatible as host machine (ISA bus supported)                                                                                                                                                                      |
| IE-70000-PCI-IF-A<br>Interface adapter       |                                     | Adapter necessary when using personal computer incorporating PCI bus as host machine                                                                                                                                                                       |
| IE-789026-NS-EM1<br>Emulation board          |                                     | Board for emulating the peripheral hardware inherent to the device. Used in combination with in-<br>circuit emulator.                                                                                                                                      |
| NP-44GB-TQ<br>NP-H44GB-TQ<br>Emulation probe |                                     | Cable to connect the in-circuit emulator and target system.<br>Used in combination with the TGB-044SAP.                                                                                                                                                    |
| C                                            | TGB-044SAP<br>Conversion<br>adapter | Conversion adapter to connect the NP-44GB-TQ or NP-H44GB-TQ and a target system board on which a 44-pin plastic LQFP (GB-8ES type) can be mounted                                                                                                          |

**Remarks 1.** The NP-44GB-TQ and NP-H44GB-TQ are products made by Naito Densei Machida Mfg. Co., Ltd. (TEL +81-45-475-4191).

2. The TGB-044SAP is a product made by TOKYO ELETECH CORPORATION.

For further information, contact: Daimaru Kogyo, Ltd.

Tokyo Electronics Department (TEL +81-3-3820-7112) Osaka Electronics Department (TEL +81-6-6244-6672)

# A.6 Debugging Tools (Software)

| ID78K0S-NS<br>Integrated debugger       | This debugger supports the in-circuit emulators IE-78K0S-NS and IE-78K0S-NS-A for the 78K/0S Series. The ID78K0S-NS is Windows-based software.<br>It has improved C-compatible debugging functions and can display the results of tracing with the source program using an integrating window function that associates the source program, disassemble display, and memory display with the trace result.<br>Used in combination with a device file (DF789026) (sold separately).                                                                          |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                         | Part number: µSxxxxID78K0S-NS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SM78K0S<br>System simulator             | This is a system simulator for the 78K/0S Series. The SM78K0S is Windows-based software.<br>It can be used to debug the target system at C source level or assembler level while<br>simulating the operation of the target system on the host machine.<br>Using SM78K0S, the logic and performance of the application can be verified independently<br>of hardware development. Therefore, the development efficiency can be enhanced and the<br>software quality can be improved.<br>Used in combination with a device file (DF789026) (sold separately). |
|                                         | Part number: µSxxxxSM78K0S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DF789026 <sup>Note</sup><br>Device file | File containing the information inherent to the device.<br>Used in combination with the RA78K0S, CC78K0S, ID78K0S-NS, and SM78K0S (all sold<br>separately).                                                                                                                                                                                                                                                                                                                                                                                                |
|                                         | Part number: µSxxxxDF789026                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Note The DF789026 is a common file that can be used with RA78K0S, CC78K0S, ID78K0S-NS, and SM78K0S.

**Remark** ×××× in the part number differs depending on the operating system and supply medium to be used.

# $\mu$ S××××ID78K0S-NS

 $\mu S \times \times \times SM78K0S$ 

| <br>×××× | Host Machine          | OS               | Supply Medium   |
|----------|-----------------------|------------------|-----------------|
| AB13     | PC-9800 series,       | Japanese Windows | 3.5-inch 2HD FD |
| BB13     | IBM PC/AT compatibles | English Windows  |                 |
| AB17     |                       | Japanese Windows | CD-ROM          |
| BB17     |                       | English Windows  |                 |

#### A.7 Conversion Adapter (TGB-044SAP) Drawing

Figure A-2. TGB-044SAP Package Drawing (Reference)

# Reference diagram: TGB-044SAP (TQPACK044SA+TQSOCKET044SAP) Package dimension (unit: mm)





| ITEM | MILLIMETERS | INCHES            | ITEM | MILLIMETERS | INCHES         |
|------|-------------|-------------------|------|-------------|----------------|
| Α    | 10.12       | 0.398             | а    | 2.0         | 0.079          |
| В    | 0.8x10=8.0  | 0.031x0.394=0.315 | b    | 0.25        | 0.010          |
| С    | 0.8         | 0.031             | С    | 9.6         | 0.378          |
| D    | 16.65       | 0.656             | d    | 1.2         | 0.047          |
| Е    | 8.4         | 0.331             | е    | 1.2         | 0.047          |
| F    | 10.8        | 0.425             | f    | 2.4         | 0.094          |
| G    | 13.2        | 0.520             | g    | 2.7         | 0.106          |
| Н    | C 2.0       | C 0.079           |      |             | TGB-044SAP-G0E |
| I    | 9.35        | 0.368             |      |             |                |
| J    | 1.325       | 0.052             |      |             |                |
| К    | 1.325       | 0.052             |      |             |                |
| L    | 12.0        | 0.472             |      |             |                |
|      |             |                   |      |             |                |

| 9.35         | 0.368                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.325        | 0.052                                                                                                                                                         |
| 1.325        | 0.052                                                                                                                                                         |
| 12.0         | 0.472                                                                                                                                                         |
| 16.65        | 0.656                                                                                                                                                         |
| 8.5          | 0.335                                                                                                                                                         |
| 13.15        | 0.518                                                                                                                                                         |
| 5.0          | 0.197                                                                                                                                                         |
| 1.8          | 0.071                                                                                                                                                         |
| $\phi$ 3.55  | φ0.140                                                                                                                                                        |
| $\phi$ 0.9   | $\phi$ 0.035                                                                                                                                                  |
| <i>ф</i> 0.3 | <i>φ</i> 0.012                                                                                                                                                |
| (16.95)      | (0.667)                                                                                                                                                       |
| 7.35         | 0.289                                                                                                                                                         |
| 1.2          | 0.047                                                                                                                                                         |
| 6.0          | 0.236                                                                                                                                                         |
| 1.85         | 0.073                                                                                                                                                         |
| 3.5          | 0.138                                                                                                                                                         |
|              | $\begin{array}{c} 1.325\\ 1.325\\ 12.0\\ 16.65\\ 8.5\\ 13.15\\ 5.0\\ 1.8\\ \phi 3.55\\ \phi 0.9\\ \phi 0.3\\ (16.95)\\ 7.35\\ 1.2\\ 6.0\\ 1.85\\ \end{array}$ |

note: Product by TOKYO ELETECH CORPORATION.

#### APPENDIX B NOTES ON TARGET SYSTEM DESIGN

Figures B-1 and B-2 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.





Note Distance when NP-44GB-TQ is used. When NP-H44GB-TQ is used, the distance is 370 mm.

Remarks 1. NP-44GB-TQ and NP-H44GB-TQ are products of Naito Densei Machida Mfg. Co., Ltd.
2. TGB-044SAP is a product of TOKYO ELETECH CORPORATION.



Figure B-2. Connection Condition of Target System (NP-H44GB-TQ)

Remarks 1. NP-H44GB-TQ is a product of Naito Densei Machida Mfg. Co., Ltd.2. TGB-044SAP is a product of TOKYO ELETECH CORPORATION.

# APPENDIX C REGISTER INDEX

# C.1 Register Name Index

| 16-bit capture register 20 (TCP20)                        |     |
|-----------------------------------------------------------|-----|
| 16-bit compare register 20 (CR20)                         |     |
| 16-bit timer counter 20 (TM20)                            |     |
| 16-bit timer mode control register 20 (TMC20)             | 90  |
| 8-bit compare register 00 (CR00)                          | 101 |
| 8-bit timer counter 00 (TM00)                             | 101 |
| 8-bit timer mode control register 00 (TMC00)              | 102 |
| [A]                                                       |     |
| Asynchronous serial interface mode register 00 (ASIM00)   |     |
| Asynchronous serial interface status register 00 (ASIS00) |     |
| [B]                                                       |     |
| Baud rate generator control register 00 (BRGC00)          |     |
| (E)                                                       |     |
| External interrupt mode register 0 (INTM0)                | 151 |
| [1]                                                       |     |
| Interrupt mask flag register 0 (MK0)                      |     |
| Interrupt mask flag register 1 (MK1)                      |     |
| Interrupt request flag register 0 (IF0)                   | 149 |
| Interrupt request flag register 1 (IF1)                   | 149 |
| [K]                                                       |     |
| Key return mode register 00 (KRM00)                       |     |
| [0]                                                       |     |
| Oscillation stabilization time select register (OSTS)     |     |
| [P]                                                       |     |
| Port 0 (P0)                                               | 67  |
| Port 1 (P1)                                               |     |
| Port 2 (P2)                                               | 69  |
| Port 3 (P3)                                               | 72  |
| Port 4 (P4)                                               | 73  |
| Port 5 (P5)                                               |     |
| Port mode register 0 (PM0)                                |     |
| Port mode register 1 (PM1)                                |     |
| Port mode register 2 (PM2)                                | 77  |

| Port mode register 3 (PM3)                 | 77          |
|--------------------------------------------|-------------|
| Port mode register 4 (PM4)                 | 77          |
| Port mode register 5 (PM5)                 | 77, 92, 103 |
| Processor clock control register (PCC)     | 81          |
| Pull-up resistor option register (PUO)     |             |
| [R]                                        |             |
| Receive buffer register 00 (RXB00)         | 119         |
| Receive shift register 00 (RXS00)          | 119         |
| [S]                                        |             |
| Serial operation mode register 00 (CSIM00) |             |
| [T]                                        |             |
| Timer clock select register 2 (TCL2)       | 112         |
| Transmit shift register 00 (TXS00)         | 119         |
| [ <b>W</b> ]                               |             |
| Watchdog timer mode register (WDTM)        | 113         |

# C.2 Register Symbol Index

| [A] |  |
|-----|--|
|     |  |

| ASIM00:    | Asynchronous serial interface mode register 00   |     |
|------------|--------------------------------------------------|-----|
| ASIS00:    | Asynchronous serial interface status register 00 |     |
| [B]        |                                                  |     |
| BRGC00:    | Baud rate generator control register 00          |     |
| [C]        |                                                  |     |
| CR00:      | 8-bit compare register 00                        |     |
| CR20:      | 16-bit compare register 20                       |     |
| CSIM00:    | Serial operation mode register 00                |     |
| [1]        |                                                  |     |
| IF0:       | Interrupt request flag register 0                |     |
| IF1:       | Interrupt request flag register 1                | 149 |
| INTM0:     | External interrupt mode register 0               |     |
| [K]        |                                                  |     |
| KRM00:     | Key return mode register 00                      |     |
| [M]        |                                                  |     |
| MK0:       | Interrupt mask flag register 0                   |     |
| MK1:       | Interrupt mask flag register 1                   |     |
| [0]        |                                                  |     |
| OSTS:      | Oscillation stabilization time select register   |     |
| [P]        | -                                                |     |
|            | De tra                                           | 67  |
| P0:<br>P1: | Port 0                                           |     |
| P1:<br>P2: | Port 2                                           |     |
| P3:        | Port 3                                           |     |
| P4:        | Port 4                                           |     |
| P5:        | Port 5                                           |     |
| PCC:       | Processor clock control register                 |     |
| PM0:       | Port mode register 0                             |     |
| PM1:       | Port mode register 1                             |     |
| PM2:       | Port mode register 2                             |     |
| PM3:       | Port mode register 3                             |     |
| PM4:       | Port mode register 4                             |     |
| PM5:       | Port mode register 5                             |     |
| PUO:       | Pull-up resistor option register                 |     |
| [R]        |                                                  |     |
| BXB00.     | Receive huffer register 00                       | 110 |

# [T]

| TCL2:  | Timer clock select register 2         |  |
|--------|---------------------------------------|--|
| TCP20: | 16-bit capture register 20            |  |
| TM00:  | 8-bit timer counter 00                |  |
| TM20:  | 16-bit timer counter 20               |  |
| TMC00: | 8-bit timer mode control register 00  |  |
| TMC20: | 16-bit timer mode control register 20 |  |
| TXS00: | Transmit shift register 00            |  |
| [W]    |                                       |  |
| WDTM:  | Watchdog timer mode register          |  |

# APPENDIX D REVISION HISTORY

# D.1 Major Revisions in This Edition

| Page                                                                 | Description                                                                                                                                 |  |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| pp.21, 22, 24-26 CHAPTER 1 GENERAL                                   |                                                                                                                                             |  |
|                                                                      | Addition of lead-free products                                                                                                              |  |
| μPD789022GB-xxx-8ES-A, μPD789024GB-xxx-8ES-A, μPD789025GB-xxx-8ES-A, |                                                                                                                                             |  |
|                                                                      | μPD789026GB-xxx-8ES-A, μPD78F9026AGB-8ES-A                                                                                                  |  |
|                                                                      | Update of 1.5 78K/0S Series Lineup to latest version                                                                                        |  |
| p.34                                                                 | CHAPTER 2 PIN FUNCTIONS                                                                                                                     |  |
|                                                                      | <ul> <li>Modification of 2.2.12 VPP (μPD78F9026A only)</li> </ul>                                                                           |  |
| pp.70, 75                                                            | CHAPTER 4 PORT FUNCTIONS                                                                                                                    |  |
|                                                                      | Modification of Figure 4-5 Block Diagram of P21                                                                                             |  |
|                                                                      | Modification of Figure 4-10 Block Diagram of P51                                                                                            |  |
| pp.124-126, 132,                                                     | CHAPTER 9 SERIAL INTERFACE 00                                                                                                               |  |
| 133                                                                  | Modification of Caution 2 in Figure 9-6 Format of Baud Rate Generator Control Register 00                                                   |  |
|                                                                      | <ul> <li>Addition of descriptions about 3-wire serial interface in 9.3 (4) Baud rate generator control register 00<br/>(BRGC00).</li> </ul> |  |
|                                                                      | • Modification of Caution 2 in 9.4.2 (d) Baud rate generator control register 00 (BRGC00)                                                   |  |
|                                                                      | <ul> <li>Modification of Caution in Table 9-3 and Table 9-5 Example of Relationship Between System Clock<br/>and Baud Rate</li> </ul>       |  |
| p.208                                                                | CHAPTER 18 RECOMMENDED SOLDERING CONDITIONS                                                                                                 |  |
|                                                                      | <ul> <li>Addition of soldering conditions of lead-free products in Table 18-1 Surface Mounting Type Soldering<br/>Conditions</li> </ul>     |  |

# **D.2 Revision History of Previous Editions**

The revision history of previous editions is described below. The "Applied to:" column indicates the chapterin each edition.

| Edition        | Revision of Previous Edition                                                                                                   | Applied to:                             |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--|
| Second edition | Change of $\mu$ PD789025 and $\mu$ PD789026 from "under development" to "developed"                                            | Throughout                              |  |
|                | Change of symbols in special function register list                                                                            | CHAPTER 3 CPU                           |  |
|                | Change of asynchronous serial interface status register 00 so that it can be manipulated in 1-bit units                        | ARCHITECTURE                            |  |
|                | Change of block diagram of each port                                                                                           | CHAPTER 4 PORT<br>FUNCTIONS             |  |
|                | Change of symbols and flag names of 16-bit timer mode control register 20                                                      | CHAPTER 6 16-BIT TIMER<br>COUNTER       |  |
|                | Change of symbols and flag names of 8-bit timer mode control register 00                                                       | CHAPTER 7 8-BIT TIMER/<br>EVENT COUNTER |  |
|                | Change of symbols and flag names of serial operation mode register 00                                                          | CHAPTER 9 SERIAL                        |  |
|                | Change of symbols and flag names of asynchronous serial interface mode register 00                                             | INTERFACE 00                            |  |
|                | Change of symbols and flag names of asynchronous serial interface status register 00                                           |                                         |  |
|                | Change of asynchronous serial interface status register 00 so that 1-bit memory manipulation instruction can be used           |                                         |  |
|                | Change of symbols and flag names of baud rate generator control register 00                                                    |                                         |  |
|                | Change of flag names of interrupt request flag register                                                                        | CHAPTER 10 INTERRUPT<br>FUNCTIONS       |  |
|                | Change of flag names of interrupt mask flag register                                                                           |                                         |  |
|                | Change of symbols and flag names of key return mode register 00                                                                |                                         |  |
|                | Addition of description on timing of maskable interrupt request acknowledgement                                                |                                         |  |
|                | Addition of setting with Flashpro II                                                                                           | CHAPTER 13 <i>µ</i> PD78F9026           |  |
| Third edition  | Completion of development of $\mu$ PD789022 and $\mu$ PD789024                                                                 | Throughout                              |  |
|                | Change of part number from $\mu$ PD78F9026 to $\mu$ PD78F9026A                                                                 |                                         |  |
|                | Deletion of following products:<br>μPD789022CU-xxx, μPD789024CU-xxx                                                            |                                         |  |
|                | Addition of GB-8ES type package to all models                                                                                  |                                         |  |
|                | Change of circuit type and recommended connection of unused pins in processing of I/O circuit type of each pin and unused pins | CHAPTER 2 PIN<br>FUNCTIONS              |  |
|                | Addition of cautions on rewriting CR20 to operation as timer interrupt                                                         | CHAPTER 6 16-BIT TIMER                  |  |
|                | Addition of cautions on rewriting CR00 to 8-bit compare register 00 (CR00)                                                     | CHAPTER 7 8-BIT<br>TIMER/EVENT COUNTER  |  |
|                | Addition of description of operation to operation as interval timer                                                            |                                         |  |
|                | Addition of description of operation to operation as external event counter                                                    |                                         |  |
|                | Addition of description of operation to operation as square wave output                                                        |                                         |  |
|                | Change of flash programmer from Flashpro II to Flashpro III                                                                    | CHAPTER 13 µPD78F90264                  |  |
|                | Addition of part number of MX78K0S to embedded software                                                                        | APPENDIX B EMBEDDED<br>SOFTWARE         |  |

|                |                                                                                                                      | (2/2)                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| Edition        | Revision of Previous Edition                                                                                         | Applied to:                                                |
| Fourth edition | Deletion of the following packages                                                                                   | Throughout                                                 |
|                | • 42-pin plastic shrink DIP (CU type)                                                                                |                                                            |
|                | • 44-pin plastic QFP (GB-3BS-MTX type)                                                                               |                                                            |
|                | Modification of pin handling of VPP pin                                                                              | CHAPTER 2 PIN<br>FUNCTIONS                                 |
|                | Modification of description in 6.4.1 Operation as timer interrupt and 6.4.2 Operation as timer output                | CHAPTER 6 16-BIT TIMER<br>20                               |
|                | Modification of Caution on rewriting CR20 in 6.4.1 Operation as timer interrupt                                      |                                                            |
|                | Addition of 6.5 Notes on Using 16-Bit Timer 20                                                                       |                                                            |
|                | Modification of description of PE00 flag in Figure 9-5 Format of<br>Asynchronous Serial Interface Status Register 00 | CHAPTER 9 SERIAL<br>INTERFACE 00                           |
|                | Addition of description on reading receive data of UART                                                              |                                                            |
|                | Addition of Caution in Figure 10-2 Format of Interrupt Request Flag Register                                         | CHAPTER 10 INTERRUPT<br>FUNCTIONS                          |
|                | Overall revision of contents related to flash memory programming as 13.1<br>Flash Memory Characteristics             | CHAPTER 13 <i>µ</i> PD78F9026A                             |
|                | Addition of electrical specifications                                                                                | CHAPTER 15 ELECTRICAL<br>SPECIFICATIONS                    |
|                | Addition of characteristics curves for mask ROM version                                                              | CHAPTER 16<br>CHARACTERISTICS CURVES<br>(MASK ROM VERSION) |
|                | Addition of package drawing                                                                                          | CHAPTER 17 PACKAGE<br>DRAWING                              |
|                | Addition of recommended soldering conditions                                                                         | CHAPTER 18<br>RECOMMENDED<br>SOLDERING CONDITIONS          |
|                | Overall revision of contents of development tools                                                                    | APPENDIX A                                                 |
|                | Deletion of embedded software                                                                                        | DEVELOPMENT TOOLS                                          |
|                | Addition of notes on target system design                                                                            | APPENDIX B NOTES ON<br>TARGET SYSTEM DESIGN                |