# 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 product for any application for which it is not intended without the prior written consent of 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; anti-crime 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 majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

# **User's Manual**

# $\mu$ PD78F9500, 78F9501, 78F9502

# 8-Bit Single-Chip Microcontrollers

 $\mu$ PD78F9500  $\mu$ PD78F9501  $\mu$ PD78F9502

Document No. U18681EJ2V0UD00 (2nd edition)

Date Published February 2008 NS

# [MEMO]

#### NOTES FOR CMOS DEVICES —

#### (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_{\rm IL}$  (MAX) and  $V_{\rm IH}$  (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_{\rm IL}$  (MAX) and  $V_{\rm IH}$  (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 VDD 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.

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

Windows is a registered trademark or a trademark 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.

SuperFlash is a registered trademark of Silicon Storage Technology, Inc. in several countries including the United States and Japan.

Caution: This product uses SuperFlash® technology licensed from Silicon Storage Technology, inc.

- The information in this document is current as of February, 2008. 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 customer-designated "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

#### INTRODUCTION

**Target Readers** 

This manual is intended for user engineers who wish to understand the functions of the  $\mu$ PD78F9500, 78F9501, 78F9502 in order to design and develop its application systems and programs.

**Purpose** 

This manual is intended to give users on understanding of the functions described in the **Organization** below.

Organization

Two manuals are available for the  $\mu$ PD78F9500, 78F9501, 78F9502: this manual and the Instruction Manual (common to the 78K/0S Series).

μPD78F9500, 78F9501, 78F9502 User's Manual

- Pin functions
- Internal block functions
- Interrupts
- · Other internal peripheral functions
- · Electrical specifications

78K/0S Series Instructions User's Manual

- CPU function
- Instruction set
- · Instruction description

**How to Use This Manual** 

It is assumed that the readers of this manual have general knowledge of electrical engineering, logic circuits, and microcontrollers.

- $\diamond$  To understand the overall functions of the  $\mu$ PD78F9500, 78F9501, 78F9502
  - → Read this manual in the order of the CONTENTS. The mark <R> shows major revised points. The revised points can be easily searched by copying an "<R>" in the PDF file and specifying it in the "Find what:" field.
- How to read register formats
  - → For a bit number enclosed in angle brackets (<>), the bit name is defined as a reserved word in the RA78K0S, and is defined as an sfr variable using the #pragma sfr directive in the CC78K0S.
- ♦ To learn the detailed functions of a register whose register name is known
  - ightarrow See APPENDIX C REGISTER INDEX.
- ♦ To learn the details of the instruction functions of the 78K/0S Series
  - → Refer to 78K/0S Series Instructions User's Manual (U11047E) separately available.
- $\diamond$  To learn the electrical specifications of the  $\mu$ PD78F9500, 78F9501, 78F9502
  - → See CHAPTER 17 ELECTRICAL SPECIFICATIONS.

**Conventions** Data significance: Higher digits on the left and lower digits on the right

Active low representation:  $\overline{\times\!\times\!\times}$  (overscore over pin or signal name)

**Note**: Footnote for item marked with **Note** in the text

**Caution**: Information requiring particular attention

**Remark**: Supplementary information Numerical representation: Binary ... ×××× or ××××B

Decimal ... xxxx Hexadecimal ... xxxH

However, preliminary versions are not marked as such.

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

| Document Name                              | Document No. |
|--------------------------------------------|--------------|
| μPD78F9500, 78F9501, 78F9502 User's Manual | This manual  |
| 78K/0S Series Instructions User's Manual   | U11047E      |

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

| Document                                 | Document No.                 |         |
|------------------------------------------|------------------------------|---------|
| RA78K0S Assembler Package                | Operation                    | U16656E |
|                                          | Language                     | U14877E |
|                                          | Structured Assembly Language | U11623E |
| CC78K0S C Compiler                       | Operation                    | U16654E |
|                                          | Language                     | U14872E |
| ID78K0S-QB Ver. 2.81 Integrated Debugger | Operation                    | U17287E |
| PM plus Ver.5.20                         |                              | U16934E |

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

| Document Name                                             | Document No. |
|-----------------------------------------------------------|--------------|
| QB-78K0SKX1 In-Circuit Emulator                           | U18219E      |
| QB-MINI2 On-chip debug emulator with programming function | U18371E      |

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-FP4 Flash Memory Programmer User's Manual | U15260E      |
| PG-FP5 Flash Memory Programmer User's Manual | U18865E      |

# **Other Related Documents**

| Document Name                                                                      | Document No. |
|------------------------------------------------------------------------------------|--------------|
| SEMICONDUCTOR SELECTION GUIDE - Products and Packages -                            | X13769X      |
| Semiconductor Device Mount Manual                                                  | Note         |
| Quality Grades on NEC Semiconductor Devices                                        | C11531E      |
| NEC Semiconductor Device Reliability/Quality Control System                        | C10983E      |
| Guide to Prevent Damage for Semiconductor Devices by Electrostatic Discharge (ESD) | C11892E      |

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

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

# **CONTENTS**

| СНАРТ | TER 1   | OVERVIEW                                   | 13 |
|-------|---------|--------------------------------------------|----|
| 1.1   | Featu   | res                                        | 13 |
| 1.2   | Order   | ing Information                            | 14 |
| 1.3   | Pin Co  | onfiguration (Top View)                    | 15 |
| 1.4   | 78K05   | S/Kx1+ Product Lineup                      | 16 |
|       |         | Diagram                                    |    |
| 1.6   | Funct   | ional Outline                              | 18 |
| СНАРТ | TER 2   | PIN FUNCTIONS                              | 19 |
|       |         | unction List                               |    |
| 2.2   | Pin Fu  | unctions                                   | 20 |
|       | 2.2.1   | P20 to P23 (Port 2)                        | 20 |
|       | 2.2.2   | P32 and P34 (Port 3)                       | 21 |
|       |         | P40 and P43 (Port 4)                       |    |
|       | 2.2.4   | RESET                                      | 21 |
|       | 2.2.5   | V <sub>DD</sub>                            | 21 |
|       |         | Vss                                        |    |
| 2.3   | Pin I/C | Circuits and Connection of Unused Pins     | 22 |
| СНАРТ | TER 3   | CPU ARCHITECTURE                           | 23 |
| 3.1   | Memo    | ory Space                                  | 23 |
|       | 3.1.1   | Internal program memory space              | 26 |
|       | 3.1.2   | Internal data memory space                 | 27 |
|       | 3.1.3   | Special function register (SFR) area       | 27 |
|       | 3.1.4   | Data memory addressing                     | 27 |
| 3.2   | Proce   | ssor Registers                             | 30 |
|       | 3.2.1   | Control registers                          | 30 |
|       | 3.2.2   | General-purpose registers                  | 33 |
|       |         | Special function registers (SFRs)          |    |
| 3.3   | Instru  | ction Address Addressing                   | 38 |
|       | 3.3.1   | Relative addressing                        | 38 |
|       | 3.3.2   | Immediate addressing                       | 39 |
|       | 3.3.3   | Table indirect addressing                  | 39 |
|       |         | Register addressing                        |    |
| 3.4   | -       | nd Address Addressing                      |    |
|       |         | Direct addressing                          |    |
|       |         | Short direct addressing                    |    |
|       |         | Special function register (SFR) addressing |    |
|       |         | Register addressing                        |    |
|       | 3.4.5   | Register indirect addressing               | 45 |
|       | 3.4.6   | Based addressing                           | 46 |

| 3.4.7      | Stack addressing                                                                            | . 47 |
|------------|---------------------------------------------------------------------------------------------|------|
|            |                                                                                             |      |
| CHAPTER 4  | PORT FUNCTIONS                                                                              | 48   |
| 4.1 Functi | ions of Ports                                                                               | .48  |
|            | onfiguration                                                                                |      |
| 4.2.1      | Port 2                                                                                      | . 49 |
| 4.2.2      | Port 3                                                                                      | . 53 |
| 4.2.3      | Port 4                                                                                      | . 54 |
| 4.3 Regist | ters Controlling Port Functions                                                             | .55  |
| 4.4 Opera  | tion of Port Function                                                                       | .59  |
| 4.4.1      | Writing to I/O port                                                                         | . 59 |
| 4.4.2      | Reading from I/O port                                                                       | . 59 |
| 4.4.3      | Operations on I/O port                                                                      | . 59 |
|            |                                                                                             |      |
| CHAPTER 5  | CLOCK GENERATORS                                                                            | .60  |
| 5.1 Functi | ions of Clock Generators                                                                    | 60   |
| 5.1.1      | System clock oscillators                                                                    | . 60 |
|            | Clock oscillator for interval time generation                                               |      |
|            | guration of Clock Generators                                                                |      |
| 5.3 Regist | ters Controlling Clock Generators                                                           | 63   |
| 5.4 Syster | n Clock Oscillators                                                                         | 65   |
| 5.4.1      | High-speed internal oscillator                                                              | . 65 |
| 5.4.2      | External clock input circuit                                                                | . 65 |
| 5.4.3      | Prescaler                                                                                   | . 65 |
| -          | tion of CPU Clock Generator                                                                 |      |
| 5.6 Opera  | tion of Clock Generator Supplying Clock to Peripheral Hardware                              | .70  |
| CHARTER 6  | 8-BIT TIMER H1                                                                              | 70   |
|            |                                                                                             |      |
|            | ons of 8-Bit Timer H1                                                                       |      |
| _          | guration of 8-Bit Timer H1                                                                  |      |
| _          | ters Controlling 8-Bit Timer H1                                                             |      |
| -          | tion of 8-Bit Timer H1                                                                      |      |
|            | Operation as interval timer/square-wave output                                              |      |
| 6.4.2      | Operation as PWM output mode                                                                | . 81 |
| CHAPTER 7  | WATCHDOG TIMER                                                                              | 87   |
|            |                                                                                             |      |
|            | ons of Watchdog Timer                                                                       |      |
| •          | guration of Watchdog Timer                                                                  |      |
|            | ters Controlling Watchdog Timer                                                             |      |
|            | tion of Watchdog Timer                                                                      |      |
| 7.4.1      | Watchdog timer operation when "low-speed internal oscillator cannot be stopped" is selected | _    |
| 7.40       | option byte                                                                                 |      |
| 7.4.2      |                                                                                             |      |
|            | selected by option byte                                                                     | . 34 |

| 7.4.3 Watchdog timer operation in STOP mode (when "low-speed internal oscillator software" is selected by option byte) | • • • • • • • • • • • • • • • • • • • • |
|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|                                                                                                                        |                                         |
| 7.4.4 Watchdog timer operation in HALT mode (when "low-speed internal oscillator                                       |                                         |
| software" is selected by option byte)                                                                                  | 97                                      |
| CHAPTER 8 INTERRUPT FUNCTIONS                                                                                          | 98                                      |
| 8.1 Interrupt Function Types                                                                                           | 98                                      |
| 8.2 Interrupt Sources and Configuration                                                                                |                                         |
| 8.3 Interrupt Function Control Registers                                                                               | 100                                     |
| 8.4 Interrupt Servicing Operation                                                                                      | 102                                     |
| 8.4.1 Maskable interrupt request acknowledgment operation                                                              | 102                                     |
| 8.4.2 Multiple interrupt servicing                                                                                     | 104                                     |
| 8.4.3 Interrupt request pending                                                                                        | 106                                     |
| CHAPTER 9 STANDBY FUNCTION                                                                                             | 107                                     |
| 9.1 Standby Function and Configuration                                                                                 | 107                                     |
| 9.1.1 Standby function                                                                                                 | 107                                     |
| 9.2 Standby Function Operation                                                                                         | 109                                     |
| 9.2.1 HALT mode                                                                                                        | 109                                     |
| 9.2.2 STOP mode                                                                                                        | 111                                     |
| CHAPTER 10 RESET FUNCTION                                                                                              | 114                                     |
| 10.1 Register for Confirming Reset Source                                                                              | 118                                     |
| CHAPTER 11 POWER-ON-CLEAR CIRCUIT                                                                                      | 119                                     |
| 11.1 Functions of Power-on-Clear Circuit                                                                               | 119                                     |
| 11.2 Configuration of Power-on-Clear Circuit                                                                           |                                         |
| 11.3 Operation of Power-on-Clear Circuit                                                                               |                                         |
| 11.4 Cautions for Power-on-Clear Circuit                                                                               |                                         |
| CHAPTER 12 LOW-VOLTAGE DETECTOR                                                                                        | 123                                     |
| 12.1 Functions of Low-Voltage Detector                                                                                 | 123                                     |
| 12.2 Configuration of Low-Voltage Detector                                                                             |                                         |
| 12.3 Registers Controlling Low-Voltage Detector                                                                        | 124                                     |
| 12.4 Operation of Low-Voltage Detector                                                                                 |                                         |
| 12.5 Cautions for Low-Voltage Detector                                                                                 | 130                                     |
| CHAPTER 13 OPTION BYTE                                                                                                 | 133                                     |
| 13.1 Functions of Option Byte                                                                                          | 133                                     |
| 13.2 Format of Option Byte                                                                                             |                                         |
| 13.3 Caution When the RESET Pin Is Used as an Input-Only Port Pin (P34)                                                | 135                                     |

| CHAPTE | R 14 FLASH MEMORY                                                                              | 136   |
|--------|------------------------------------------------------------------------------------------------|-------|
| 14.1   | Features                                                                                       | 136   |
| 14.2   | Memory Configuration                                                                           | 137   |
| 14.3   | Functional Outline                                                                             | 137   |
| 14.4   | Writing with Flash Memory Programmer                                                           | 138   |
|        | Programming Environment                                                                        |       |
| 14.6   | Processing of Pins on Board                                                                    |       |
|        | 14.6.1 EXCLK pin                                                                               |       |
|        | 14.6.2 RESET pin                                                                               |       |
|        | 14.6.3 Port pins                                                                               |       |
|        | 14.6.4 Power supply                                                                            |       |
| 14.7   | On-Board and Off-Board Flash Memory Programming                                                |       |
|        | 14.7.1 Flash memory programming mode                                                           |       |
|        | 14.7.2 Communication commands                                                                  |       |
| 110    | 14.7.3 Security settings                                                                       |       |
| 14.0   | Flash Memory Programming by Self Programming                                                   |       |
|        | 14.8.2 Cautions on self programming function                                                   |       |
|        | 14.8.3 Registers used for self-programming function                                            |       |
|        | 14.8.4 Example of shifting normal mode to self programming mode                                |       |
|        | 14.8.5 Example of shifting self programming mode to normal mode                                |       |
|        | 14.8.6 Example of block erase operation in self programming mode                               |       |
|        | 14.8.7 Example of block blank check operation in self programming mode                         |       |
|        | 14.8.8 Example of byte write operation in self programming mode                                |       |
|        | 14.8.9 Example of internal verify operation in self programming mode                           |       |
|        | 14.8.10 Examples of operation when command execution time should be minimized in self program  |       |
|        | mode                                                                                           | _     |
|        | 14.8.11 Examples of operation when interrupt-disabled time should be minimized in self program | ıming |
|        | mode                                                                                           | . 179 |
|        |                                                                                                |       |
| CHAPTE | R 15 ON-CHIP DEBUG FUNCTION                                                                    | 190   |
| 15.1   | Connecting QB-MINI2 to $\mu$ PD78F9500, 78F9501, 78F9502                                       | 190   |
|        | 15.1.1 Connection of INTP1 pin                                                                 |       |
|        | 15.1.2 Connection of EXCLK and P22 pins                                                        | . 192 |
| 15.2   | Securing of user resources                                                                     | 193   |
|        |                                                                                                |       |
| CHAPTE | R 16 INSTRUCTION SET OVERVIEW                                                                  | 194   |
| 16.1   | Operation                                                                                      | 194   |
|        | 16.1.1 Operand identifiers and description methods                                             | . 194 |
|        | 16.1.2 Description of "Operation" column                                                       | . 195 |
|        | 16.1.3 Description of "Flag" column                                                            |       |
|        | Operation List                                                                                 |       |
| 16.3   | Instructions Listed by Addressing Type                                                         | .201  |

| CHAPTER 17 ELECTRICAL SPECIFICATIONS                                             | 204 |
|----------------------------------------------------------------------------------|-----|
| CHAPTER 18 PACKAGE DRAWING                                                       | 214 |
| CHAPTER 19 RECOMMENDED SOLDERING CONDITIONS                                      | 215 |
| APPENDIX A DEVELOPMENT TOOLS                                                     | 216 |
| A.1 Software Package                                                             |     |
| A.2 Language Processing Software                                                 |     |
| A.3 Control Software                                                             |     |
| A.4 Flash Memory Writing Tools                                                   |     |
| A.5 Debugging Tools (Hardware)                                                   |     |
| A.5.1 When using in-circuit emulator QB-78K0SKX1                                 |     |
| A.5.2 When using on-chip debug emulator QB-MINI2  A.6 Debugging Tools (Software) |     |
| APPENDIX B NOTES ON DESIGNING TARGET SYSTEM                                      | 223 |
| APPENDIX C REGISTER INDEX                                                        | 225 |
| C.1 Register Index (Register Name)                                               | 225 |
| C.2 Register Index (Symbol)                                                      |     |
| APPENDIX D LIST OF CAUTIONS                                                      | 228 |
| APPENDIX E REVISION HISTORY                                                      | 235 |
| F 1 Major Revisions in This Edition                                              | 235 |

#### **CHAPTER 1 OVERVIEW**

#### 1.1 Features

#### O 78K0S CPU core

O ROM and RAM capacities

| Item Part number | Program Memory (Flash Memory) | Memory (Internal High-Speed RAM) |
|------------------|-------------------------------|----------------------------------|
| μPD78F9500       | 1 KB                          | 128 bytes                        |
| μPD78F9501       | 2 KB                          |                                  |
| μPD78F9502       | 4 KB                          |                                  |

O Minimum instruction execution time: 0.2 μs (with 10 MHz@4.0 to 5.5 V operation)

#### O Clock

• High-speed system clock ... Selected from the following two sources

- External clock: 2 to 10 MHz

- High-speed internal oscillator: 8 MHz  $\pm 2\%$  (-10 to +85°C), 8 MHz  $\pm 5\%$  (-40 to +85°C)

• Low-speed internal oscillator 240 kHz (TYP.) ... Watchdog timer, timer clock in intermittent operation

O I/O ports: 8 (CMOS I/O: 7, CMOS input: 1)

O Timer: 2 channels

• 8-bit timer: 1 channel ... PWM output × 1

• Watchdog timer: 1 channel ... Operable with low-speed internal oscillation clock

O On-chip power-on-clear (POC) circuit (A reset is automatically generated when the voltage drops to 2.1 V ±0.1 V or below)

- O On-chip low voltage detector (LVI) circuit (An interrupt/reset (selectable) is generated when the detection voltage is reached)
  - Detection voltage: Selectable from ten levels between 2.35 and 4.3 V
- O Single-power-supply flash memory
  - Flash self programming enabled
  - Software protection function: Protected from outside party copying (no flash reading command)
  - Time required for writing by dedicated flash memory programmer: Approximately 3 seconds (4 KB)
  - \* Write operations on mass production lines supported
- O Safety function
  - Watchdog timer operated by clock independent from CPU
    - ... A hang-up can be detected even if the system clock stops
  - Supply voltage drop detectable by LVI
    - ... Appropriate processing can be executed before the supply voltage drops below the operation voltage
  - Equipped with option byte function
    - ... Important system operation settings set in hardware
- O Assembly and C language supported
- O Enhanced development environment
  - Support for full-function emulator (IECUBE), simplified emulator (MINICUBE2), and simulator Note

**Note** Under development for the  $\mu$ PD78F9500, 78F9501, 78F9502

- O Supply voltage:  $V_{DD} = 2.0$  to 5.5 V
  - \* Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage ( $V_{POC}$ ) of the power-on-clear (POC) circuit is 2.1 V  $\pm$ 0.1 V.
- O Operating temperature range:  $T_A = -40 \text{ to } +85^{\circ}\text{C}$

# 1.2 Ordering Information



#### [Part number list]

 $\mu$  PD78F9500MA-CAC-A

 $\mu$  PD78F9501MA-CAC-A

 $\mu$  PD78F9502MA-CAC-A

# 1.3 Pin Configuration (Top View)

10-pin plastic SSOP



INTP0, INTP1:External interrupt inputTOH1:Timer outputP20 to P23:Port 2Vpd:Power supplyP30, P34:Port 3Vss:Ground

P40, P43: Port 4 EXCLK: External Clock Input RESET: Reset (Main System Clock)

# 1.4 78K0S/Kx1+ Product Lineup

The following table shows the product lineup of the 78K0S/Kx1+.

| Part Number                        |                           | 78K0S/KU1+                                                                                                                                                                                       | 78K0S/KY1+                                                                                                                                                | 78K0S/KA1+      |                | 78K0S/KB1+ |
|------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|------------|
| Number of pins                     |                           | 10 pins                                                                                                                                                                                          | 16 pins                                                                                                                                                   | 20 pins         |                | 30/32 pins |
| Internal                           | Flash memory              | -                                                                                                                                                                                                | KB, 4 KB                                                                                                                                                  | 2 KB 4 KB       |                | 4 KB, 8 KB |
| memory                             | RAM                       |                                                                                                                                                                                                  | bytes                                                                                                                                                     | 128             | 256            | 256 bytes  |
|                                    | T D WI                    | 120                                                                                                                                                                                              | bytos                                                                                                                                                     | bytes           | bytes          | 200 Bytes  |
| Supply volt                        | age                       | V <sub>DD</sub> = 2.0 to 5.5 V <sup>Note 1</sup>                                                                                                                                                 |                                                                                                                                                           |                 |                |            |
| Minimum instruction execution time |                           | 0.20 $\mu$ s (10 MHz, $V_{DD} = 4.0$ to 5.5 V)<br>0.33 $\mu$ s (6 MHz, $V_{DD} = 3.0$ to 5.5 V)<br>0.40 $\mu$ s (5 MHz, $V_{DD} = 2.7$ to 5.5 V)<br>1.0 $\mu$ s (2 MHz, $V_{DD} = 2.0$ to 5.5 V) |                                                                                                                                                           |                 |                |            |
| System clo<br>(oscillation         |                           |                                                                                                                                                                                                  | High-speed internal oscillation (8 MHz (TYP.)) Crystal/ceramic oscillation (2 to 10 MHz) <sup>Note 2</sup> External clock input oscillation (2 to 10 MHz) |                 |                |            |
| Clock for T (oscillation           | MH1 and WDT<br>frequency) |                                                                                                                                                                                                  | Low-speed internal oscillation (240 kHz (TYP.))                                                                                                           |                 |                |            |
| Port                               | CMOS I/O                  | 7                                                                                                                                                                                                | 13                                                                                                                                                        | 1               | 5              | 24         |
|                                    | CMOS input                | 1                                                                                                                                                                                                | 1                                                                                                                                                         |                 | 1              | 1          |
|                                    | CMOS output               | -                                                                                                                                                                                                | -                                                                                                                                                         |                 | 1              | 1          |
| Timer                              | 16-bit (TM0)              | 1 ch <sup>Note 3</sup>                                                                                                                                                                           |                                                                                                                                                           |                 |                |            |
|                                    | 8-bit (TMH)               | 1 ch                                                                                                                                                                                             |                                                                                                                                                           |                 |                |            |
|                                    | 8-bit (TM8)               | _ 1 ch                                                                                                                                                                                           |                                                                                                                                                           |                 |                | ch         |
|                                    | WDT                       |                                                                                                                                                                                                  | 1                                                                                                                                                         | ch              |                |            |
| Serial inter                       | ace                       | – LIN-Bus-supporting UA                                                                                                                                                                          |                                                                                                                                                           | ting UART: 1 ch |                |            |
| A/D conver                         | ter <sup>Note 4</sup>     | 10 bits: 4 ch (2.7 to 5.5 V) <sup>Note 4</sup>                                                                                                                                                   |                                                                                                                                                           |                 |                |            |
| Multiplier (8                      | B bits × 8 bits)          | -                                                                                                                                                                                                |                                                                                                                                                           | Provided        |                | Provided   |
| Interrupts                         | Internal                  | 5 <sup>Note 5</sup>                                                                                                                                                                              |                                                                                                                                                           | 9               |                |            |
|                                    | External                  | 2                                                                                                                                                                                                |                                                                                                                                                           | 4               |                |            |
| Reset                              | RESET pin                 | Provided                                                                                                                                                                                         |                                                                                                                                                           |                 |                |            |
|                                    | POC                       | 2.1 V (TYP.)                                                                                                                                                                                     |                                                                                                                                                           |                 |                |            |
|                                    | LVI                       | Provided (selectable by software)                                                                                                                                                                |                                                                                                                                                           |                 |                |            |
|                                    | WDT                       | Provided                                                                                                                                                                                         |                                                                                                                                                           |                 |                |            |
| Operating t                        | emperature range          | Standard products:<br>-40 to +85°C                                                                                                                                                               | Standard products, (A) (A2) grade products: -4                                                                                                            |                 | ts: -40 to +85 | 5°C        |

**Notes 1.** Use these products in the following voltage range because the detection voltage (V<sub>POC</sub>) of the power-on-clear (POC) circuit is the supply voltage range.

Standard product, (A) grade product: 2.2 to 5.5 V, (A2) grade product: 2.26 to 5.5 V

- **2.** This product ( $\mu$ PD78F950x) does not support crystal/ceramic oscillation
- 3. The product without A/D converter (µPD78F950x) in the 78K0S/KU1+ has no 16 bit timer (TM0).
- **4.** The product without A/D converter ( $\mu$ PD78F95xx) is provided for the 78K0S/KU1+ and 78K0S/KY1+ respectively. This product has no A/D converter.
- **5.** The product without A/D converter in the 78K0S/KU1+ has 2 factors, while the products without A/D converter in the 78K0S/KY1+ has 4 factors.

# 1.5 Block Diagram



# 1.6 Functional Outline

| Item               |                                      |              |                       | μPD78F9500 μPD78F9501 μPD78F9502                                                                                                        |                                    |                   |  |  |  |  |
|--------------------|--------------------------------------|--------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------------|--|--|--|--|
| Internal Flash mem |                                      | Flash memory | 1 KB                  | 2 KB                                                                                                                                    | 4 KB                               |                   |  |  |  |  |
| memo               | ory                                  |              | High-speed RAM        | 128 bytes                                                                                                                               |                                    | •                 |  |  |  |  |
| Memo               | ry spac                              | е            |                       | 64 KB                                                                                                                                   |                                    |                   |  |  |  |  |
|                    | _                                    | Hi           | gh-speed system clock | External clock input: 10 MHz                                                                                                            | (V <sub>DD</sub> = 2.7 to 5.5 V)   |                   |  |  |  |  |
| Clock              | Main                                 |              | ternal high-speed     | 8 MHz (TYP.)                                                                                                                            |                                    |                   |  |  |  |  |
| O                  | Internal low-speed oscillation clock |              |                       | 240 kHz (TYP.)                                                                                                                          |                                    |                   |  |  |  |  |
| Gene               | ral-purp                             | ose          | registers             | 8 bits × 8 registers                                                                                                                    |                                    |                   |  |  |  |  |
| Instru             | ction ex                             | cecut        | ion time              | 0.2 μs/0.4 μs/0.8 μs/1.6 μs/3                                                                                                           | 3.2 $\mu$ s (high-speed system clo | ock: fx = 10 MHz) |  |  |  |  |
| I/O po             | ort                                  |              |                       | Total:         8 pins           CMOS I/O:         7 pins           CMOS input:         1 pin                                            |                                    |                   |  |  |  |  |
| Timer              |                                      |              |                       | 8-bit timer (timer H1):     Watchdog timer:                                                                                             |                                    |                   |  |  |  |  |
|                    |                                      |              | Timer output          | 2 pins (PWM: 1 pin)                                                                                                                     |                                    |                   |  |  |  |  |
| Vecto              | red inte                             | rrupt        | External              | 2                                                                                                                                       |                                    |                   |  |  |  |  |
| source             | es                                   |              | Internal              | 2                                                                                                                                       |                                    |                   |  |  |  |  |
| Reset              |                                      |              |                       | Reset by RESET pin     Internal reset by watchdog timer     Internal reset by power-on clear     Internal reset by low-voltage detector |                                    |                   |  |  |  |  |
| Suppl              | y voltaç                             | je           |                       | $V_{DD} = 2.0 \text{ to } 5.5 \text{ V}^{\text{Note}}$                                                                                  |                                    |                   |  |  |  |  |
| Opera              | ting ter                             | npera        | ature range           | T <sub>A</sub> = -40 to +85°C                                                                                                           |                                    |                   |  |  |  |  |
| Packa              | ige                                  |              |                       | 10-pin plastic SSOP                                                                                                                     |                                    |                   |  |  |  |  |

Note Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (VPOC) of the power-on- clear (POC) circuit is 2.1 V  $\pm$ 0.1 V.

# **CHAPTER 2 PIN FUNCTIONS**

#### 2.1 Pin Function List

# (1) Port pins

| Pin Name            | I/O   |                                                                                     | Function                                                      | After Reset | Alternate-Function<br>Pin |
|---------------------|-------|-------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------|---------------------------|
| P20                 | I/O   | Port 2.                                                                             |                                                               | Input port  | TOH1                      |
| P21                 |       | 4-bit I/O port.                                                                     |                                                               |             | INTP0                     |
| P22                 |       | ·                                                                                   | output mode in 1-bit units.  Stor can be connected by setting |             | _                         |
| P23 <sup>Note</sup> |       | software.                                                                           | , ,                                                           |             | EXCLK <sup>Note</sup>     |
| P32                 | I/O   | Port 3 An on-chip pull-up resistor can be connected by setting                      | Can be set to input or output mode in 1-bit units.            | Input port  | INTP1                     |
| P34 <sup>Note</sup> | Input | software.                                                                           | Input only                                                    | Input port  | RESET                     |
| P40, P43            | I/O   | Port 4. 2-bit I/O port. Can be set to input or o An on-chip pull-up resis software. | Input port                                                    | -           |                           |

Note For the setting method for pin functions, see CHAPTER 13 OPTION BYTE.

Caution The P22 and P23/EXCLK pins are pulled down during reset. The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.

# (2) Non-port pins

| Pin Name              | I/O    | Function                                                         | After Reset | Alternate-<br>Function Pin |
|-----------------------|--------|------------------------------------------------------------------|-------------|----------------------------|
| INTP0                 | Input  | External interrupt input for which the valid edge (rising edge,  | Input port  | P21                        |
| INTP1                 |        | falling edge, or both rising and falling edges) can be specified |             | P32                        |
| TOH1                  | Output | 8-bit timer H1 output                                            | Input port  | P20                        |
| RESET Note            | Input  | System reset input                                               | Input port  | P34 <sup>Note</sup>        |
| EXCLK <sup>Note</sup> | Input  | External clock input for main system clock                       | Input port  | P23 <sup>Note</sup>        |
| V <sub>DD</sub>       | _      | Positive power supply                                            | _           | _                          |
| Vss                   | _      | Ground potential                                                 | _           | _                          |

Note For the setting method for pin functions, see CHAPTER 13 OPTION BYTE.

Caution The P22 and P23/EXCLK pins are pulled down during reset. The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.

#### 2.2 Pin Functions

# 2.2.1 P20 to P23 (Port 2)

P20 to P23 constitute a 4-bit I/O port. In addition to the function as I/O port pins, these pins also have a function to output a timer signal, input an external interrupt request signal, and input an external clock for the main system clock.

P23 also functions as the EXCLK. For the setting method for pin functions, see CHAPTER 13 OPTION BYTE.

These pins can be set to the following operation modes in 1-bit units.

#### (1) Port mode

P20 to P23 function as a 4-bit I/O port. Each bit of this port can be set to the input or output mode by using port mode register 2 (PM2). In addition, an on-chip pull-up resistor can be connected to the port by using pull-up resistor option register 2 (PU2).

# (2) Control mode

P20 to P23 function to output a timer signal, and input an external interrupt request signal.

#### (a) TOH1

This pin outputs a signal from 8-bit timer H1.

# (b) INTP0

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

#### (c) EXCLK

This pin inputs and external clock input for the main system clock.

Caution The P22 and P23/EXCLK pins are pulled down during reset.

#### 2.2.2 P32 and P34 (Port 3)

P32 is a 1-bit I/O port. In addition to the function as an I/O port pin, this pin also has a function to input an external interrupt request signal.

P34 is a 1-bit input-only port. This pin is also used as a RESET pin, and when the power is turned on, this is the reset function.

For the setting method for pin functions, see CHAPTER 13 OPTION BYTE.

When P34 is used as an input port pin, connect the pull-up resistor.

P32 and P34 can be set to the following operation modes in 1-bit units.

#### (1) Port mode

P32 functions as a 1-bit I/O port. This pin can be set to the input or output mode by using port mode register 3 (PM3). In addition, an on-chip pull-up resistor can be connected to the port by using pull-up resistor option register 3 (PU3).

P34 functions as a 1-bit input-only port.

#### (2) Control mode

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

Caution The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.

#### 2.2.3 P40 and P43 (Port 4)

P40 and P43 constitute a 2-bit I/O port. Each bit of this port can be set to the input or output mode by using port mode register 4 (PM4). In addition, an on-chip pull-up resistor can be connected to the port by using pull-up resistor option register 4 (PU4).

# 2.2.4 **RESET**

This pin inputs an active-low system reset signal. When the power is turned on, this is the reset function, regardless of the option byte setting.

Caution The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.

# 2.2.5 VDD

This is the positive power supply pin.

#### 2.2.6 Vss

This is the ground pin.

Be sure to connect Vss to a stabilized GND (= 0 V).

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

Table 2-1 shows I/O circuit type of each pin and the connections of unused pins.

For the configuration of the I/O circuit of each type, refer to **Figure 2-1**.

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

| Pin Name    | I/O Circuit Type | I/O   | Recommended Connection of Unused Pin                                         |
|-------------|------------------|-------|------------------------------------------------------------------------------|
| P20/TOH1    | 8-A              | I/O   | Input: Individually connect to VDD or Vss via resistor.                      |
| P21/INTP0   |                  |       | Output: Leave open.                                                          |
| P22         |                  |       |                                                                              |
| P23/EXCLK   |                  |       |                                                                              |
| P32/INTP1   |                  |       |                                                                              |
|             |                  |       |                                                                              |
| P34/RESET   | 2-A              | Input | Set ENPU34 to "1" on the option byte, and leave the pin open.                |
| P40 and P43 | 8-A              | I/O   | Input: Individually connect to VDD or Vss via resistor.  Output: Leave open. |

Figure 2-1. Pin I/O Circuits



# **CHAPTER 3 CPU ARCHITECTURE**

# 3.1 Memory Space

The  $\mu$ PD78F9500, 78F9501, 78F9502 can access up to 64 KB of memory space. Figures 3-1 to 3-3 show the memory maps.



Figure 3-1. Memory Map (μPD78F9500)

**Remark** The option byte and protect byte are 1 byte each.

FFFFH Special function registers (SFR)  $256 \times 8$  bits FF00H FEFFH Internal high-speed RAM  $128 \times 8 \text{ bits}$ FE80H FE7FH Use prohibited Data memory space 07FFH 0800H 07FFH Program area 0082H 0081H Protect byte area Flash memory 0080H Option byte area Program memory 2,048 × 8 bits 007FH space CALLT table area 0040H 003FH Program area 0014H 0013H Vector table area 0000H 0000H

Figure 3-2. Memory Map (μPD78F9501)

**Remark** The option byte and protect byte are 1 byte each.

FFFFH Special function registers (SFR)  $256 \times 8$  bits FF00H FEFFH Internal high-speed RAM  $128 \times 8$  bits FE80H FD7FH Use prohibited Data memory space 0 F F F H 1000H 0 F F F H Program area 0082H 0081H Protect byte area Flash memory 0080H Option byte area Program memory  $4,096 \times 8$  bits 007FH space CALLT table area 0040H 003FH Program area 0014H 0013H Vector table area 0000H 0000H

Figure 3-3. Memory Map (μPD78F9502)

**Remark** The option byte and protect byte are 1 byte each.

#### 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$ PD78F9500, 78F9501, 78F9502 provide the following internal ROMs (or flash memory) containing the following capacities.

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

| Part Number | Internal ROM |                |  |  |  |
|-------------|--------------|----------------|--|--|--|
|             | Structure    | Capacity       |  |  |  |
| μPD78F9500  | Flash memory | 1,024 × 8 bits |  |  |  |
| μPD78F9501  |              | 2,048 × 8 bits |  |  |  |
| μPD78F9502  |              | 4,096 × 8 bits |  |  |  |

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

# (1) Vector table area

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

Table 3-2. Vector Table

| Vector Table Address | Interrupt Request |
|----------------------|-------------------|
| 0000H                | Reset             |
| 0006H                | INTLVI            |
| 0008H                | INTP0             |
| 000AH                | INTP1             |
| 000CH                | INTTMH1           |

# (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) Option byte area

The option byte area is the 1-byte area of address 0080H. For details, refer to **CHAPTER 13 OPTION BYTE**.

# (4) Protect byte area

The protect byte area is the 1-byte area of address 0081H. For details, refer to **CHAPTER 14 FLASH MEMORY**.

#### 3.1.2 Internal data memory space

128-byte internal high-speed RAM is provided in the  $\mu$ PD78F9500, 78F9501, 78F9502.

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

# 3.1.3 Special function register (SFR) area

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

#### 3.1.4 Data memory addressing

The  $\mu$ PD78F9500, 78F9501, 78F9502 are provided with a wide range of addressing modes to make memory manipulation as efficient as possible. The area (FE80H to FEFFH) which contains a data memory and the special function register (SFR) area can be accessed using a unique addressing mode in accordance with each function. Figures 3-4 to 3-6 illustrate the data memory addressing.



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



Figure 3-5. Data Memory Addressing (µPD78F9501)



Figure 3-6. Data Memory Addressing (μPD78F9502)

# 3.2 Processor Registers

The  $\mu$ PD78F9500, 78F9501, 78F9502 provide the following on-chip processor registers.

#### 3.2.1 Control registers

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

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

The program counter is a 16-bit register which holds the address information of the next program to be executed.

In normal operation, the PC is automatically incremented according to the number of bytes of the instruction to be fetched. When a branch instruction is executed, immediate data or register contents are set.

Reset signal generation sets the reset vector table values at addresses 0000H and 0001H to the program counter.

Figure 3-7. Program Counter Configuration

|      | 15   |      |      |      |      |      |     |     |     |     |     |     |     |     |     | 0   |
|------|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| PC F | 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 stored in stack area upon interrupt request generation or PUSH PSW instruction execution and are restored upon execution of the RETI and POP PSW instructions. Reset signal generation sets PSW to 02H.

Figure 3-8. Program Status Word Configuration



#### (a) Interrupt enable flag (IE)

This flag controls interrupt request acknowledge operations of the CPU.

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

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

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

#### (b) Zero flag (Z)

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

# (c) Auxiliary carry flag (AC)

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

# (d) Carry flag (CY)

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

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

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

Figure 3-9. Stack Pointer Configuration

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

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

Each stack operation saves/restores data as shown in Figures 3-10 and 3-11.

- Cautions 1. Since reset signal generation makes the SP contents undefined, be sure to initialize the SP before using the stack memory.
  - 2. Stack pointers can be set only to the high-speed RAM area, and only the lower 10 bits can be actually set.

0FF00H is in the SFR area, not the high-speed RAM area, so it was converted to 0FB00H that is in the high-speed RAM area.

When the value is actually pushed onto the stack, 1 is subtracted from 0FB00H to become 0FAFFH, but that value is not in the high-speed RAM area, so it is converted to 0FEFFH, which is the same value as when 0FF00H is set to the stack pointer.

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



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



# 3.2.2 General-purpose registers

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

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

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

Figure 3-12. General-Purpose Register Configuration

# (a) Function names

| 16-bit processing |   | 8-bit processing |
|-------------------|---|------------------|
| HL                |   | Н                |
| I III             |   | L                |
| DE                |   | D                |
| DE                |   | E                |
| BC                |   | В                |
| ВС                |   | С                |
| AX                |   | А                |
| AX                |   | Х                |
| 15                | ) | 7 0              |

## (b) Absolute names

| 16-bit processing | _        | 8-bit processing |
|-------------------|----------|------------------|
| RP3               |          | R7               |
| nr3               |          | R6               |
| DDO               |          | R5               |
| RP2               |          | R4               |
| DD4               |          | R3               |
| RP1               |          | R2               |
| PP0               |          | R1               |
| RP0               |          | R0               |
| 15                | <u> </u> | 7 0              |

#### 3.2.3 Special function registers (SFRs)

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

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

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

Each manipulation bit unit can be specified as follows.

#### • 1-bit manipulation

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

#### • 8-bit manipulation

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

#### • 16-bit manipulation

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

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

#### Symbol

Indicates the addresses of the implemented special function registers. It is defined as a reserved word in the RA78K0S, and is defined as an sfr variable using the #pragma sfr directive in the CC78K0S. 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/writeR: Read onlyW: Write only

# • Number of bits manipulated simultaneously

Indicates the bit units (1, 8, and 16) in which the special function register can be manipulated.

## · After reset

Indicates the status of the special function register when a reset is input.

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

| Address              | Symbol | Special Function Register (SFR) Name |      |      |           |           |           | R/W       | R/W Number of Bits<br>Manipulated<br>Simultaneously |      | ted          | After<br>Reset | Reference<br>page |     |       |
|----------------------|--------|--------------------------------------|------|------|-----------|-----------|-----------|-----------|-----------------------------------------------------|------|--------------|----------------|-------------------|-----|-------|
| ·                    |        | 7                                    | 6    | 5    | 4         | 3         | 2         | 1         | 0                                                   |      | 1            | 8              | 16                |     | Refer |
| FF00H,<br>FF01H      | _      | -                                    | -    | -    | -         | -         | -         | -         | -                                                   | -    | -            | -              | -                 | _   | -     |
| FF02H                | P2     | 0                                    | 0    | 0    | 0         | P23       | P22       | P21       | P20                                                 | R/W  | $\checkmark$ | √              | -                 | 00H | 57    |
| FF03H                | P3     | 0                                    | 0    | 0    | P34       | 0         | P32       | 0         | 0                                                   | Note | √            | $\sqrt{}$      | _                 | 00H | 57    |
| FF04H                | P4     | 0                                    | 0    | 0    | 0         | P43       | 0         | 0         | P40                                                 |      | √            | √              | _                 | 00H | 57    |
| FF05H<br>to<br>FF0DH | -      | -                                    | -    | -    | -         | -         | -         | -         | -                                                   | -    | - 1          | -              | -                 | -   | -     |
| FF0EH                | CMP01  | _                                    | _    | _    | _         | _         | -         | -         | -                                                   | R/W  | _            | √              | -                 | 00H | 74    |
| FF0FH                | CMP11  | =                                    | =    | =    | -         | -         | -         | -         | -                                                   |      | _            | $\sqrt{}$      | _                 | 00H | 74    |
| FF10H<br>to<br>FF21H | -      | -                                    | -    | -    | -         | _         | _         | -         | -                                                   | -    | 1            | -              | -                 | -   | -     |
| FF22H                | PM2    | 1                                    | 1    | 1    | 1         | PM23      | PM22      | PM21      | PM20                                                | R/W  | √            | <b>V</b>       | _                 | FFH | 56    |
| FF23H                | РМ3    | 1                                    | 1    | 1    | 1         | 1         | PM32      | 1         | 1                                                   |      | √            | $\sqrt{}$      | _                 | FFH | 56    |
| FF24H                | PM4    | PM47                                 | PM46 | PM45 | PM44      | PM43      | PM42      | PM41      | PM40                                                |      | √            | $\sqrt{}$      | _                 | FFH | 56    |
| FF25H<br>to<br>FF31H | -      | -                                    | -    | -    | -         | -         | -         | -         | -                                                   | -    | 1            | -              | -                 | -   | -     |
| FF32H                | PU2    | 0                                    | 0    | 0    | 0         | PU23      | PU22      | PU21      | PU20                                                | R/W  | √            | <b>V</b>       | _                 | 00H | 58    |
| FF33H                | PU3    | 0                                    | 0    | 0    | PU34      | 0         | PU32      | 0         | 0                                                   |      | √            | √              | _                 | 00H | 58    |
| FF34H                | PU4    | PU47                                 | PU46 | PU45 | PU44      | PU43      | PU42      | PU41      | PU40                                                |      | $\sqrt{}$    | $\sqrt{}$      | _                 | 00H | 58    |
| FF35H<br>to<br>FF47H | -      | -                                    | -    | -    | -         | -         | -         | -         | -                                                   | -    | -            | -              | -                 | -   | -     |
| FF48H                | WDTM   | 0                                    | 1    | 1    | WDC<br>S4 | WDC<br>S3 | WDC<br>S2 | WDC<br>S1 | WDC<br>S0                                           | R/W  |              | <b>V</b>       | _                 | 67H | 90    |
| FF49H                | WDTE   |                                      |      |      | -         | _         | -         | -         | -                                                   |      | -            | $\sqrt{}$      | _                 | 9AH | 91    |

Note Only P34 is an input-only port.

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

| Address              | Symbol |                          | Special Function Register (SFR) Name |             |             |             |             |                           |                           | R/W Number of Bits Manipulated Simultaneously |          | ted          | After<br>Reset | Reference<br>page     |               |
|----------------------|--------|--------------------------|--------------------------------------|-------------|-------------|-------------|-------------|---------------------------|---------------------------|-----------------------------------------------|----------|--------------|----------------|-----------------------|---------------|
|                      |        | 7                        | 6                                    | 5           | 4           | 3           | 2           | 1                         | 0                         |                                               | 1        | 8            | 16             |                       | Refer<br>page |
| FF50H                | LVIM   | <lvi<br>ON&gt;</lvi<br>  | 0                                    | 0           | 0           | 0           | 0           | <lvi<br>MD&gt;</lvi<br>   | <lvi<br>F&gt;</lvi<br>    | R/W                                           | <b>V</b> | √            | _              | 00H <sup>Note 1</sup> | 124           |
| FF51H                | LVIS   | 0                        | 0                                    | 0           | 0           | LVIS3       | LVIS2       | LVIS1                     | LVIS0                     |                                               | _        | $\checkmark$ | _              | 00H <sup>Note 1</sup> | 125           |
| FF52H,<br>FF53H      | -      | -                        | 1                                    | 1           | ı           | -           | -           | -                         | ı                         | ı                                             | -        | -            | -              | -                     | _             |
| FF54H                | RESF   | 0                        | 0                                    | 0           | WDT<br>RF   | 0           | 0           | 0                         | LVIRF                     | R                                             | -        | 1            | -              | 00H <sup>Note 2</sup> | 118           |
| FF55H<br>to<br>FF57H | -      | _                        | 1                                    | -           | _           | -           | _           | _                         | 1                         | -                                             | -        | -            | -              | -                     | _             |
| FF58H                | LSRCM  | 0                        | 0                                    | 0           | 0           | 0           | 0           | 0                         | <lsr<br>STOP&gt;</lsr<br> | R/W                                           | <b>V</b> | √            | _              | 00H                   | 64            |
| FF59H<br>to<br>FF6FH | -      | -                        | _                                    | -           | -           | -           | -           | -                         | _                         | -                                             | -        | -            | -              | -                     | -             |
| FF70H                | TMHMD1 | <tmhe<br>1&gt;</tmhe<br> | CKS1<br>2                            | CKS1        | CKS1<br>0   | TMM<br>D11  | TMM<br>D10  | <tole<br>V1&gt;</tole<br> | <toen<br>1&gt;</toen<br>  | R/W                                           | <b>V</b> | <b>V</b>     | -              | 00H                   | 75            |
| FF71H<br>to<br>FF9FH | -      |                          | -                                    | ı           | -           | -           | _           | _                         | П                         | -                                             | -        | 1            | -              | _                     | -             |
| FFA0H                | PFCMD  | REG7                     | REG6                                 | REG5        | REG4        | REG3        | REG2        | REG1                      | REG0                      | W                                             | 1        | √            | _              | Undefined             | 148           |
| FFA1H                | PFS    | 0                        | 0                                    | 0           | 0           | 0           | WEP<br>RERR | VCER<br>R                 | FPRE<br>RR                | R/W                                           | √        | 7            | -              | 00H                   | 149           |
| FFA2H                | FLPMC  | 0                        | PRSE<br>LF4                          | PRSE<br>LF3 | PRSE<br>LF2 | PRSE<br>LF1 | PRSE<br>LF0 | 0                         | FLSP<br>M                 |                                               | I        | <b>√</b>     | -              | Undefined             | 147           |
| FFA3H                | FLCMD  | 0                        | 0                                    | 0           | 0           | 0           | FLCM<br>D2  | FLCM<br>D1                | FLCM<br>D0                |                                               | <b>V</b> | 1            | -              | 00H                   | 151           |
| FFA4H                | FLAPL  | FLA<br>P7                | FLA<br>P6                            | FLA<br>P5   | FLA<br>P4   | FLA<br>P3   | FLA<br>P2   | FLA<br>P1                 | FLA<br>P0                 |                                               | 1        | √            | _              | Undefined             | 152           |

Notes 1. Retained only after a reset by LVI.

**Remark** For a bit name enclosed in angle brackets (<>), the bit name is defined as a reserved word in the RA78K0S, and is defined as an sfr variable using the #pragma sfr directive in the CC78K0S.

**<sup>2.</sup>** Varies depending on the reset cause.

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

| Address              | Symbol |            | Special Function Register (SFR) Name |            |                           |                        |                        |                          |            | R/W | R/W Number of Bits Manipulated Simultaneously |          | ted | After<br>Reset | Reference<br>page |
|----------------------|--------|------------|--------------------------------------|------------|---------------------------|------------------------|------------------------|--------------------------|------------|-----|-----------------------------------------------|----------|-----|----------------|-------------------|
|                      |        | 7          | 6                                    | 5          | 4                         | 3                      | 2                      | 1                        | 0          |     | 1                                             | 8        | 16  |                | Refer<br>page     |
| FFA5H                | FLAPH  | 0          | 0                                    | 0          | 0                         | FLA<br>P11             | FLA<br>P10             | FLA<br>P9                | FLA<br>P8  | R/W | <b>V</b>                                      | <b>V</b> | _   | Undefined      | 152               |
| FFA6H                | FLAPHC | 0          | 0                                    | 0          | 0                         | FLAP<br>C11            | FLAP<br>C10            | FLAP<br>C9               | FLAP<br>C8 | ·   | <b>V</b>                                      | <b>√</b> | -   | 00H            | 152               |
| FFA7H                | FLAPLC | FLAP<br>C7 | FLAP<br>C6                           | FLAP<br>C5 | FLAP<br>C4                | FLAP<br>C3             | FLAP<br>C2             | FLAP<br>C1               | FLAP<br>C0 | ·   | 1                                             | <b>√</b> | -   | 00H            | 152               |
| FFA8H                | FLW    | FLW7       | FLW6                                 | FLW5       | FLW4                      | FLW3                   | FLW2                   | FLW1                     | FLW0       |     | _                                             | √        | _   | 00H            | 153               |
| FFA9H<br>to<br>FFDFH | -      | ı          | -                                    | -          | 1                         | ı                      | ı                      | -                        | 1          | ı   | ı                                             | -        | _   | -              | -                 |
| FFE0H                | IF0    | 0          | 0                                    | 0          | <tmif<br>H1&gt;</tmif<br> | <pif<br>1&gt;</pif<br> | <pif<br>0&gt;</pif<br> | <lvi<br>IF&gt;</lvi<br>  | 0          | R/W | 1                                             | √        | _   | 00H            | 100               |
| FFE1H<br>to<br>FFE3H | -      | _          | _                                    | _          | 1                         | _                      | _                      | _                        | 1          | 1   | -                                             | -        | -   | _              | -                 |
| FFE4H                | МКО    | 1          | 1                                    | 1          | <tmm<br>KH1&gt;</tmm<br>  | <pmk<br>1&gt;</pmk<br> | <pmk<br>0&gt;</pmk<br> | <lvim<br>K&gt;</lvim<br> | 1          | R/W | <b>V</b>                                      | <b>√</b> | -   | FFH            | 101               |
| FFE5H<br>to<br>FFEBH | -      | -          | -                                    | _          | _                         | -                      | -                      | -                        | _          | 1   | -                                             | -        | -   | -              | -                 |
| FFECH                | INTM0  | 0          | 0                                    | ES11       | ES10                      | ES01                   | ES00                   | 0                        | 0          | R/W | -                                             | √        | _   | 00H            | 101               |
| FFEDH<br>to<br>FFF2H | -      | ı          | ı                                    | ı          | 1                         | I                      | ı                      | ı                        | ı          | ı   | 1                                             | -        | -   | -              | -                 |
| FFF3H                | PPCC   | 0          | 0                                    | 0          | 0                         | 0                      | 0                      | PPCC<br>1                | PPCC<br>0  | R/W | <b>V</b>                                      | <b>V</b> | -   | 02H            | 63                |
| FFF4H<br>to<br>FFFAH | -      |            | _                                    | _          | -                         | _                      | -                      | -                        | -          | -   | -                                             |          | _   |                | -                 |
| FFFBH                | PCC    | 0          | 0                                    | 0          | 0                         | 0                      | 0                      | PCC1                     | 0          | R/W | $\sqrt{}$                                     | √        | _   | 02H            | 63                |

**Remark** For a bit name enclosed in angle brackets (<>), the bit name is defined as a reserved word in the RA78K0S, and is defined as an sfr variable using the #pragma sfr directive in the CC78K0S.

## 3.3 Instruction Address Addressing

An instruction address is determined by the program counter (PC) contents. The PC contents are normally incremented (+1 for each byte) automatically according to the number of bytes of an instruction to be fetched each time another instruction is executed. When a branch instruction is executed, the branch destination address information is set to the PC to branch 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) to branch. The displacement value is treated as signed two's complement data (–128 to +127) and bit 7 becomes the sign bit. In other words, the range of branch in relative addressing is between –128 and +127 of the start address of the following instruction.

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

#### [Illustration]



When S = 0,  $\alpha$  indicates that all bits are "0". When S = 1,  $\alpha$  indicates that all bits are "1".

#### 3.3.2 Immediate addressing

#### [Function]

Immediate data in the instruction word is transferred to the program counter (PC) to branch. This function is carried out when the CALL !addr16 and BR !addr16 instructions are executed. CALL !addr16 and BR !addr16 instructions can be used to branch to all the memory spaces.

## [Illustration]

In case of CALL !addr16 and BR !addr16 instructions



## 3.3.3 Table indirect addressing

#### [Function]

The table contents (branch destination address) of the particular location to be addressed by the immediate data of an instruction code from bit 1 to bit 5 are transferred to the program counter (PC) to branch.

Table indirect addressing is carried out when the CALLT [addr5] instruction is executed. This instruction can be used to branch to all the memory spaces according to the address stored in the memory table 40H to 7FH.



## 3.3.4 Register addressing

## [Function]

The register pair (AX) contents to be specified with an instruction word are transferred to the program counter (PC) to branch.

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



# 3.4 Operand Address Addressing

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

## 3.4.1 Direct addressing

#### [Function]

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

## [Operand format]

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

#### [Description example]

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





#### 3.4.2 Short direct addressing

## [Function]

The memory to be manipulated in the fixed space is directly addressed with the 8-bit data in an instruction word.

The fixed space where this addressing is applied is the 160-byte space FE80H to FF1FH (FE80H to FEFFH (internal high-speed RAM) + FF00H to FF1FH (special function registers)).

The SFR area where short direct addressing is applied (FF00H to FF1FH) is a part of the total SFR area. In this area, ports which are frequently accessed in a program and a compare register of the timer counter are mapped, and these SFRs can be manipulated with a small number of bytes and clocks.

When 8-bit immediate data is at 80H to FFH, bit 8 of an effective address is cleared to 0. When it is at 00H to 1FH, bit 8 is set to 1. See [Illustration] below.

## [Operand format]

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

#### [Description example]

EQU DATA1 0FE90H ; DATA1 shows FE90H of a saddr area, MOV DATA1, #50H ; When setting the immediate data to 50H



## [Illustration]



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

## 3.4.3 Special function register (SFR) addressing

# [Function]

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

This addressing is applied to the 256-byte space FF00H to FFFH. However, SFRs mapped at FF00H to FF1FH are accessed with short direct addressing.

## [Operand format]

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

## [Description example]

MOV PM0, A; When selecting PM0 for sfr





#### 3.4.4 Register addressing

## [Function]

A general-purpose register is accessed as an operand.

The general-purpose register to be accessed is specified with the register specify code and functional name in the instruction code.

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

## [Operand format]

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

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

### [Description example]

MOV A, C; When selecting the C register for r



INCW DE; When selecting the DE register pair for rp



## 3.4.5 Register indirect addressing

# [Function]

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

## [Operand format]

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

#### [Description example]

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





## 3.4.6 Based addressing

# [Function]

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

#### [Operand format]

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

## [Description example]

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





## 3.4.7 Stack addressing

# [Function]

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

This addressing method is automatically employed when the PUSH, POP, subroutine call, and return instructions are executed or the register is saved/restored upon interrupt request generation.

Stack addressing can be used to access the internal high-speed RAM area only.

## [Description example]

In the case of PUSH DE





## **CHAPTER 4 PORT FUNCTIONS**

#### 4.1 Functions of Ports

The  $\mu$ PD78F9500, 78F9501, 78F9502 have the ports shown in Figure 4-1, which can be used for various control operations. Table 4-1 shows the functions of each port.

In addition to digital I/O port functions, each of these ports has an alternate function. For details, refer to **CHAPTER 2 PIN FUNCTIONS**.



Figure 4-1. Port Functions

Table 4-1. Port Functions

| Pin Name            | I/O   |                                                      | Function                                                                  | After Reset | Alternate-<br>Function Pin |
|---------------------|-------|------------------------------------------------------|---------------------------------------------------------------------------|-------------|----------------------------|
| P20                 | I/O   | Port 2.                                              |                                                                           | Input       | TOH1                       |
| P21                 |       | 4-bit I/O port.                                      |                                                                           |             | INTP0                      |
| P22                 | 1     |                                                      | or output mode in 1-bit units. stor can be connected by setting software. |             | _                          |
| P23 <sup>Note</sup> | ]     |                                                      | •                                                                         |             | EXCLK <sup>Note</sup>      |
| P32                 | I/O   | Port 3. On-chip pull-up resistor can be connected by | Can be set to input or output mode in 1-bit units.                        | Input       | INTP1                      |
| P34 <sup>Note</sup> | Input | setting software.                                    | Input only                                                                | Input       | RESET                      |
| P40 and P43         | I/O   |                                                      | or output mode in 1-bit units.<br>stor can be connected setting software. | Input       | _                          |

Note For the setting method for pin functions, see CHAPTER 13 OPTION BYTE.

Caution The P22 and P23/EXCLK pins are pulled down during reset. The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.

Remark P23 can be allocated when the high-speed internal oscillation is selected as the system clock.

## 4.2 Port Configuration

Ports consist of the following hardware units.

Table 4-2. Configuration of Ports

| Item              | Configuration                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------|
| Control registers | Port mode registers (PM2 to PM4) Port registers (P2 to P4) Pull-up resistor option registers (PU2 to PU4) |
| Ports             | Total: 8 (CMOS I/O: 7, CMOS input: 1)                                                                     |
| Pull-up resistor  | Total: 7                                                                                                  |

#### 4.2.1 Port 2

Port 2 is a 4-bit I/O port with an output latch. Each bit of this port can be set to the input or output mode by using port mode register 2 (PM2). When the P20 to P23 pins are used as an input port, an on-chip pull-up resistor can be connected in 1-bit units by using pull-up resistor option register 2 (PU2).

This port can also be used for timer I/O, and external interrupt request input.

The P23 pin is also used as the EXCLK pin of the system clock oscillator. The functions of the EXCLK pin differs, therefore, depending on the selected system clock oscillator. The following two system clock oscillators can be used.

## (1) High-speed internal oscillator

The P23 pin can be used as I/O port pin.

### (2) External clock input

The P23 pin is used as the EXCLK pin to input an external clock, and therefore it cannot be used as an I/O port pin.

The system clock oscillation is selected by the option byte. For details, refer to CHAPTER 13 OPTION BYTE.

Reset signal generation sets port 2 to the input mode.

Figures 4-2 to 4-4 show the block diagrams of port 2.

<R>

Figure 4-2. Block Diagram of P20 and P21



P2: Port register 2

PU2: Pull-up resistor option register 2

PM2: Port mode register 2

RD: Read signal WRxx: Write signal

WRPORT P2

Output latch (P22)

WRPM

PM2

PM2

Figure 4-3. Block Diagram of P22

P2: Port register 2

PU2: Pull-up resistor option register 2

PM2: Port mode register 2

RD: Read signal WR×x: Write signal

<R>

Figure 4-4. Block Diagram of P23



P2: Port register 2

PU2: Pull-up resistor option register 2

PM2: Port mode register 2

RD: Read signal WR×x: Write signal

#### 4.2.2 Port 3

The P32 pin is a 1-bit I/O port with an output latch. This pin can be set to the input or output mode by using port mode register 3 (PM3). When this pin is used as an input port, an on-chip pull-up resistor can be connected in 1-bit units by using pull-up resistor option register 3 (PU3). This pin can also be used for external interrupt request input.

The P32 pin is a Reset signal generation sets port 3 to the input mode.

The P34 pin is a 1-bit input-only port. This pin is also used as a RESET pin, and when the power is turned on, this is the reset function. For the setting method for pin functions, see **CHAPTER 13 OPTION BYTE**.

When P32 and P34 are used as an input port pins, connect the pull-up resistor.

Figures 4-5 and 4-6 show the block diagrams of port 3.

WRpu PU<sub>3</sub> PU32 Alternate function RD Selector nternal bus WRPORT РЗ Output latch P32/INTP1 (P32) **WRPM** РМ3 PM32

Figure 4-5. Block Diagram of P32

P3: Port register 3

PU3: Pull-up resistor option register 3

PM3: Port mode register 3

RD: Read signal WR×x: Write signal

PU34
PU34
PP-ch
RD
P34/RESET
Option byte

Figure 4-6. Block Diagram of P34

RD: Read signal

Caution Because the P34 pin functions alternately as the RESET pin, if it is used as an input port pin, the function to input an external reset signal to the RESET pin cannot be used. The function of the port is selected by the option byte. For details, refer to CHAPTER 13 OPTION BYTE.

Also, since the option byte is referenced after the reset release, if low level is input to the RESET pin before the referencing, then the reset state is not released. When it is used as an input port

### 4.2.3 Port 4

Port 4 is a 2-bit I/O port with an output latch. Each bit of this port can be set to the input or output mode by using port mode register 4 (PM4). When the P40 and P43 pins are used as an input port, an on-chip pull-up resistor can be connected in 1-bit units by using pull-up resistor option register 4 (PU4).

Reset signal generation sets port 4 to the input mode.

pin, connect the pull-up resistor.

Figures 4-7 shows the block diagram of port 4.

WRPU PU4
PU40, PU43
PU40, PU43
WRPORT
P4
Output latch
(P40, P43)
WRPM
PM4
PM40, PM43

Figure 4-7. Block Diagram of P40 and P43

P4: Port register 4

PU4: Pull-up resistor option register 4

PM4: Port mode register 4

RD: Read signal WRxx: Write signal

# **4.3 Registers Controlling Port Functions**

The ports are controlled by the following three types of registers.

- Port mode registers (PM2 to PM4)
- Port registers (P2 to P4)
- Pull-up resistor option registers (PU2 to PU4)

# (1) Port mode registers (PM2 to PM4)

These registers are used to set the corresponding port to the input or output mode in 1-bit units.

Each port mode register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation sets these registers to FFH.

When a port pin is used as an alternate-function pin, set its port mode register and output latch as shown in Table 4-3.

Caution Because P21 and P32 are also used as external interrupt pins, the corresponding interrupt request flag is set if each of these pins is set to the output mode and its output level is changed. To use the port pin in the output mode, therefore, set the corresponding interrupt mask flag to 1 in advance.

Figure 4-8. Format of Port Mode Register

| Address: | FF22H, After r | eset: FFH, R/V | V |   |      |      |      |      |
|----------|----------------|----------------|---|---|------|------|------|------|
| Symbol   | 7              | 6              | 5 | 4 | 3    | 2    | 1    | 0    |
| PM2      | 1              | 1              | 1 | 1 | PM23 | PM22 | PM21 | PM20 |
| ·        |                |                |   |   |      |      |      | -    |
| Address: | FF23H, After r | eset: FFH, R/V | V |   |      |      |      |      |
| Symbol   | 7              | 6              | 5 | 4 | 3    | 2    | 1    | 0    |
| РМ3      | 1              | 1              | 1 | 1 | 1    | PM32 | 1    | 1    |
|          |                |                |   |   |      |      |      |      |
| Address: | FF24H, After r | eset: FFH, R/V | V |   |      |      |      |      |
| Symbol   | 7              | 6              | 5 | 4 | 3    | 2    | 1    | 0    |
| PM4      | 1              | 1              | 1 | 1 | PM43 | 1    | 1    | PM40 |

| PMmn | Selection of I/O mode of Pmn pin (m = 2 to 4; n = 0 to 3) |
|------|-----------------------------------------------------------|
| 0    | Output mode (output buffer ON)                            |
| 1    | Input mode (output buffer OFF)                            |

## (2) Port registers (P2 to P4)

These registers are used to write data to be output from the corresponding port pin to an external device connected to the chip.

When a port register is read, the pin level is read in the input mode, and the value of the output latch of the port is read in the output mode.

P20 to P23, P32, P40 and P43 are set by using a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation sets these registers to 00H.

Figure 4-9. Format of Port Register

| Address: | Address: FF02H, After reset: 00H (Output latch) R/W |                              |                 |                    |     |     |     |     |
|----------|-----------------------------------------------------|------------------------------|-----------------|--------------------|-----|-----|-----|-----|
| Symbol   | 7                                                   | 6                            | 5               | 4                  | 3   | 2   | 1   | 0   |
| P2       | 0                                                   | 0                            | 0               | 0                  | P23 | P22 | P21 | P20 |
|          |                                                     |                              |                 |                    |     |     |     |     |
| Address: | FF03H, After r                                      | eset: 00H <sup>Note</sup> (0 | Output latch) R | /W <sup>Note</sup> |     |     |     |     |
| Symbol   | 7                                                   | 6                            | 5               | 4                  | 3   | 2   | 1   | 0   |
| P3       | 0                                                   | 0                            | 0               | P34                | 0   | P32 | 0   | 0   |
|          |                                                     |                              |                 |                    |     |     |     |     |
| Address: | Address: FF04H, After reset: 00H (Output latch) R/W |                              |                 |                    |     |     |     |     |
| Symbol   | 7                                                   | 6                            | 5               | 4                  | 3   | 2   | 1   | 0   |
| P4       | 0                                                   | 0                            | 0               | 0                  | P43 | 0   | 0   | P40 |

| Pmn | m = 2 to 4; n = 0 to 4                   |                                 |  |  |  |
|-----|------------------------------------------|---------------------------------|--|--|--|
|     | Controls of output data (in output mode) | Input data read (in input mode) |  |  |  |
| 0   | Output 0                                 | Input low level                 |  |  |  |
| 1   | Output 1                                 | Input high level                |  |  |  |

Note Because P34 is read-only, its reset value is undefined.

## (3) Pull-up resistor option registers (PU2 to PU4)

These registers are used to specify whether an on-chip pull-up resistor is connected to P20 to P23, P32, P34, P40 and P43. By setting PU2 to PU4, an on-chip pull-up resistor can be connected to the port pin corresponding to the bit of PU2 to PU4.

PU2 to PU4 are set by using a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation set these registers to 00H.

Figure 4-10. Format of Pull-up Resistor Option Register

| Address: | Address: FF32H, After reset: 00H R/W |               |   |      |      |      |      |      |
|----------|--------------------------------------|---------------|---|------|------|------|------|------|
| Symbol   | 7                                    | 6             | 5 | 4    | 3    | 2    | 1    | 0    |
| PU2      | 0                                    | 0             | 0 | 0    | PU23 | PU22 | PU21 | PU20 |
| •        |                                      |               |   |      |      |      |      |      |
| Address: | FF33H, After r                       | eset: 00H R/W |   |      |      |      |      |      |
| Symbol   | 7                                    | 6             | 5 | 4    | 3    | 2    | 1    | 0    |
| PU3      | 0                                    | 0             | 0 | PU34 | 0    | PU32 | 0    | 0    |
| ·        |                                      |               |   |      |      |      |      | _    |
| Address: | FF34H, After r                       | eset: 00H R/W |   |      |      |      |      |      |
| Symbol   | 7                                    | 6             | 5 | 4    | 3    | 2    | 1    | 0    |
| PU4      | 0                                    | 0             | 0 | 0    | PU43 | 0    | 0    | PU40 |

| PUmn | Selection of connection of on-chip pull-up resistor of Pmn (m = 2 to 4; n = 0 to 4) |
|------|-------------------------------------------------------------------------------------|
| 0    | Does not connect on-chip pull-up resistor                                           |
| 1    | Connects on-chip pull-up resistor                                                   |

#### 4.4 Operation of Port Function

The operation of a port differs, as follows, depending on the setting of the I/O mode.

Caution Although a 1-bit memory manipulation instruction manipulates 1 bit, it accesses a port in 8-bit units. Therefore, the contents of the output latch of a pin in the input mode, even if it is not subject to manipulation by the instruction, are undefined in a port with a mixture of inputs and outputs.

#### 4.4.1 Writing to I/O port

#### (1) In output mode

A value can be written to the output latch by a transfer instruction. In addition, the contents of the output latch are output from the pin. Once data is written to the output latch, it is retained until new data is written to the output latch.

When a reset signal is generated, cleans the data in the output latch.

#### (2) In input mode

A value can be written to the output latch by a transfer instruction. Because the output buffer is off, however, the pin status remains unchanged.

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

When a reset signal is generated, cleans the data in the output latch.

#### 4.4.2 Reading from I/O port

#### (1) In output mode

The contents of the output latch can be read by a transfer instruction. The contents of the output latch remain unchanged.

#### (2) In input mode

The pin status can be read by a transfer instruction. The contents of the output latch remain unchanged.

#### 4.4.3 Operations on I/O port

#### (1) In output mode

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

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

Reset signal generation clears the data in the output latch.

#### (2) In input mode

The pin level is read and an operation is performed on its contents. The operation result is written to the output latch. However, the pin status remains unchanged because the output buffer is off.

When a reset signal is generated, cleans the data in the output latch.

#### **CHAPTER 5 CLOCK GENERATORS**

#### 5.1 Functions of Clock Generators

The clock generators include a circuit that generates a clock (system clock) to be supplied to the CPU and peripheral hardware, and a circuit that generates a clock (interval time generation clock) to be supplied to the watchdog timer and 8-bit timer H1 (TMH1).

### 5.1.1 System clock oscillators

The following three types of system clock oscillators are used.

· High-speed internal oscillator

This circuit internally oscillates a clock of 8 MHz (TYP.). Its oscillation can be stopped by execution of the STOP instruction.

If the High-speed internal oscillator is selected to supply the system clock, the EXCLK pin can be used as I/O port pins.

· External clock input circuit

This circuit supplies a clock from an external IC to the EXCLK pin. A clock of 2 MHz to 10 MHz can be supplied. Internal clock supply can be stopped by execution of the STOP instruction.

The system clock source is selected by using the option byte. For details, refer to **CHAPTER 13 OPTION BYTE**. When using the EXCLK pin as I/O port pins, refer to **CHAPTER 4 PORT FUNCTIONS** for details.

#### 5.1.2 Clock oscillator for interval time generation

The following circuit is used as a clock oscillator for interval time generation.

· Low-speed internal oscillator

This circuit oscillates a clock of 240 kHz (TYP.). Its oscillation can be stopped by using the low-speed internal oscillation mode register (LSRCM) when it is specified by the option byte that its oscillation can be stopped by software.

# **5.2 Configuration of Clock Generators**

The clock generators consist of the following hardware.

Table 5-1. Configuration of Clock Generators

| Item              | Configuration                                                                                                                          |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Control registers | Processor clock control register (PCC) Preprocessor clock control register (PPCC) Low-speed internal oscillation mode register (LSRCM) |
| Oscillators       | High-speed internal oscillator External clock input circuit Low-speed internal oscillator                                              |



Figure 5-1. Block Diagram of Clock Generators

**Note** Select the high-speed internal oscillator or external clock input circuit as the system clock source by using the option byte.

## **5.3 Registers Controlling Clock Generators**

The clock generators are controlled by the following three registers.

- Processor clock control register (PCC)
- Preprocessor clock control register (PPCC)
- Low-speed internal oscillation mode register (LSRCM)

## (1) Processor clock control register (PCC) and preprocessor clock control register (PPCC)

These registers are used to specify the division ratio of the system clock.

PCC and PPCC are set by using a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation sets PCC and PPCC to 02H.

Figure 5-2. Format of Processor Clock Control Register (PCC)

| Address: FF | FBH, After res | set: 02H, R/W |   |   |   |   |      |   |   |
|-------------|----------------|---------------|---|---|---|---|------|---|---|
| Symbol      | 7              | 6             | 5 | 4 | 3 | 2 | 1    | 0 |   |
| PCC         | 0              | 0             | 0 | 0 | 0 | 0 | PCC1 | 0 | l |

Figure 5-3. Format of Preprocessor Clock Control Register (PPCC)

| Address: FF | F3H, After res | set: 02H, R/W |   |   |   |   |       |       |
|-------------|----------------|---------------|---|---|---|---|-------|-------|
| Symbol      | 7              | 6             | 5 | 4 | 3 | 2 | 1     | 0     |
| PPCC        | 0              | 0             | 0 | 0 | 0 | 0 | PPCC1 | PPCC0 |

| PPCC1 | PPCC0            | PCC1 | Selection of CPU clock (fcpu) Note 1 |
|-------|------------------|------|--------------------------------------|
| 0     | 0                | 0    | fx                                   |
| 0     | 1                | 0    | fx/2 Note 2                          |
| 0     | 0                | 1    | fx/2 <sup>2</sup>                    |
| 1     | 0                | 0    | fx/2 <sup>2</sup> Note 3             |
| 0     | 1                | 1    | fx/2 <sup>3</sup> Note <sup>2</sup>  |
| 1     | 0                | 1    | fx/2 <sup>4</sup> Note <sup>3</sup>  |
| 0     | Other than above |      | Setting prohibited                   |

- Notes 1. The setting range of the CPU clock differs depending on the supply voltage to be used.

  Be sure to refer to CPU clock and peripheral clock frequencies described in AC

  Characteristics in CHAPTER 17 ELECTRICAL SPECIFICATIONS.
  - **2.** If PPCC = 01H, the clock (fxP) supplied to the peripheral hardware is fx/2.
  - 3. If PPCC = 02H, the clock (fxp) supplied to the peripheral hardware is  $fx/2^2$ .

The fastest instruction of the  $\mu$ PD78F9500, 78F9501, 78F9502 is executed in two CPU clocks. Therefore, the relationship between the CPU clock (fcpu) and the minimum instruction execution time is as shown in Table 5-2.

Table 5-2. Relationship between CPU Clock and Minimum Instruction Execution Time

| CPU Clock (fcpu) Note | Minimum Instruction Execution Time: 2/fcpu                |                                       |  |  |
|-----------------------|-----------------------------------------------------------|---------------------------------------|--|--|
|                       | High-speed internal oscillation clock (at 8.0 MHz (TYP.)) | External clock input<br>(at 10.0 MHz) |  |  |
| fx                    | 0.25 μs                                                   | 0.2 μs                                |  |  |
| fx/2                  | 0.5 μs                                                    | 0.4 μs                                |  |  |
| fx/2 <sup>2</sup>     | 1.0 <i>μ</i> s                                            | 0.8 <i>µ</i> s                        |  |  |
| fx/2³                 | 2.0 μs                                                    | 1.6 <i>μ</i> s                        |  |  |
| fx/2 <sup>4</sup>     | 4.0 <i>μ</i> s                                            | 3.2 μs                                |  |  |

**Note** The CPU clock (high-speed internal oscillation clock, or external clock input) is selected by the option byte.

## (2) Low-speed internal oscillation mode register (LSRCM)

This register is used to select the operation mode of the low-speed internal oscillator (240 kHz (TYP.)).

This register is valid when it is specified by the option byte that the low-speed internal oscillator can be stopped by software. If it is specified by the option byte that the low-speed internal oscillator cannot be stopped by software, setting of this register is invalid, and the low-speed internal oscillator continues oscillating. In addition, the source clock of WDT is fixed to the low-speed internal oscillator. For details, refer to **CHAPTER 7 WATCHDOG TIMER**.

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

Reset signal generation sets LSRCM to 00H.

Figure 5-4. Format of Low-Speed internal oscillation Mode Register (LSRCM)

 Address: FF58H, After reset: 00H, R/W

 Symbol
 7
 6
 5
 4
 3
 2
 1
 <0>

 LSRCM
 0
 0
 0
 0
 0
 0
 LSRSTOP

| LSRSTOP | Oscillation/stop of low-speed internal oscillator |
|---------|---------------------------------------------------|
| 0       | Low-speed internal oscillates                     |
| 1       | Low-speed internal oscillator stops               |

## 5.4 System Clock Oscillators

The following two types of system clock oscillators are available.

• High-speed internal oscillator: Internally oscillates a clock of 8 MHz (TYP.).

• External clock input circuit: Supplies a clock of 2 MHz to 10 MHz to the EXCLK pin.

#### 5.4.1 High-speed internal oscillator

The  $\mu$ PD78F9500, 78F9501, 78F9502 include a high-speed internal oscillator (8 MHz (TYP.)).

If the high-speed internal oscillation is selected by the option byte as the clock source, the EXCLK pin can be used as an I/O port pin.

For details of the option byte, refer to **CHAPTER 13 OPTION BYTE**. For details of I/O ports, refer to **CHAPTER 4 PORT FUNCTIONS**.

## 5.4.2 External clock input circuit

This circuit supplies a clock from an external IC to the EXCLK pin.

#### 5.4.3 Prescaler

The prescaler divides the clock (fx) output by the system clock oscillator to generate a clock (fx) to be supplied to the peripheral hardware. It also divides the clock to peripheral hardware (fx) to generate a clock to be supplied to the CPU.

**Remark** The clock output by the oscillator selected by the option byte (high-speed internal oscillator, or external clock input circuit) is divided. For details of the option byte, refer to **CHAPTER 13 OPTION BYTE**.

## 5.5 Operation of CPU Clock Generator

A clock (fcpu) is supplied to the CPU from the system clock (fx) oscillated by one of the following three types of oscillators.

• High-speed internal oscillator: Internally oscillates a clock of 8 MHz (TYP.).

• External clock input circuit: Supplies a clock of 2 MHz to 10 MHz to EXCLK pin.

The system clock oscillator is selected by the option byte. For details of the option byte, refer to **CHAPTER 13 OPTION BYTE**.

## (1) High-speed internal oscillator

When the high-speed internal oscillation is selected by the option byte, the following is possible.

- Shortening of start time

  If the high-speed internal oscillator is selected as the oscillator, the CPU can be started without having to wait
  for the oscillation stabilization time of the system clock. Therefore, the start time can be shortened.
- Improvement of expandability
   If the high-speed internal oscillator is selected as the oscillator, the EXCLK pin can be used as I/O port pins.
   For details, refer to CHAPTER 4 PORT FUNCTIONS.

Figures 5-5 and 5-6 show the timing chart and status transition diagram of the default start by the high-speed internal oscillation.

**Remark** When the high-speed internal oscillation is used, the clock accuracy is  $\pm 5\%$ .



Figure 5-5. Timing Chart of Default Start by High-Speed Internal Oscillation

**Note** Operation stop time is 277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), and 1.075 ms (MAX.).

- (a) The internal reset signal is generated by the power-on clear function on power application, the option byte is referenced after reset, and the system clock is selected.
- (b) The option byte is referenced and the system clock is selected. Then the high-speed internal oscillation clock operates as the system clock.

Power application  $V_{DD} > 2.1 \text{ V} \pm 0.1 \text{ V}$ Reset by power-on clear Reset signal High-speed internal oscillator selected by option byte Start with PCC = 02H, PPCC = 02HClock division ratio variable during CPU operation Interrupt Interrupt HALT instruction **STOP** instruction HALT **STOP** 

Figure 5-6. Status Transition of Default Start by High-Speed internal oscillation

Remark PCC: Processor clock control register

PPCC: Preprocessor clock control register

#### (2) External clock input circuit

If external clock input is selected by the option byte, the following is possible.

#### • High-speed operation

The accuracy of processing is improved as compared with high-speed internal oscillation (8 MHz (TYP.)) because an oscillation frequency of 2 MHz to 10 MHz can be selected and an external clock with a small frequency deviation can be supplied.

Figures 5-7 and 5-8 show the timing chart and status transition diagram of default start by external clock input.



Figure 5-7. Timing of Default Start by External Clock Input

**Note** Operation stop time is 277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), and 1.075 ms (MAX.).

- (a) The internal reset signal is generated by the power-on clear function on power application, the option byte is referenced after reset, and the system clock is selected.
- (b) The option byte is referenced and the system clock is selected. Then the external clock operates as the system clock.



Figure 5-8. Status Transition of Default Start by External Clock Input

**Remark** PCC: Processor clock control register

PPCC: Preprocessor clock control register

## 5.6 Operation of Clock Generator Supplying Clock to Peripheral Hardware

The following two types of clocks are supplied to the peripheral hardware.

- Clock to peripheral hardware (fxp)
- Low-speed internal oscillation clock (fRL)

#### (1) Clock to peripheral hardware

The clock to the peripheral hardware is supplied by dividing the system clock (fx). The division ratio is selected by the pre-processor clock control register (PPCC).

Three types of frequencies are selectable: "fx", "fx/2", and "fx/2". Table 5-3 lists the clocks supplied to the peripheral hardware.

| PPCC1 | PPCC0 | Selection of clock to peripheral hardware (fxp) |
|-------|-------|-------------------------------------------------|
| 0     | 0     | fx                                              |
| 0     | 1     | fx/2                                            |
| 1     | 0     | fx/2 <sup>2</sup>                               |
| 1     | 1     | Setting prohibited                              |

Table 5-3. Clocks to Peripheral Hardware

#### (2) Low-speed internal oscillation clock

The low-speed internal oscillator of the clock oscillator for interval time generation is always started after release of reset, and oscillates at 240 kHz (TYP.).

It can be specified by the option byte whether the low-speed internal oscillator can or cannot be stopped by software. If it is specified that the low-speed internal oscillator can be stopped by software, oscillation can be started or stopped by using the low-speed internal oscillation mode register (LSRCM). If it is specified that it cannot be stopped by software, the clock source of WDT is fixed to the low-speed internal oscillation clock (fRL).

The low-speed internal oscillator is independent of the CPU clock. If it is used as the source clock of WDT, therefore, a hang-up can be detected even if the CPU clock is stopped. If the low-speed internal oscillator is used as a count clock source of 8-bit timer H1, 8-bit timer H1 can operate even in the standby status.

Table 5-4 shows the operation status of the low-speed internal oscillator when it is selected as the source clock of WDT and the count clock of 8-bit timer H1. Figure 5-9 shows the status transition of the low-speed internal oscillator.

| Option Byte Setting        |             | CPU Status     | WDT Status | TMH1 Status |
|----------------------------|-------------|----------------|------------|-------------|
| Can be stopped by software | LSRSTOP = 1 | Operation mode | Stopped    | Stopped     |
|                            | LSRSTOP = 0 |                | Operates   | Operates    |
|                            | LSRSTOP = 1 | Standby        | Stopped    | Stopped     |
|                            | LSRSTOP = 0 |                | Stopped    | Operates    |
| Cannot be stopped          |             | Operation mode | Operates   |             |
|                            |             | Standby        |            |             |

Table 5-4. Operation Status of Low-Speed Internal Oscillator



Figure 5-9. Status Transition of Low-Speed Internal Oscillator

**Note** The clock source of the watchdog timer (WDT) is selected from fx or f<sub>RL</sub>, or it may be stopped. For details, refer to **CHAPTER 7 WATCHDOG TIMER**.

# CHAPTER 6 8-BIT TIMER H1

# 6.1 Functions of 8-Bit Timer H1

8-bit timer H1 has the following functions.

- Interval timer
- PWM output mode
- Square-wave output

# 6.2 Configuration of 8-Bit Timer H1

8-bit timer H1 consists of the following hardware.

Table 6-1. Configuration of 8-Bit Timer H1

| Item              | Configuration                                                                          |
|-------------------|----------------------------------------------------------------------------------------|
| Timer register    | 8-bit timer counter H1                                                                 |
| Registers         | 8-bit timer H compare register 01 (CMP01) 8-bit timer H compare register 11 (CMP11)    |
| Timer output      | TOH1                                                                                   |
| Control registers | 8-bit timer H mode register 1 (TMHMD1) Port mode register 2 (PM2) Port register 2 (P2) |

Figure 6-1 shows a block diagram.



Figure 6-1. Block Diagram of 8-Bit Timer H1

User's Manual U18681EJ2V0UD

# (1) 8-bit timer H compare register 01 (CMP01)

This register can be read or written by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

Figure 6-2. Format of 8-Bit Timer H Compare Register 01 (CMP01)



Caution CMP01 cannot be rewritten during timer count operation.

## (2) 8-bit timer H compare register 11 (CMP11)

This register can be read or written by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

Figure 6-3. Format of 8-Bit Timer H Compare Register 11 (CMP11)



CMP11 can be rewritten during timer count operation.

If the CMP11 value is rewritten during timer operation, the compare value after the rewrite takes effect at the timing at which the count value and the compare value before the rewrite match. If the timing at which the count value and compare value match conflicts with the timing of the writing from the CPU to CMP11, the compare value after the rewrite takes effect at the timing at which the next count value and the compare value before the rewrite match.

Caution In the PWM output mode, be sure to set CMP11 when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to CMP11).

# 6.3 Registers Controlling 8-Bit Timer H1

The following three registers are used to control 8-Bit Timer H1.

- 8-bit timer H mode register 1 (TMHMD1)
- Port mode register 2 (PM2)
- Port register 2 (P2)

# (1) 8-bit timer H mode register 1 (TMHMD1)

This register controls the mode of timer H.

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

Reset signal generation clears this register to 00H.

Figure 6-4. Format of 8-Bit Timer H Mode Register 1 (TMHMD1)

Address: FF70H After reset: 00H R/W

Symbol TMHMD1

| <7>   | 6     | 5     | 4     | 3      | 2      | <1>    | <0>   |
|-------|-------|-------|-------|--------|--------|--------|-------|
| TMHE1 | CKS12 | CKS11 | CKS10 | TMMD11 | TMMD10 | TOLEV1 | TOEN1 |

| TMHE1 | Timer operation enable                                                    |
|-------|---------------------------------------------------------------------------|
| 0     | Stop timer count operation (counter is cleared to 0)                      |
| 1     | Enable timer count operation (count operation started by inputting clock) |

| CKS12            | CKS11 | CKS10   |                                 | Count clock (fcnt) selection |  |  |
|------------------|-------|---------|---------------------------------|------------------------------|--|--|
| 0                | 0     | 0       | fxp                             | (10 MHz)                     |  |  |
| 0                | 0     | 1       | fxp/2 <sup>2</sup>              | (2.5 MHz)                    |  |  |
| 0                | 1     | 0       | fxp/2 <sup>4</sup>              | (625 kHz)                    |  |  |
| 0                | 1     | 1       | f <sub>XP</sub> /2 <sup>6</sup> | (156.25 kHz)                 |  |  |
| 1                | 0     | 0       | fxp/2 <sup>12</sup>             | (2.44 kHz)                   |  |  |
| 1                | 0     | 1       | frL/2 <sup>7</sup>              | (1.88 kHz (TYP.))            |  |  |
| Other than above |       | Setting | prohibited                      |                              |  |  |

| TMMD11           | TMMD10 | Timer operation mode |  |  |
|------------------|--------|----------------------|--|--|
| 0                | 0      | Interval timer mode  |  |  |
| 1                | 0      | PWM output mode      |  |  |
| Other than above |        | Setting prohibited   |  |  |

| TOLEV1 | Timer output level control (in default mode) |
|--------|----------------------------------------------|
| 0      | Low level                                    |
| 1      | High level                                   |

| TOEN1 | Timer output control |
|-------|----------------------|
| 0     | Disable output       |
| 1     | Enable output        |

Cautions 1. When TMHE1 = 1, setting the other bits of the TMHMD1 register is prohibited.

2. In the PWM output mode, be sure to set 8-bit timer H compare register 11 (CMP11) when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register).

Remarks 1. fxp: Oscillation frequency of clock to peripheral hardware

- 2. fr.: Low-speed internal oscillation clock oscillation frequency
- 3. Figures in parentheses apply to operation at  $f_{XP} = 10$  MHz,  $f_{RL} = 240$  kHz (TYP.).

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

When using the P20/TOH1 pin for timer output, clear PM20, the output latch of P20 to 0.

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

Reset signal generation sets PM2 to FFH.

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



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

## 6.4 Operation of 8-Bit Timer H1

# 6.4.1 Operation as interval timer/square-wave output

When 8-bit timer counter H1 and compare register 01 (CMP01) match, an interrupt request signal (INTTMH1) is generated and 8-bit timer counter H1 is cleared to 00H.

Compare register 11 (CMP11) is not used in interval timer mode. Since a match of 8-bit timer counter H1 and the CMP11 register is not detected even if the CMP11 register is set, timer output is not affected.

By setting bit 0 (TOEN1) of timer H mode register 1 (TMHMD1) to 1, a square wave of any frequency (duty = 50%) is output from TOH1.

#### (1) Usage

Generates the INTTMH1 signal repeatedly at the same interval.

<1> Set each register.

Figure 6-6. Register Setting During Interval Timer/Square-Wave Output Operation

(i) Setting timer H mode register 1 (TMHMD1)



# (ii) CMP01 register setting

- Compare value (N)
- <2> Count operation starts when TMHE1 = 1.
- <3> When the values of 8-bit timer counter H1 and the CMP01 register match, the INTTMH1 signal is generated and 8-bit timer counter H1 is cleared to 00H.

Interval time = 
$$(N + 1)/f_{CNT}$$

<4> Subsequently, the INTTMH1 signal is generated at the same interval. To stop the count operation, clear TMHE1 to 0.

## (2) Timing chart

The timing of the interval timer/square-wave output operation is shown below.



Figure 6-7. Timing of Interval Timer/Square-Wave Output Operation (1/2)

- <1> The count operation is enabled by setting the TMHE1 bit to 1. The count clock starts counting no more than 1 clock after the operation is enabled.
- <2> When the values of 8-bit timer counter H1 and the CMP01 register match, the value of 8-bit timer counter H1 is cleared, the TOH1 output level is inverted, and the INTTMH1 signal is output.
- <3> The INTTMH1 signal and TOH1 output become inactive by clearing the TMHE1 bit to 0 during timer H1 operation. If these are inactive from the first, the level is retained.

**Remark**  $01H \le N \le FEH$ 

Figure 6-7. Timing of Interval Timer/Square-Wave Output Operation (2/2)

# (b) Operation when CMP01 = FFH



# (c) Operation when CMP01 = 00H



#### 6.4.2 Operation as PWM output mode

In PWM output mode, a pulse with an arbitrary duty and arbitrary cycle can be output.

8-bit timer compare register 01 (CMP01) controls the cycle of timer output (TOH1). Rewriting the CMP01 register during timer operation is prohibited.

8-bit timer compare register 11 (CMP11) controls the duty of timer output (TOH1). Rewriting the CMP11 register during timer operation is possible.

The operation in PWM output mode is as follows.

TOH1 output becomes active and 8-bit timer counter H1 is cleared to 0 when 8-bit timer counter H1 and the CMP01 register match after the timer count is started. TOH1 output becomes inactive when 8-bit timer counter H1 and the CMP11 register match.

#### (1) Usage

In PWM output mode, a pulse for which an arbitrary duty and arbitrary cycle can be set is output.

<1> Set each register.

Figure 6-8. Register Setting in PWM Output Mode

## (i) Setting timer H mode register 1 (TMHMD1)



#### (ii) Setting CMP01 register

• Compare value (N): Cycle setting

#### (iii) Setting CMP11 register

• Compare value (M): Duty setting

**Remark**  $00H \le CMP11 (M) < CMP01 (N) \le FFH$ 

- <2> The count operation starts when TMHE1 = 1.
- <3> The CMP01 register is the compare register that is to be compared first after count operation is enabled. When the values of 8-bit timer counter H1 and the CMP01 register match, 8-bit timer counter H1 is cleared, an interrupt request signal (INTTMH1) is generated, and TOH1 output becomes active. At the same time, the compare register to be compared with 8-bit timer counter H1 is changed from the CMP01 register to the CMP11 register.

- <4> When 8-bit timer counter H1 and the CMP11 register match, TOH1 output becomes inactive and the compare register to be compared with 8-bit timer counter H1 is changed from the CMP11 register to the CMP01 register. At this time, 8-bit timer counter H1 is not cleared and the INTTMH1 signal is not generated.
- <5> By performing procedures <3> and <4> repeatedly, a pulse with an arbitrary duty can be obtained.
- <6> To stop the count operation, set TMHE1 = 0.

If the setting value of the CMP01 register is N, the setting value of the CMP11 register is M, and the count clock frequency is fcNT, the PWM pulse output cycle and duty are as follows.

```
PWM pulse output cycle = (N+1)/f_{CNT}
Duty = Active width : Total width of PWM = (M+1) : (N+1)
```

- Cautions 1. In PWM output mode, the setting value for the CMP11 register can be changed during timer count operation. However, three operation clocks (signal selected using the CKS12 to CKS10 bits of the TMHMD1 register) or more are required to transfer the register value after rewriting the CMP11 register value.
  - 2. Be sure to set the CMP11 register when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register).

#### (2) Timing chart

The operation timing in PWM output mode is shown below.

Caution Make sure that the CMP11 register setting value (M) and CMP01 register setting value (N) are within the following range.

 $00H \le CMP11 (M) < CMP01 (N) \le FFH$ 

Figure 6-9. Operation Timing in PWM Output Mode (1/4)

# (a) Basic operation (00H < CMP11 < CMP01 < FFH)



- <1> The count operation is enabled by setting the TMHE1 bit to 1. Start 8-bit timer counter H1 by masking one count clock to count up. At this time, TOH1 output remains inactive (when TOLEV1 = 0).
- <2> When the values of 8-bit timer counter H1 and the CMP01 register match, the TOH1 output level is inverted, the value of 8-bit timer counter H1 is cleared, and the INTTMH1 signal is output.
- <3> When the values of 8-bit timer counter H1 and the CMP11 register match, the level of the TOH1 output is returned. At this time, the 8-bit timer counter value is not cleared and the INTTMH1 signal is not output.
- <4> Clearing the TMHE1 bit to 0 during timer H1 operation makes the INTTMH1 signal and TOH1 output inactive.

Figure 6-9. Operation Timing in PWM Output Mode (2/4)

# (b) Operation when CMP01 = FFH, CMP11 = 00H



# (c) Operation when CMP01 = FFH, CMP11 = FEH



Figure 6-9. Operation Timing in PWM Output Mode (3/4)

# (d) Operation when CMP01 = 01H, CMP11 = 00H



Figure 6-9. Operation Timing in PWM Output Mode (4/4)

## (e) Operation by changing CMP11 (CMP11 = 02H $\rightarrow$ 03H, CMP01 = A5H)



- <1> The count operation is enabled by setting TMHE1 = 1. Start 8-bit timer counter H1 by masking one count clock to count up. At this time, the TOH1 output remains inactive (when TOLEV1 = 0).
- <2> The CMP11 register value can be changed during timer counter operation. This operation is asynchronous to the count clock.
- <3> When the values of 8-bit timer counter H1 and the CMP01 register match, the value of 8-bit timer counter H1 is cleared, the TOH1 output becomes active, and the INTTMH1 signal is output.
- <4> If the CMP11 register value is changed, the value is latched and not transferred to the register. When the values of 8-bit timer counter H1 and the CMP11 register before the change match, the value is transferred to the CMP11 register and the CMP11 register value is changed (<2>').
  - However, three count clocks or more are required from when the CMP11 register value is changed to when the value is transferred to the register. If a match signal is generated within three count clocks, the changed value cannot be transferred to the register.
- <5> When the values of 8-bit timer counter H1 and the CMP11 register after the change match, the TOH1 output becomes inactive. 8-bit timer counter H1 is not cleared and the INTTMH1 signal is not generated.
- <6> Clearing the TMHE1 bit to 0 during timer H1 operation makes the INTTMH1 signal and TOH1 output inactive.

## **CHAPTER 7 WATCHDOG TIMER**

# 7.1 Functions of Watchdog Timer

The watchdog timer is used to detect an inadvertent program loop. If a program loop is detected, an internal reset signal is generated.

When a reset occurs due to the watchdog timer, bit 4 (WDTRF) of the reset control flag register (RESF) is set to 1. For details of RESF, see **CHAPTER 10 RESET FUNCTION**.

Table 7-1. Loop Detection Time of Watchdog Timer

| Loop Detection Time                                   |                                 |  |  |  |  |
|-------------------------------------------------------|---------------------------------|--|--|--|--|
| During Low-Speed Internal oscillation Clock Operation | During System Clock Operation   |  |  |  |  |
| 2 <sup>11</sup> /f <sub>RL</sub> (4.27 ms)            | 2 <sup>13</sup> /fx (819.2 μs)  |  |  |  |  |
| 2 <sup>12</sup> /f <sub>RL</sub> (8.53 ms)            | 2 <sup>14</sup> /fx (1.64 ms)   |  |  |  |  |
| 2 <sup>13</sup> /f <sub>RL</sub> (17.07 ms)           | 2 <sup>15</sup> /fx (3.28 ms)   |  |  |  |  |
| 2 <sup>14</sup> /f <sub>RL</sub> (34.13 ms)           | 2 <sup>16</sup> /fx (6.55 ms)   |  |  |  |  |
| 2 <sup>15</sup> /f <sub>RL</sub> (68.27 ms)           | 2 <sup>17</sup> /fx (13.11 ms)  |  |  |  |  |
| 2 <sup>16</sup> /f <sub>RL</sub> (136.53 ms)          | 2 <sup>18</sup> /fx (26.21 ms)  |  |  |  |  |
| 2 <sup>17</sup> /f <sub>RL</sub> (273.07 ms)          | 2 <sup>19</sup> /fx (52.43 ms)  |  |  |  |  |
| 2 <sup>18</sup> /f <sub>RL</sub> (546.13 ms)          | 2 <sup>20</sup> /fx (104.86 ms) |  |  |  |  |

Remarks 1. fr.L: Low-speed internal oscillation clock oscillation frequency

- 2. fx: System clock oscillation frequency
- **3.** Figures in parentheses apply to operation at  $f_{RL} = 480 \text{ kHz}$  (MAX.),  $f_{X} = 10 \text{ MHz}$ .

The operation mode of the watchdog timer (WDT) is switched according to the option byte setting of the on-chip low-speed internal oscillator as shown in Table 7-2.

Table 7-2. Option Byte Setting and Watchdog Timer Operation Mode

|                             | Option Byte Setting                                                             |                                                                                 |  |  |  |
|-----------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|--|--|
|                             | Low-Speed Internal Oscillator Cannot Be Stopped                                 | Low-Speed Internal Oscillator Can Be Stopped by Software                        |  |  |  |
| Watchdog timer clock source | Fixed to f <sub>RL</sub> <sup>Note 1</sup> .                                    | Selectable by software (fx, fRL or stopped)     When reset is released: fRL     |  |  |  |
| Operation after reset       | Operation starts with the maximum interval (2 <sup>18</sup> /f <sub>RL</sub> ). | Operation starts with the maximum interval (2 <sup>18</sup> /f <sub>RL</sub> ). |  |  |  |
| Operation mode selection    | The interval can be changed only once.                                          | The clock selection/interval can be changed only once.                          |  |  |  |
| Features                    | The watchdog timer cannot be stopped.                                           | The watchdog timer can be stopped <sup>Note 2</sup> .                           |  |  |  |

- **Notes 1.** As long as power is being supplied, low-speed internal oscillator cannot be stopped (except in the reset period).
  - 2. The conditions under which clock supply to the watchdog timer is stopped differ depending on the clock source of the watchdog timer.
    - <1> If the clock source is fx, clock supply to the watchdog timer is stopped under the following conditions.
      - When fx is stopped
      - In HALT/STOP mode
      - During oscillation stabilization time
    - <2> If the clock source is f<sub>RL</sub>, clock supply to the watchdog timer is stopped under the following conditions.
      - If the CPU clock is fx and if fRL is stopped by software before execution of the STOP instruction
      - In HALT/STOP mode

Remarks 1. fr.L: Low-speed internal oscillation clock oscillation frequency

2. fx: System clock oscillation frequency

# 7.2 Configuration of Watchdog Timer

The watchdog timer consists of the following hardware.

Table 7-3. Configuration of Watchdog Timer

| Item              | Configuration                         |
|-------------------|---------------------------------------|
| Control registers | Watchdog timer mode register (WDTM)   |
|                   | Watchdog timer enable register (WDTE) |

Figure 7-1. Block Diagram of Watchdog Timer



Remarks 1. fr.L: Low-speed internal oscillation clock oscillation frequency

2. fx: System clock oscillation frequency

## 7.3 Registers Controlling Watchdog Timer

The watchdog timer is controlled by the following two registers.

- Watchdog timer mode register (WDTM)
- Watchdog timer enable register (WDTE)

#### (1) Watchdog timer mode register (WDTM)

This register sets the overflow time and operation clock of the watchdog timer.

This register can be set by an 8-bit memory manipulation instruction and can be read many times, but can be written only once after reset is released.

Reset signal generation sets this register to 67H.

Figure 7-2. Format of Watchdog Timer Mode Register (WDTM)

| Address: FF48H |   | After reset: 67H | R/W |       |       |       |       |       |
|----------------|---|------------------|-----|-------|-------|-------|-------|-------|
| Symbol         | 7 | 6                | 5   | 4     | 3     | 2     | 1     | 0     |
| WDTM           | 0 | 1                | 1   | WDCS4 | WDCS3 | WDCS2 | WDCS1 | WDCS0 |

| WDCS4 <sup>Note 1</sup> | WDCS3 <sup>Note 1</sup> | Operation clock selection                  |
|-------------------------|-------------------------|--------------------------------------------|
| 0                       | 0                       | Low-speed internal oscillation clock (fRL) |
| 0                       | 1                       | System Clock (fx)                          |
| 1                       | ×                       | Watchdog timer operation stopped           |

| WDCS2 <sup>Note 2</sup> | WDCS1 <sup>Note 2</sup> | WDCS0 <sup>Note 2</sup> | Overflow time setting                                 |                                 |  |
|-------------------------|-------------------------|-------------------------|-------------------------------------------------------|---------------------------------|--|
|                         |                         |                         | During low-speed internal oscillation clock operation | During system clock operation   |  |
| 0                       | 0                       | 0                       | 2 <sup>11</sup> /f <sub>RL</sub> (4.27 ms)            | 2 <sup>13</sup> /fx (819.2 μs)  |  |
| 0                       | 0                       | 1                       | 2 <sup>12</sup> /f <sub>RL</sub> (8.53 ms)            | 2 <sup>14</sup> /fx (1.64 ms)   |  |
| 0                       | 1                       | 0                       | 2 <sup>13</sup> /f <sub>RL</sub> (17.07 ms)           | 2 <sup>15</sup> /fx (3.28 ms)   |  |
| 0                       | 1                       | 1                       | 2 <sup>14</sup> /f <sub>RL</sub> (34.13 ms)           | 2 <sup>16</sup> /fx (6.55 ms)   |  |
| 1                       | 0                       | 0                       | 2 <sup>15</sup> /f <sub>RL</sub> (68.27 ms)           | 2 <sup>17</sup> /fx (13.11 ms)  |  |
| 1                       | 0                       | 1                       | 2 <sup>16</sup> /f <sub>RL</sub> (136.53 ms)          | 2 <sup>18</sup> /fx (26.21 ms)  |  |
| 1                       | 1                       | 0                       | 2 <sup>17</sup> /f <sub>RL</sub> (273.07 ms)          | 2 <sup>19</sup> /fx (52.43 ms)  |  |
| 1                       | 1                       | 1                       | 2 <sup>18</sup> /f <sub>RL</sub> (546.13 ms)          | 2 <sup>20</sup> /fx (104.86 ms) |  |

**Notes 1.** If "low-speed internal oscillator cannot be stopped" is specified by the option byte, this cannot be set. The low-speed internal oscillation clock will be selected no matter what value is written.

**2.** Reset is released at the maximum cycle (WDCS2, 1, 0 = 1, 1, 1).

Caution 1. Set bits 7, 6, and 5 to 0, 1, and 1, respectively. Do not set the other values.

- Cautions 2. After reset is released, WDTM can be written only once by an 8-bit memory manipulation instruction. If writing is attempted a second time, an internal reset signal is generated. However, at the first write, if "1" and "x" are set for WDCS4 and WDCS3 respectively and the watchdog timer is stopped, then the internal reset signal does not occur even if the following are executed.
  - Second write to WDTM
  - 1-bit memory manipulation instruction to WDTE
  - Writing of a value other than "ACH" to WDTE
  - 3. WDTM cannot be set by a 1-bit memory manipulation instruction.
  - 4. When using the flash memory programming by self programming, set the overflow time for the watchdog timer so that enough overflow time is secured (Example 1-byte writing:  $200 \mu s$  MIN., 1-block deletion: 10 ms MIN.).
- Remarks 1. fr.L: Low-speed internal oscillation clock oscillation frequency
  - 2. fx: System clock oscillation frequency
  - 3. x: Don't care
  - **4.** Figures in parentheses apply to operation at  $f_{RL} = 480 \text{ kHz}$  (MAX.),  $f_{X} = 10 \text{ MHz}$ .

#### (2) Watchdog timer enable register (WDTE)

Writing ACH to WDTE clears the watchdog timer counter and starts counting again.

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

Reset signal generation sets this register to 9AH.

Figure 7-3. Format of Watchdog Timer Enable Register (WDTE)

| Address: | FF49H | After reset: 9AF | l R/W |   |   |   |   |   |   |
|----------|-------|------------------|-------|---|---|---|---|---|---|
| Symbol   | 7     | 6                | 5     | 4 | 3 | 2 | 1 | 0 |   |
| WDTE     |       |                  |       |   |   |   |   |   | 1 |

- Cautions 1. If a value other than ACH is written to WDTE, an internal reset signal is generated.
  - 2. If a 1-bit memory manipulation instruction is executed for WDTE, an internal reset signal is generated.
  - 3. The value read from WDTE is 9AH (this differs from the written value (ACH)).

## 7.4 Operation of Watchdog Timer

# 7.4.1 Watchdog timer operation when "low-speed internal oscillator cannot be stopped" is selected by option byte

The operation clock of watchdog timer is fixed to low-speed internal oscillation clock.

After reset is released, operation is started at the maximum cycle (bits 2, 1, and 0 (WDCS2, WDCS1, WDCS0) of the watchdog timer mode register (WDTM) = 1, 1, 1). The watchdog timer operation cannot be stopped.

The following shows the watchdog timer operation after reset release.

- 1. The status after reset release is as follows.
  - Operation clock: Low-speed internal oscillation clock
  - Cycle:  $2^{18}/f_{RL}$  (546.13 ms: At operation with  $f_{RL} = 480$  kHz (MAX.))
  - · Counting starts
- 2. The following should be set in the watchdog timer mode register (WDTM) by an 8-bit memory manipulation instruction Notes 1,2.
  - Cycle: Set using bits 2 to 0 (WDCS2 to WDCS0)
- 3. After the above procedures are executed, writing ACH to WDTE clears the count to 0, enabling recounting.
- **Notes 1.** The operation clock (low-speed internal oscillation clock) cannot be changed. If any value is written to bits 3 and 4 (WDCS3, WDCS4) of WDTM, it is ignored.
  - 2. As soon as WDTM is written, the counter of the watchdog timer is cleared.

Caution In this mode, operation of the watchdog timer cannot be stopped even during STOP instruction execution. For 8-bit timer H1 (TMH1), a division of the low-speed internal oscillation clock can be selected as the count source, so clear the watchdog timer using the interrupt request of TMH1 before the watchdog timer overflows after STOP instruction execution. If this processing is not performed, an internal reset signal is generated when the watchdog timer overflows after STOP instruction execution.

A status transition diagram is shown below

Figure 7-4. Status Transition Diagram When "Low-Speed Internal Oscillator Cannot Be Stopped" Is Selected by Option Byte



# 7.4.2 Watchdog timer operation when "low-speed internal oscillator can be stopped by software" is selected by option byte

The operation clock of the watchdog timer can be selected as either the low-speed internal oscillation clock or system clock.

After reset is released, operation is started at the maximum cycle of the low-speed internal oscillation clock (bits 2, 1, and 0 (WDCS2, WDCS1, WDCS0) of the watchdog timer mode register (WDTM) = 1, 1, 1).

The following shows the watchdog timer operation after reset release.

- 1. The status after reset release is as follows.
  - · Operation clock: Low-speed internal oscillation clock
  - Cycle:  $2^{18}/f_{RL}$  (546.13 ms: At operation with  $f_{RL} = 480$  kHz (MAX.))
  - Counting starts
- 2. The following should be set in the watchdog timer mode register (WDTM) by an 8-bit memory manipulation instruction Notes 1, 2, 3.
  - Operation clock: Any of the following can be selected using bits 3 and 4 (WDCS3 and WDCS4).
     Low-speed internal oscillation clock (fRL)
    - Syatem clock (fx)
    - Watchdog timer operation stopped
  - Cycle: Set using bits 2 to 0 (WDCS2 to WDCS0)
- 3. After the above procedures are executed, writing ACH to WDTE clears the count to 0, enabling recounting.
- **Notes 1.** As soon as WDTM is written, the counter of the watchdog timer is cleared.
  - 2. Set bits 7, 6, and 5 to 0, 1, 1, respectively. Do not set the other values.
  - **3.** At the first write, If the watchdog timer is stopped by setting WDCS4 and WDCS3 to 1 and  $\times$ , respectively, an internal reset signal is not generated even if the following processing is performed.
    - · WDTM is written a second time.
    - A 1-bit memory manipulation instruction is executed to WDTE.
    - A value other than ACH is written to WDTE.

Caution In this mode, watchdog timer operation is stopped during HALT/STOP instruction execution.

After HALT/STOP mode is released, counting is started again using the operation clock of the watchdog timer set before HALT/STOP instruction execution by WDTM. At this time, the counter is not cleared to 0 but holds its value.

For the watchdog timer operation during STOP mode and HALT mode in each status, see **7.4.3 Watchdog timer** operation in STOP mode and **7.4.4 Watchdog timer operation in HALT mode**.

A status transition diagram is shown below.



Figure 7-5. Status Transition Diagram When "Low-Speed Internal Oscillator Can Be Stopped by Software" Is Selected by Option Byte

# 7.4.3 Watchdog timer operation in STOP mode (when "low-speed internal oscillator can be stopped by software" is selected by option byte)

The watchdog timer stops counting during STOP instruction execution regardless of whether the system clock or low-speed internal oscillation clock is being used.

(1) When the watchdog timer operation clock is the system clock (fx) when the STOP instruction is executed When STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, operation stops for 34  $\mu$ s (TYP.) and then counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0 but holds its value.

Figure 7-6. Operation in STOP Mode (WDT Operation Clock: Clock to Peripheral Hardware)



**Note** The operation stop time is 17  $\mu$ s (MIN.), 34  $\mu$ s (TYP.), and 67  $\mu$ s (MAX.).

# (2) When the watchdog timer operation clock is the low-speed internal oscillation clock (fRL) when the STOP instruction is executed

When the STOP instruction is executed, operation of the watchdog timer is stopped. After STOP mode is released, operation stops for 34  $\mu s$  (TYP.) and then counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0 but holds its value.

Figure 7-7. Operation in STOP Mode (WDT Operation Clock: Low-Speed Internal Oscillation Clock)



**Note** The operation stop time is 17  $\mu$ s (MIN.), 34  $\mu$ s (TYP.), and 67  $\mu$ s (MAX.).

# 7.4.4 Watchdog timer operation in HALT mode (when "low-speed internal oscillator can be stopped by software" is selected by option byte)

The watchdog timer stops counting during HALT instruction execution regardless of whether the operation clock of the watchdog timer is the system clock (fx) or low-speed internal oscillation clock (fRL). After HALT mode is released, counting is started again using the operation clock before the operation was stopped. At this time, the counter is not cleared to 0 but holds its value.



Figure 7-8. Operation in HALT Mode

#### **CHAPTER 8 INTERRUPT FUNCTIONS**

### 8.1 Interrupt Function Types

There are two types of interrupts: maskable interrupts and resets.

#### Maskable interrupts

These interrupts undergo mask control. When an interrupt request occurs, the standby release signal occurs, and if an interrupt can be acknowledged then the program corresponding to the address written in the vector table address is executed (vector interrupt servicing). When several interrupt requests are generated at the same time, processing takes place in the priority order of the vector interrupt servicing. For details on the priority order, see Table 8-1.

There are two internal sources and two external sources of maskable interrupts.

#### Reset

The CPU and SFR are returned to their initial states by the reset signal. The causes for reset signal occurrences are shown in Table 8-1.

When a reset signal occurs, program execution starts from the programs at the addresses written in addresses 0000H and 0001H.

## 8.2 Interrupt Sources and Configuration

There are a total of 4 maskable interrupt sources, and up to four reset sources (see **Table 8-1**).

Priority<sup>Note 1</sup> Interrupt Type Interrupt Source Internal/ Vector Table Basic External Address Configuration Name Trigger Type<sup>Note 2</sup> Low-voltage detectionNote 3 Maskable 1 INTLVI Internal 0006H (A) 2 INTP0 Pin input edge detection External H8000 (B) 3 INTP1 000AH 4 INTTMH1 Match between TMH1 and CMP01 Internal 000CH (A) Reset RESET Reset input 0000H POC Power-on-clear LVI Low-voltage detection Note 4 WDT WDT overflow

**Table 8-1. Interrupt Sources** 

- **Notes 1.** Priority is the vector interrupt servicing priority order when several maskable interrupt requests are generated at the same time. 1 is the highest and 4 is the lowest.
  - 2. Basic configuration types (A) and (B) correspond to (A) and (B) in Figure 8-1.
  - 3. When bit 1 (LVIMD) of low-voltage detection register (LVIM) = 0 is selected.
  - **4.** When bit 1 (LVIMD) of low-voltage detection register (LVIM) = 1 is selected.

Figure 8-1. Basic Configuration of Interrupt Function

# (A) Internal maskable interrupt



## (B) External maskable interrupt



IF: Interrupt request flagIE: Interrupt enable flagMK: Interrupt mask flag

## 8.3 Interrupt Function Control Registers

The interrupt functions are controlled by the following four types of registers.

- Interrupt request flag register 0 (IF0)
- Interrupt mask flag register 0 (MK0)
- External interrupt mode register 0 (INTM0)
- Program status word (PSW)

Table 8-2 lists interrupt requests, the corresponding interrupt request flags, and interrupt mask flags.

Table 8-2. Interrupt Request Signals and Corresponding Flags

| Interrupt Request Signal | Interrupt Request Flag | Interrupt Mask Flag |
|--------------------------|------------------------|---------------------|
| INTLVI                   | LVIIF                  | LVIMK               |
| INTP0                    | PIF0                   | РМК0                |
| INTP1                    | PIF1                   | PMK1                |
| INTTMH1                  | TMIFH1                 | ТММКН1              |

### (1) Interrupt request flag register 0 (IF0)

An interrupt request flag is set to 1 when the corresponding interrupt request is issued, or when the instruction is executed. It is cleared to 0 by executing an instruction when the interrupt request is acknowledged or when a reset signal is input.

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

Reset signal generation clears IF0 to 00H.

Figure 8-2. Format of Interrupt Request Flag Register 0 (IF0)

| Address: | FFE0H | After reset: | 00H R/W |        |      |      |       |   |
|----------|-------|--------------|---------|--------|------|------|-------|---|
| Symbol   | 7     | 6            | 5       | <4>    | <3>  | <2>  | <1>   | 0 |
| IF0      | 0     | 0            | 0       | TMIFH1 | PIF1 | PIF0 | LVIIF | 0 |

| Ī | ××IF× | Interrupt request flag                                                    |  |  |  |
|---|-------|---------------------------------------------------------------------------|--|--|--|
|   | 0     | No interrupt request signal has been issued.                              |  |  |  |
|   | 1     | An interrupt request signal has been issued; an interrupt request status. |  |  |  |

Caution Because P21 and P32 have an alternate function as external interrupt inputs, 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.

#### (2) Interrupt mask flag register 0 (MK0)

The interrupt mask flag is used to enable and disable the corresponding maskable interrupts.

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

Reset signal generation sets MK0 to FFH.

Figure 8-3. Format of Interrupt Mask Flag Register 0 (MK0)

| Address: | FFE4H | After reset: F | FH R/W |        |      |      |       |   |
|----------|-------|----------------|--------|--------|------|------|-------|---|
| Symbol   | 7     | 6              | 5      | <4>    | <3>  | <2>  | <1>   | 0 |
| MK0      | 1     | 1              | 1      | TMMKH1 | PMK1 | PMK0 | LVIMK | 1 |

| ××MK× | Interrupt servicing control   |  |
|-------|-------------------------------|--|
| 0     | Enables interrupt servicing.  |  |
| 1     | Disables interrupt servicing. |  |

Caution Because P21 and P32 have an alternate function as external interrupt inputs, when the output level is changed by specifying the output mode of the port function, an interrupt request flag is set. Therefore, the interrupt mask flag should be set to 1 before using the output mode.

# (3) External interrupt mode register 0 (INTM0)

This register is used to set the valid edge of INTP0 and INTP1.

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

Reset signal generation clears INTM0 to 00H.

Figure 8-4. Format of External Interrupt Mode Register 0 (INTM0)

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

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

Caution 1. Be sure to clear bits 0, 1, 6, and 7 to 0.

Caution 2. Before setting the INTM0 register, be sure to set the corresponding interrupt mask flag (xxMKx = 1) to disable interrupts. After setting the INTM0 register, clear the interrupt request flag (xxMFx = 0), then clear the interrupt mask flag (xxMKx = 0), which will enable interrupts.

### (4) Program status word (PSW)

The program status word is used to hold the instruction execution result and the current status of the interrupt requests. The IE flag, used to enable and disable maskable interrupts, is mapped to PSW.

PSW can be read- and write-accessed in 8-bit units, as well as using bit manipulation instructions and dedicated instructions (El and DI). When a vectored interrupt is acknowledged, the PSW is automatically saved to a stack, and the IE flag is reset to 0.

Reset signal generation sets PSW to 02H.

Figure 8-5. Program Status Word (PSW) Configuration



IE Whether to enable/disable interrupt acknowledgment

0 Disabled

1 Enabled

# 8.4 Interrupt Servicing Operation

### 8.4.1 Maskable interrupt request acknowledgment 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. If the interrupt enabled status is in effect (when the IE flag is set to 1), then the request is acknowledged as a vector interrupt.

The time required to start the vectored interrupt servicing after a maskable interrupt request has been generated is shown in Table 8-3.

See Figures 8-7 and 8-8 for the interrupt request acknowledgment timing.

Table 8-3. Time from Generation of Maskable Interrupt Request to Servicing

| Minimum Time | Maximum Time <sup>Note</sup> |
|--------------|------------------------------|
| 9 clocks     | 19 clocks                    |

**Note** The wait time is maximum when an interrupt request is generated immediately before BT and BF instructions.

**Remark** 1 clock: 
$$\frac{1}{f_{CPU}}$$
 (fcpu: CPU clock)

When two or more maskable interrupt requests are generated at the same time, they are acknowledged starting from the interrupt request assigned the highest priority.

A pending interrupt is acknowledged when a status in which it can be acknowledged is set.

Figure 8-6 shows the algorithm of interrupt request acknowledgment.

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 8-6. Interrupt Request Acknowledgment Processing Algorithm

xxIF: Interrupt request flag
xxMK: Interrupt mask flag

IE: Flag to control maskable interrupt request acknowledgment (1 = enable, 0 = disable)



Figure 8-7. Interrupt Request Acknowledgment Timing (Example of MOV A, r)

If an interrupt request flag ( $\times \times IF$ ) is set before an instruction clock n (n = 4 to 10) under execution becomes n – 1, the interrupt is acknowledged after the instruction under execution is complete. Figure 8-7 shows an example of the interrupt request acknowledgment timing for an 8-bit data transfer instruction MOV A, r. Since this instruction is executed for 4 clocks, if an interrupt occurs for 3 clocks after the instruction fetch starts, the interrupt acknowledgment processing is performed after the MOV A, r instruction is executed.

Figure 8-8. Interrupt Request Acknowledgment Timing (When Interrupt Request Flag Is Set at Last Clock During Instruction Execution)



If an interrupt request flag (xxIF) is set at the last clock of the instruction, the interrupt acknowledgment processing starts after the next instruction is executed.

Figure 8-8 shows an example of the interrupt request acknowledgment 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 acknowledgment processing is performed.

Caution Interrupt requests will be held pending while the interrupt request flag register 0 (IF0) or interrupt mask flag register 0 (MK0) are being accessed.

#### 8.4.2 Multiple interrupt servicing

In order to perform multiple interrupt servicing in which another interrupt is acknowledged while an interrupt is being serviced, the interrupt mask function must be used to mask interrupts for which a low priority is to be set.

Figure 8-9. Example of Multiple Interrupts (1/2)

Example 1. Multiple interrupts are acknowledged



During interrupt INTxx servicing, interrupt request INTyy is acknowledged, and multiple interrupts are generated. Before each interrupt request acknowledgement, the EI instruction is issued, the interrupt mask is released, and the interrupt request acknowledgement enable state is set.

Caution Multiple interrupts can be acknowledged even for low-priority interrupts.

Example 2. Multiple interrupts are not generated because interrupts are not enabled



Because interrupts are not enabled in interrupt INTxx servicing (the EI instruction is not issued), interrupt request INTyy is not acknowledged, and multiple interrupts are not generated. The INTyy request is held pending and acknowledged after the INTxx servicing is performed.

IE = 0: Interrupt request acknowledgment disabled

Figure 8-9. Example of Multiple Interrupts (2/2)

#### Example 3. A priority is controlled by the multiple interrupts

The vector interrupt enable state is set for INTP0, INTP1, and INTTMH1. (Interruption priority INTP0 > INTP1 > INTTMH1 (refer to **Table8-1**))



In the interrupt INTTMH1 servicing, servicing is performed such that the INTP1 interrupt is given priority, since the INTP0 interrupt was first masked.

Afterwards, once the interrupt mask for INTP0 is released, INTP0 processing through multiple interrupts is performed.

IE = 0: Interrupt request acknowledgment disabled

#### 8.4.3 Interrupt request pending

Some instructions may keep pending the acknowledgment of an instruction request until the completion of the execution of the next instruction even if the interrupt request (maskable interrupt and external interrupt) is generated during the execution. The following shows such instructions (interrupt request pending instruction).

- Manipulation instruction for interrupt request flag register 0 (IF0)
- Manipulation instruction for interrupt mask flag register 0 (MK0)

### **CHAPTER 9 STANDBY FUNCTION**

# 9.1 Standby Function and Configuration

### 9.1.1 Standby function

Table 9-1. Relationship Between Operation Clocks in Each Operation Status

| Status         | Low         | -Speed Internal Oscil         | System Clock | Clock Supplied to |                |
|----------------|-------------|-------------------------------|--------------|-------------------|----------------|
|                | Note 1      | Not                           | te 2         |                   | Peripheral<br> |
| Operation Mode |             | LSRSTOP = 0                   | LSRSTOP = 1  |                   | Hardware       |
| Reset          | Stopped     |                               |              | Stopped           | Stopped        |
| STOP           | Oscillating | Oscillating <sup>Note 3</sup> | Stopped      |                   |                |
| HALT           |             |                               |              | Oscillating       | Oscillating    |

Notes 1. When "Cannot be stopped" is selected for low-speed internal oscillator by the option byte.

- 2. When it is selected that the low-speed internal oscillator "can be stopped by software", oscillation of the low-speed internal oscillator can be stopped by LSRSTOP.
- **3.** If the operating clock of the watchdog timer is the low-speed internal oscillation clock, the watchdog timer is stopped.

Caution The LSRSTOP setting is valid only when "Can be stopped by software" is set for the low-speed internal oscillator by the option byte.

Remark LSRSTOP: Bit 0 of the low-speed internal oscillation mode register (LSRCM)

The standby function is designed to reduce the operating current of the system. The following two modes are available.

#### (1) HALT mode

HALT instruction execution sets the HALT mode. In the HALT mode, the CPU operation clock is stopped. Oscillation of the system clock oscillator continues. If the low-speed internal oscillator is operating before the HALT mode is set, oscillation of the clock of the low-speed internal oscillator continues (refer to **Table 9-1**. Oscillation of the low-speed internal oscillation clock (whether it cannot be stopped or can be stopped by software) is set by the option byte). In this mode, the operating current is not decreased as much as in the STOP mode, but the HALT mode is effective for restarting operation immediately upon interrupt request generation and frequently carrying out intermittent operations.

### (2) STOP mode

STOP instruction execution sets the STOP mode. In the STOP mode, the system clock oscillator stops, stopping the whole system, thereby considerably reducing the CPU operating current.

Because this mode can be cleared by an interrupt request, it enables intermittent operations to be carried out. However, select the HALT mode if processing must be immediately started by an interrupt request when the operation stop time<sup>Note</sup> is generated after the STOP mode is released.

**Note** The operation stop time is 17  $\mu$ s (MIN.), 34  $\mu$ s (TYP.), and 67  $\mu$ s (MAX.).

In either of these two modes, all the contents of registers, flags and data memory just before the standby mode is set are held. The I/O port output latches and output buffer statuses are also held.

- Cautions 1. When shifting to the STOP mode, be sure to stop the peripheral hardware operation before executing STOP instruction (except the peripheral hardware that operates on the low-speed internal oscillation clock).
  - 2. If the low-speed internal oscillator is operating before the STOP mode is set, oscillation of the low-speed internal oscillation clock cannot be stopped in the STOP mode (refer to Table 9-1).

# 9.2 Standby Function Operation

# 9.2.1 HALT mode

# (1) HALT mode

The HALT mode is set by executing the HALT instruction.

The operating statuses in the HALT mode are shown below.

Caution Because an interrupt request signal is used to clear the standby mode, if there is an interrupt source with the interrupt request flag set and the interrupt mask flag clear, the standby mode is immediately cleared if set.

Table 9-2. Operating Statuses in HALT Mode

|                        | Setting of HALT Mode                                                     | Low-Speed Internal                             | Low-Speed Internal Osc                                                           | cillator can be stopped <sup>Note</sup> . |  |
|------------------------|--------------------------------------------------------------------------|------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------|--|
| Item                   |                                                                          | Oscillator cannot be stopped <sup>Note</sup> . | When Low-Speed Internal Oscillation Continues When Low-Speed In Oscillation Stop |                                           |  |
| System cloc            | k                                                                        | Clock supply to CPU is sto                     | pped.                                                                            |                                           |  |
| CPU                    |                                                                          | Operation stops.                               |                                                                                  |                                           |  |
| Port (latch)           |                                                                          | Holds status before HALT                       | mode was set.                                                                    |                                           |  |
| 8-bit timer            | Sets count clock to fxp to fxp/2 <sup>12</sup>                           | Operable                                       |                                                                                  |                                           |  |
| H1                     | Sets count clock to f <sub>RL</sub> /2 <sup>7</sup>                      | Operable                                       | Operable                                                                         | Operation stops.                          |  |
| Watchdog timer         | "System clock" selected as operating clock                               | Setting disabled.                              | Operation stops.                                                                 |                                           |  |
|                        | "Low-speed internal oscillation<br>clock" selected as operating<br>clock | Operable (Operation continues)                 | Operation stops.                                                                 |                                           |  |
| Power-on-clear circuit |                                                                          | Always operates.                               |                                                                                  |                                           |  |
| Low-voltage            | e detector                                                               | Operable                                       |                                                                                  |                                           |  |
| External interrupt     |                                                                          | Operable                                       |                                                                                  |                                           |  |

**Note** "Cannot be stopped" or "Stopped by software" is selected for low-speed internal oscillator by the option byte (for the option byte, see **CHAPTER 13 OPTION BYTE**).

# (2) HALT mode release

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

#### (a) Release by unmasked interrupt request

When an unmasked interrupt request is generated, the HALT mode is released. If interrupt acknowledgement is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgement is disabled, the next address instruction is executed.

Figure 9-1. HALT Mode Release by Interrupt Request Generation



- **Remarks 1.** The broken lines indicate the case when the interrupt request which has released the standby mode is acknowledged.
  - 2. The wait time is as follows:
    - When vectored interrupt servicing is carried out: 11 to 13 clocks
    - · When vectored interrupt servicing is not carried out: 3 to 5 clocks

### (b) Release by reset signal generation

When the reset signal is input, HALT mode is released, and then, as in the case with a normal reset operation, the program is executed after branching to the reset vector address.

Figure 9-2. HALT Mode Release by Reset Signal Generation



**Note** Operation is stopped (277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), 1.075 ms (MAX.)) because the option byte is referenced.

Table 9-3. Operation in Response to Interrupt Request in HALT Mode

| Release Source             | MK××                      | ΙE | Operation                          |  |
|----------------------------|---------------------------|----|------------------------------------|--|
| Maskable interrupt request | ble interrupt request 0 0 |    | Next address instruction execution |  |
|                            | 0                         | 1  | Interrupt servicing execution      |  |
|                            | 1                         | ×  | HALT mode held                     |  |
| Reset signal generation    | _                         | ×  | Reset processing                   |  |

×: don't care

#### 9.2.2 STOP mode

# (1) STOP mode setting and operating statuses

The STOP mode is set by executing the STOP instruction.

Caution Because an interrupt request signal is used to clear the standby mode, if there is an interrupt source with the interrupt request flag set and the interrupt mask flag reset, the standby mode is immediately cleared if set. Thus, in the STOP mode, the normal operation mode is restored after the STOP instruction is executed and then the operation is stopped for the duration of 34  $\mu$ s (TYP.).

The operating statuses in the STOP mode are shown below.

Table 9-4. Operating Statuses in STOP Mode

|                | Setting of STOP Mode                                                     | Low-Speed Internal                             | Low-Speed Internal Oscillator can be stopped Note. |                                           |  |  |
|----------------|--------------------------------------------------------------------------|------------------------------------------------|----------------------------------------------------|-------------------------------------------|--|--|
| Item           |                                                                          | Oscillator cannot be stopped <sup>Note</sup> . | When Low-Speed Internal Oscillation Continues      | When Low-Speed Internal Oscillation Stops |  |  |
| System clo     | ck                                                                       | Oscillation stops.                             |                                                    |                                           |  |  |
| CPU            |                                                                          | Operation stops.                               |                                                    |                                           |  |  |
| Port (latch)   |                                                                          | Holds status before STOP                       | mode was set.                                      |                                           |  |  |
| 8-bit timer    | Sets count clock to fxp to fxp/2 <sup>12</sup>                           | Operation stops.                               |                                                    |                                           |  |  |
| H1             | Sets count clock to f <sub>RL</sub> /2 <sup>7</sup>                      | Operable                                       | Operable                                           | Operation stops.                          |  |  |
| Watchdog timer | "System clock" selected as operating clock                               | Setting disabled.                              | Operation stops.                                   |                                           |  |  |
|                | "Low-speed internal oscillation<br>clock" selected as operating<br>clock | Operable<br>(Operation continues)              | Operation stops.                                   |                                           |  |  |
| Power-on-c     | elear circuit                                                            | Always operates.                               |                                                    |                                           |  |  |
| Low-voltage    | e detector                                                               | Operable                                       |                                                    |                                           |  |  |
| External int   | errupt                                                                   | Operable                                       |                                                    |                                           |  |  |

**Note** "Cannot be stopped" or "Stopped by software" is selected for low-speed internal oscillator by the option byte (for the option byte, see **CHAPTER 13 OPTION BYTE**).

### (2) STOP mode release

Figure 9-3. Operation Timing When STOP Mode Is Released



**Note** The operation stop time is 17  $\mu$ s (MIN.), 34  $\mu$ s (TYP.), and 67  $\mu$ s (MAX.).

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

### (a) Release by unmasked interrupt request

When an unmasked interrupt request (8-bit timer H1<sup>Note</sup>, low-voltage detector, external interrupt request) is generated, the STOP mode is released. After the oscillation stabilization time has elapsed, if interrupt acknowledgment is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgment is disabled, the next address instruction is executed.

Note Only when sets count clock to f<sub>RL</sub>/2<sup>7</sup>

Figure 9-4. STOP Mode Release by Interrupt Request Generation



**Note** The operation stop time is 17  $\mu$ s (MIN.), 34  $\mu$ s (TYP.), and 67  $\mu$ s (MAX.).

**Remark** The broken lines indicate the case when the interrupt request that has released the standby mode is acknowledged.

# (b) Release by reset signal generation

When the reset signal is input, STOP mode is released and a reset operation is performed after the oscillation stabilization time has elapsed.

Figure 9-5. STOP Mode Release by Reset signal generation



**Note** Operation is stopped (277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), 1.075 ms (MAX.)) because the option byte is referenced.

Table 9-5. Operation in Response to Interrupt Request in STOP Mode

| Release Source             | MK××                          | ΙE | Operation                          |
|----------------------------|-------------------------------|----|------------------------------------|
| Maskable interrupt request | askable interrupt request 0 0 |    | Next address instruction execution |
|                            | 0                             | 1  | Interrupt servicing execution      |
|                            | 1                             | ×  | STOP mode held                     |
| Reset signal generation    | _                             | ×  | Reset processing                   |

x: don't care

#### **CHAPTER 10 RESET FUNCTION**

The following four operations are available to generate a reset signal.

- (1) External reset input via RESET pin
- (2) Internal reset by watchdog timer overflows
- (3) Internal reset by comparison of supply voltage and detection voltage of power-on-clear (POC) circuit
- (4) Internal reset by comparison of supply voltage and detection voltage of low-power-supply detector (LVI)

External and internal resets have no functional differences. In both cases, program execution starts from the programs at the address written in addresses 0000H and 0001H when the reset signal is generated.

A reset is applied when a low level is input to the RESET pin, the watchdog timer overflows, or by POC and LVI circuit voltage detection, and each item of hardware is set to the status shown in Table 10-1. Each pin is high impedance during reset signal generation or during the oscillation stabilization time just after reset release, except for P130, which is low-level output.

When a low level is input to the RESET pin, a reset occurs, and when a high level is input to the RESET pin, the reset is released and the CPU starts program execution after referencing the option byte. A reset generated by the watchdog timer source is automatically released after the reset, and the CPU starts program execution after referencing the option byte. (see **Figures 10-2** to **10-4**). Reset by POC and LVI circuit power supply detection is automatically released when VDD > VPOC or VDD > VLVI after the reset, and the CPU starts program execution after referencing the option byte (see **CHAPTER 11 POWER-ON-CLEAR CIRCUIT** and **CHAPTER 12 LOW-VOLTAGE DETECTOR**).

- Cautions 1. For an external reset, input a low level for 2  $\mu$ s or more to the RESET pin.
  - 2. During reset signal generation, the system clock and low-speed internal oscillation clock stop oscillating.
  - 3. When the RESET pin is used as an input-only port pin (P34), the μPD78F9500, 78F9501, 78F9502 are reset if a low level is input to the RESET pin after reset is released by the POC circuit, the LVI circuit and the watchdog timer and before the option byte is referenced again. The reset status is retained until a high level is input to the RESET pin.

<R>

Reset signal of WDT

Reset signal of POC

Reset signal of LVI

Figure 10-1. Block Diagram of Reset Function

Caution The LVI circuit is not reset by the internal reset signal of the LVI circuit.

Remarks 1. LVIM: Low-voltage detect register

2. LVIS: Low-voltage detection level select register



Figure 10-2. Timing of Reset by RESET Input

**Note** The operation stop time is 277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), and 1.075 ms (MAX.).

Figure 10-3. Timing of Reset by Overflow of Watchdog Timer



**Note** The operation stop time is 277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), and 1.075 ms (MAX.).

Caution The watchdog timer is also reset in the case of an internal reset of the watchdog timer.

Figure 10-4. Reset Timing by RESET Input in STOP Mode



**Note** The operation stop time is 277  $\mu$ s (MIN.), 544  $\mu$ s (TYP.), and 1.075 ms (MAX.).

Remark For the reset timing of the power-on-clear circuit and low-voltage detector, refer to CHAPTER 11 POWER-ON-CLEAR CIRCUIT and CHAPTER 12 LOW-VOLTAGE DETECTOR.

Table 10-1. Hardware Statuses After Reset Acknowledgment

| Program counter (PC) Notes 1         Contents of reset vector table (0000H and 0001H) are set.           Stack pointer (SP)         Undefined           Program status word (PSW)         02H           RAM         Data memory         Undefined Note 2           Ports (P2 to P4) (output latches)         00H           Port mode registers (PM2 to PM4)         FFH           Pull-up resistor option registers (PU2 to PU4)         00H           Processor clock control register (PCC)         02H           Preprocessor clock control register (PCC)         02H           Low-speed internal oscillation mode register (LSRCM)         00H           8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register (WDTM)         67H           Enable register (WDTM)         67H           Reset function         Reset control flag register (RESF)         00H Note 3           Low-voltage detector         Low-voltage detection register (LVIM)         00H Note 3           Interrupt         Request flag registers (MK0)         FFH           Mask flag registers (MK0)         FFH           External interrupt mode register (FCMD)         Undefined           Flash programming mode control register (FLPMC)         Undefined           Flash programming command r                                                            |                                        | Hardware                                           | Status After Reset          |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------------|-----------------------------|--|--|--|
| Program status word (PSW)         Data memory         Undefined Notes 2           RAM         Data memory         Undefined Notes 2           Ports (P2 to P4) (output latches)         00H           Port mode registers (PM2 to PM4)         FFH           Pull-up resistor option registers         (PU2 to PU4)         00H           Processor clock control register (PPCC)         02H           Preprocessor clock control register (PPCC)         02H           Low-speed internal oscillation mode register (LSRCM)         00H           8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register 1 (TMHMD1)         00H           Watchdog timer         Mode register (WDTM)         67H           Enable register (WDTE)         9AH           Reset function         Reset control flag register (RESF)         00H***                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Program counter (PC) <sup>Note 1</sup> |                                                    |                             |  |  |  |
| Bata memory         Undefined Note 2           Ports (P2 to P4) (output latches)         00H           Port mode registers (PM2 to PM4)         FFH           Pull-up resistor option registers (PM2 to PU4)         00H           Processor clock control register (PCC)         02H           Preprocessor clock control register (PCC)         02H           Low-speed internal oscillation mode register (LSRCM)         00H           8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register 1 (TMHMD1)         00H           Watchdog timer         Mode register (WDTM)         67H           Enable register (WDTE)         9AH           Reset function         Reset control flag register (RESF)         00H Note 3           Low-voltage detector         Low-voltage detection register (LVIM)         00H Note 3           Interrupt         Request flag registers (IFC)         00H Note 3           Interrupt         Request flag registers (IFC)         00H Note 3           External interrupt mode register (FC)         00H           External interrupt mode register (FC)         Undefined           Flash programming mode control register (FLPMC)         Undefined           Flash programming command register (FLCMD)         00H           Flash address pointer H (F                                             | Stack pointer (SP)                     | Stack pointer (SP)                                 |                             |  |  |  |
| General-purpose registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Program status word (PSW)              |                                                    | _                           |  |  |  |
| Ports (P2 to P4) (output latches)         00H           Port mode registers (PM2 to PM4)         FFH           Pull-up resistor option registers (PU2 to PU4)         00H           Processor clock control register (PCC)         02H           Preprocessor clock control register (PCC)         02H           Low-speed internal oscillation mode register (LSRCM)         00H           8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register (WDTM)         67H           Enable register (WDTM)         67H           Enable register (WDTE)         9AH           Reset function         Reset control flag register (RESF)         00H Note 3           Low-voltage detector         Low-voltage detection register (LVIM)         00H Note 3           Interrupt         Request flag registers (IFC)         00H           Mask flag registers (IFC)         00H           Mask flag registers (IFC)         00H           External interrupt mode register (PFCMD)         Undefined           Flash programming mode control register (FLCMD)         Undefined           Flash programming command register (FLCMD)         Undefined           Flash address pointer L (FLAPL)         Undefined           Flash address pointer H compare register (FLAPHC)         00H <td< td=""><td>RAM</td><td>Data memory</td><td></td></td<> | RAM                                    | Data memory                                        |                             |  |  |  |
| Port mode registers (PM2 to PM4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                        | General-purpose registers                          | Undefined <sup>Note 2</sup> |  |  |  |
| Pull-up resistor option registers (PU2 to PU4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ports (P2 to P4) (output latche        | es)                                                | 00H                         |  |  |  |
| Processor clock control register (PCC)         02H           Preprocessor clock control register (PPCC)         02H           Low-speed internal oscillation mode register (LSRCM)         00H           8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register 1 (TMHMD1)         00H           Watchdog timer         Mode register (WDTM)         67H           Enable register (WDTE)         9AH           Reset function         Reset control flag register (RESF)         00H <sup>Note 3</sup> Low-voltage detector         Low-voltage detection register (LVIM)         00H <sup>Note 3</sup> Interrupt         Request flag registers (IFO)         00H           Mask flag registers (MK0)         FFH           External interrupt mode registers (INTM0)         00H           Flash protect command register (PFCMD)         Undefined           Flash status register (PFS)         00H           Flash programming mode control register (FLCMD)         00H           Flash address pointer L (FLAPL)         Undefined           Flash address pointer H (FLAPH)         Flash address pointer H compare register (FLAPHC)         00H           Flash address pointer L compare register (FLAPHC)         00H         00H                                                                                                     | Port mode registers (PM2 to F          | PM4)                                               | FFH                         |  |  |  |
| Preprocessor clock control register (PPCC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Pull-up resistor option register       | rs (PU2 to PU4)                                    | 00H                         |  |  |  |
| Low-speed internal oscillation mode register (LSRCM) 8-bit timer H1  Compare registers (CMP01, CMP11)  Mode register 1 (TMHMD1)  Watchdog timer  Mode register (WDTM) Enable register (WDTE)  Reset function  Reset control flag register (RESF)  Low-voltage detector  Low-voltage detector level select register (LVIS)  Interrupt  Request flag registers (IFO) Mask flag registers (IFO) External interrupt mode registers (INTMO)  Flash protect command register (PFCMD)  Flash programming mode control register (FLPMC)  Flash address pointer L (FLAPL)  Flash address pointer H compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  OOH  OOH  OOH  OOH  OOH  OOH  Flash address pointer L compare register (FLAPLC)  OOH  Flash address pointer L compare register (FLAPLC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Processor clock control regist         | er (PCC)                                           | 02H                         |  |  |  |
| 8-bit timer H1         Compare registers (CMP01, CMP11)         00H           Mode register 1 (TMHMD1)         00H           Watchdog timer         Mode register (WDTM)         67H           Enable register (WDTE)         9AH           Reset function         Reset control flag register (RESF)         00H <sup>Note 3</sup> Low-voltage detector         Low-voltage detection register (LVIM)         00H <sup>Note 3</sup> Low-voltage detection level select register (LVIS)         00H <sup>Note 3</sup> Interrupt         Request flag registers (IFO)         00H           Mask flag registers (MKO)         FFH           External interrupt mode registers (INTMO)         00H           Flash protect command register (PFCMD)         Undefined           Flash status register (PFS)         00H           Flash programming mode control register (FLPMC)         Undefined           Flash programming command register (FLCMD)         00H           Flash address pointer H (FLAPH)         Undefined           Flash address pointer H compare register (FLAPHC)         00H           Flash address pointer L compare register (FLAPLC)         00H                                                                                                                                                                                                          | Preprocessor clock control reg         | gister (PPCC)                                      | 02H                         |  |  |  |
| Mode register 1 (TMHMD1) 00H  Mode register (WDTM) 67H  Enable register (WDTE) 9AH  Reset function Reset control flag register (RESF) 00H <sup>Note 3</sup> Low-voltage detector Low-voltage detection register (LVIM) 00H <sup>Note 3</sup> Low-voltage detection level select register (LVIS) 00H <sup>Note 3</sup> Interrupt Request flag registers (IFO) 00H  Mask flag registers (IFO) 00H  External interrupt mode registers (INTM0) 00H  Flash protect command register (PFCMD) Undefined  Flash status register (PFS) 00H  Flash programming mode control register (FLCMD) 00H  Flash address pointer L (FLAPL) Undefined  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPLC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Low-speed internal oscillation         | mode register (LSRCM)                              | 00H                         |  |  |  |
| Watchdog timer     Mode register (WDTM)     67H       Enable register (WDTE)     9AH       Reset function     Reset control flag register (RESF)     00H <sup>Note 3</sup> Low-voltage detector     Low-voltage detection register (LVIM)     00H <sup>Note 3</sup> Interrupt     Request flag registers (IF0)     00H       Mask flag registers (MK0)     FFH       External interrupt mode registers (INTM0)     00H       Flash protect command register (PFCMD)     Undefined       Flash status register (PFS)     00H       Flash programming mode control register (FLPMC)     Undefined       Flash address pointer L (FLAPL)     Undefined       Flash address pointer H (FLAPH)     Undefined       Flash address pointer H compare register (FLAPHC)     00H       Flash address pointer L compare register (FLAPLC)     00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8-bit timer H1                         | Compare registers (CMP01, CMP11)                   | 00H                         |  |  |  |
| Enable register (WDTE)  Reset function  Reset control flag register (RESF)  Low-voltage detector  Low-voltage detection register (LVIM)  Low-voltage detection level select register (LVIS)  Interrupt  Request flag registers (IFO)  Mask flag registers (MKO)  External interrupt mode registers (INTMO)  Flash protect command register (PFCMD)  Flash status register (PFS)  Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                        | Mode register 1 (TMHMD1)                           | 00H                         |  |  |  |
| Reset function Reset control flag register (RESF)  Low-voltage detector  Low-voltage detection register (LVIM)  Low-voltage detection level select register (LVIS)  Interrupt  Request flag registers (IF0)  Mask flag registers (MK0)  External interrupt mode registers (INTM0)  Flash protect command register (PFCMD)  Flash status register (PFS)  OOH  Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  OOH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Watchdog timer                         | Mode register (WDTM)                               | 67H                         |  |  |  |
| Low-voltage detection register (LVIM) 00H <sup>Note 3</sup> Low-voltage detection level select register (LVIS) 00H <sup>Note 3</sup> Interrupt Request flag registers (IFO) 00H  Mask flag registers (MK0) FFH  External interrupt mode registers (INTM0) 00H  Flash protect command register (PFCMD) Undefined  Flash status register (PFS) 00H  Flash programming mode control register (FLPMC) Undefined  Flash address pointer L (FLAPL) Undefined  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC) 00H  Flash address pointer L compare register (FLAPHC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                        | Enable register (WDTE)                             |                             |  |  |  |
| Low-voltage detection level select register (LVIS)    Dot Note 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset function                         | Reset control flag register (RESF)                 | 00H <sup>Note 3</sup>       |  |  |  |
| Interrupt Request flag registers (IF0) 00H  Mask flag registers (MK0) FFH  External interrupt mode registers (INTM0) 00H  Flash memory Flash protect command register (PFCMD) Undefined  Flash status register (PFS) 00H  Flash programming mode control register (FLPMC) Undefined  Flash programming command register (FLCMD) 00H  Flash address pointer L (FLAPL) Undefined  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC) 00H  Flash address pointer L compare register (FLAPHC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Low-voltage detector                   | Low-voltage detection register (LVIM)              |                             |  |  |  |
| Mask flag registers (MK0)  External interrupt mode registers (INTM0)  Flash protect command register (PFCMD)  Flash status register (PFS)  Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)  OOH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                        | Low-voltage detection level select register (LVIS) | 00H <sup>Note 3</sup>       |  |  |  |
| External interrupt mode registers (INTM0) 00H  Flash protect command register (PFCMD) Undefined  Flash status register (PFS) 00H  Flash programming mode control register (FLPMC) Undefined  Flash programming command register (FLCMD) 00H  Flash address pointer L (FLAPL) Undefined  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC) 00H  Flash address pointer L compare register (FLAPHC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Interrupt                              | Request flag registers (IF0)                       | 00H                         |  |  |  |
| Flash protect command register (PFCMD)  Flash status register (PFS)  Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  Flash address pointer L compare register (FLAPLC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                        | Mask flag registers (MK0)                          | FFH                         |  |  |  |
| Flash status register (PFS)  Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                        | External interrupt mode registers (INTM0)          | 00H                         |  |  |  |
| Flash programming mode control register (FLPMC)  Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  OOH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Flash memory                           | Flash protect command register (PFCMD)             | Undefined                   |  |  |  |
| Flash programming command register (FLCMD)  Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  OOH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                        | Flash status register (PFS)                        | 00H                         |  |  |  |
| Flash address pointer L (FLAPL)  Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  OOH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                        | Flash programming mode control register (FLPMC)    | Undefined                   |  |  |  |
| Flash address pointer H (FLAPH)  Flash address pointer H compare register (FLAPHC)  Flash address pointer L compare register (FLAPLC)  00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                        | Flash programming command register (FLCMD)         | 00Н                         |  |  |  |
| Flash address pointer H compare register (FLAPHC) 00H  Flash address pointer L compare register (FLAPLC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                        | Flash address pointer L (FLAPL)                    | Undefined                   |  |  |  |
| Flash address pointer L compare register (FLAPLC) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                        | Flash address pointer H (FLAPH)                    |                             |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                        | Flash address pointer H compare register (FLAPHC)  | 00H                         |  |  |  |
| Flash write buffer register (FLW) 00H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                        | Flash address pointer L compare register (FLAPLC)  | 00H                         |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                        | Flash write buffer register (FLW)                  | 00H                         |  |  |  |

**Notes 1.** Only the contents of PC are undefined while reset signal generation and while the oscillation stabilization time elapses. The statuses of the other hardware units remain unchanged.

2. The status after reset is held in the standby mode.

**Note** 3. These values change as follows depending on the reset source.

|          | Reset Source | RESET Input   | Reset by POC  | Reset by WDT  | Reset by LVI |
|----------|--------------|---------------|---------------|---------------|--------------|
| Register |              |               |               |               |              |
| RESF     | WDTRF        | Cleared (0)   | Cleared (0)   | Set (1)       | Held         |
|          | LVIRF        |               |               | Held          | Set (1)      |
| LVIM     |              | Cleared (00H) | Cleared (00H) | Cleared (00H) | Held         |
| LVIS     |              |               |               |               |              |

# 10.1 Register for Confirming Reset Source

Many internal reset generation sources exist in the  $\mu$ PD78F9500, 78F9501, 78F9502. The reset control flag register (RESF) is used to store which source has generated the reset request.

RESF can be read by an 8-bit memory manipulation instruction.

RESET input, reset signal generation by power-on-clear (POC) circuit, and reading RESF clear RESF to 00H.

Figure 10-5. Format of Reset Control Flag Register (RESF)

| Address: FF5 | 4H After re | eset: 00H <sup>Note</sup> | R |       |   |   |   |       |
|--------------|-------------|---------------------------|---|-------|---|---|---|-------|
| Symbol       | 7           | 6                         | 5 | 4     | 3 | 2 | 1 | 0     |
| RESF         | 0           | 0                         | 0 | WDTRF | 0 | 0 | 0 | LVIRF |

| WDTRF | Internal reset request by watchdog timer (WDT)               |
|-------|--------------------------------------------------------------|
| 0     | Internal reset request is not generated, or RESF is cleared. |
| 1     | Internal reset request is generated.                         |

| LVIRF | Internal reset request by low-voltage detector (LVI)         |
|-------|--------------------------------------------------------------|
| 0     | Internal reset request is not generated, or RESF is cleared. |
| 1     | Internal reset request is generated.                         |

**Note** The value after reset varies depending on the reset source.

# Caution Do not read data by a 1-bit memory manipulation instruction.

The status of RESF when a reset request is generated is shown in Table 10-2.

Table 10-2. RESF Status When Reset Request Is Generated

| Reset Source | RESET Input | Reset by POC | Reset by WDT | Reset by LVI |
|--------------|-------------|--------------|--------------|--------------|
| Flag         |             |              |              |              |
| WDTRF        | Cleared (0) | Cleared (0)  | Set (1)      | Held         |
| LVIRF        |             |              | Held         | Set (1)      |

### **CHAPTER 11 POWER-ON-CLEAR CIRCUIT**

#### 11.1 Functions of Power-on-Clear Circuit

The power-on-clear circuit (POC) has the following functions.

- Generates internal reset signal at power on.
- Compares supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>POC</sub> = 2.1 V ±0.1 V), and generates internal reset signal when V<sub>DD</sub> < V<sub>POC</sub>.
- Compares supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>POC</sub> = 2.1 V ±0.1 V), and releases internal reset signal when V<sub>DD</sub> ≥ V<sub>POC</sub>.
- Cautions 1. If an internal reset signal is generated in the POC circuit, the reset control flag register (RESF) is cleared to 00H.
  - 2. Because the detection voltage (VPOC) of the POC circuit is in a range of 2.1 V  $\pm$ 0.1 V, use a voltage in the range of 2.2 to 5.5 V.
- Remark This product incorporates multiple hardware functions that generate an internal reset signal. A flag that indicates the reset cause is located in the reset control flag register (RESF) for when an internal reset signal is generated by the watchdog timer (WDT) or low-voltage-detection (LVI) circuit. RESF is not cleared to 00H and the flag is set to 1 when an internal reset signal is generated by WDT or LVI. For details of RESF, see CHAPTER 10 RESET FUNCTION.

# 11.2 Configuration of Power-on-Clear Circuit

The block diagram of the power-on-clear circuit is shown in Figure 11-1.

V<sub>DD</sub>
Internal reset signal
Reference voltage source

Figure 11-1. Block Diagram of Power-on-Clear Circuit

# 11.3 Operation of Power-on-Clear Circuit

In the power-on-clear circuit, the supply voltage ( $V_{DD}$ ) and detection voltage ( $V_{POC} = 2.1 \text{ V} \pm 0.1 \text{ V}$ ) are compared, and an internal reset signal is generated when  $V_{DD} < V_{POC}$ , and an internal reset is released when  $V_{DD} \ge V_{POC}$ .



Figure 11-2. Timing of Internal Reset Signal Generation in Power-on-Clear Circuit

#### 11.4 Cautions for Power-on-Clear Circuit

In a system where the supply voltage (VDD) fluctuates for a certain period in the vicinity of the POC detection voltage (VPOC), the system may be repeatedly reset and released from the reset status. In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking the following action.

#### <Action>

After releasing the reset signal, wait for the supply voltage fluctuation period of each system by means of a software counter that uses a timer, and then initialize the ports.

Figure 11-3. Example of Software Processing After Release of Reset (1/2)

• If supply voltage fluctuation is 50 ms or less in vicinity of POC detection voltage



- Notes 1. If reset is generated again during this period, initialization processing <2> is not started.
  - 2. A flowchart is shown on the next page.

Figure 11-3. Example of Software Processing After Release of Reset (2/2)

# • Checking reset cause



# **CHAPTER 12 LOW-VOLTAGE DETECTOR**

# 12.1 Functions of Low-Voltage Detector

The low-voltage detector (LVI) has following functions.

- Compares supply voltage (V<sub>DD</sub>) and detection voltage (V<sub>LVI</sub>), and generates an internal interrupt signal or internal reset signal when V<sub>DD</sub> < V<sub>LVI</sub>.
- Detection levels (ten levels) of supply voltage can be changed by software.
- Interrupt or reset function can be selected by software.
- Operable in STOP mode.

When the low-voltage detector is used to reset, bit 0 (LVIRF) of the reset control flag register (RESF) is set to 1 if reset occurs. For details of RESF, refer to **CHAPTER 10 RESET FUNCTION**.

# 12.2 Configuration of Low-Voltage Detector

The block diagram of the low-voltage detector is shown in Figure 12-1.

VDD -ow-voltage detection level selector  $V_{DD}$ Internal reset signal Selector - INTLVI Reference voltage source 4 LVION LVIMD LVIS3 LVIS2 LVIS1 LVIS0 LVIF Low-voltage detection Low-voltage detect register (LVIM) level select register (LVIS) Internal bus

Figure 12-1. Block Diagram of Low-Voltage Detector

# 12.3 Registers Controlling Low-Voltage Detector

The low-voltage detector is controlled by the following registers.

- Low-voltage detect register (LVIM)
- Low-voltage detection level select register (LVIS)

### (1) Low-voltage detect register (LVIM)

This register sets low-voltage detection and the operation mode.

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

Reset signal generation clears this register to 00H<sup>Note 1</sup>.

Figure 12-2. Format of Low-Voltage Detect Register (LVIM)

| Address: | FF50H Afte | er reset: 00H | Note 1 R/W <sup>Note</sup> | 2 |   |   |       |      |
|----------|------------|---------------|----------------------------|---|---|---|-------|------|
| Symbol   | <7>        | 6             | 5                          | 4 | 3 | 2 | <1>   | <0>  |
| LVIM     | LVION      | 0             | 0                          | 0 | 0 | 0 | LVIMD | LVIF |

| LVION <sup>Note 3</sup> | Enabling low-voltage detection operation |
|-------------------------|------------------------------------------|
| 0                       | Disable operation                        |
| 1                       | Enable operation                         |

|                                                                                      | LVIMD | Low-voltage detection operation mode selection                                      |
|--------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------|
|                                                                                      | 0     | Generate interrupt signal when supply voltage (VDD) < detection voltage (VLVI)      |
| 1 Generate internal reset signal when supply voltage (VDD) < detection voltage (VLVI |       | Generate internal reset signal when supply voltage (VDD) < detection voltage (VLVI) |

| LVIF <sup>Note 4</sup>                            | Low-voltage detection flag                                                                               |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 0                                                 | Supply voltage (V <sub>DD</sub> ) ≥ detection voltage (V <sub>LVI</sub> ), or when operation is disabled |
| 1 Supply voltage (VDD) < detection voltage (VLVI) |                                                                                                          |

**Notes 1.** For a reset by LVI, the value of LVIM is not initialized.

- 2. Bit 0 is a read-only bit.
- 3. When LVION is set to 1, operation of the comparator in the LVI circuit is started. Use software to instigate a wait of at least 0.2 ms from when LVION is set to 1 until the voltage is confirmed at LVIF.
- **4.** The value of LVIF is output as the interrupt request signal INTLVI when LVION = 1 and LVIMD = 0.

### Cautions 1. To stop LVI, follow either of the procedures below.

- When using 8-bit manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVION to 0.
- 2. Be sure to set bits 2 to 6 to 0.

# (2) Low-voltage detection level select register (LVIS)

This register selects the low-voltage detection level.

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

Reset signal generation clears this register to 00H<sup>Note</sup>.

Figure 12-3. Format of Low-Voltage Detection Level Select Register (LVIS)

Address: FF51H, After reset: 00H Note R/W Symbol 5 4 3 2 1 0 LVIS 0 0 0 LVIS3 LVIS2 LVIS1 LVIS0 0

| LVIS3 | LVIS2            | LVIS1 | LVIS0 | Detection level                    |
|-------|------------------|-------|-------|------------------------------------|
| 0     | 0                | 0     | 0     | VLVI0 (4.3 V ±0.2 V)               |
| 0     | 0                | 0     | 1     | V <sub>LVI1</sub> (4.1 V ±0.2 V)   |
| 0     | 0                | 1     | 0     | V <sub>LVI2</sub> (3.9 V ±0.2 V)   |
| 0     | 0                | 1     | 1     | V <sub>LVI3</sub> (3.7 V ±0.2 V)   |
| 0     | 1                | 0     | 0     | V <sub>LVI4</sub> (3.5 V ±0.2 V)   |
| 0     | 1                | 0     | 1     | V <sub>LVI5</sub> (3.3 V ±0.15 V)  |
| 0     | 1                | 1     | 0     | V <sub>LVI6</sub> (3.1 V ±0.15 V)  |
| 0     | 1                | 1     | 1     | V <sub>LV17</sub> (2.85 V ±0.15 V) |
| 1     | 0                | 0     | 0     | V <sub>LVI8</sub> (2.6 V ±0.1 V)   |
| 1     | 0                | 0     | 1     | V <sub>LVI9</sub> (2.35 V ±0.1 V)  |
|       | Other than above |       |       | Setting prohibited                 |

Note For a reset by LVI, the value of LVIS is not initialized.

#### Cautions 1. Bits 4 to 7 must be set to 0.

2. If a value other than the above is written during LVI operation, the value becomes undefined at the very moment it is written, and thus be sure to stop LVI (bit 7(LVION) = 0 on the LVIM register) before writing.

# 12.4 Operation of Low-Voltage Detector

The low-voltage detector can be used in the following two modes.

· Used as reset

Compares the supply voltage ( $V_{DD}$ ) and detection voltage ( $V_{LVI}$ ), and generates an internal reset signal when  $V_{DD} < V_{LVI}$ , and releases internal reset when  $V_{DD} \ge V_{LVI}$ .

· Used as interrupt

Compares the supply voltage ( $V_{DD}$ ) and detection voltage ( $V_{LVI}$ ), and generates an interrupt signal (INTLVI) when  $V_{DD} < V_{LVI}$ .

The operation is set as follows.

#### (1) When used as reset

- · When starting operation
- <1> Mask the LVI interrupt (LVIMK = 1).
- <2> Set the detection voltage using bits 3 to 0 (LVIS3 to LVIS0) of the low-voltage detection level select register (LVIS).
- <3> Set bit 7 (LVION) of LVIM to 1 (enables LVI operation).
- <4> Use software to instigate a wait of at least 0.2 ms.
- <5> Wait until "supply voltage (VDD) ≥ detection voltage (VLVI)" at bit 0 (LVIF) of LVIM is confirmed.
- <6> Set bit 1 (LVIMD) of LVIM to 1 (generates internal reset signal when supply voltage (VDD) < detection voltage (VLVI)).

Figure 12-4 shows the timing of generating the internal reset signal of the low-voltage detector. Numbers <1> to <6> in this figure correspond to <1> to <6> above.

- Cautions 1. <1> must always be executed. When LVIMK = 0, an interrupt may occur immediately after the processing in <3>.
  - 2. If supply voltage (V<sub>DD</sub>) ≥ detection voltage (V<sub>LVI</sub>) when LVIMD is set to 1, an internal reset signal is not generated.
- When stopping operation

Either of the following procedures must be executed.

- When using 8-bit memory manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVIMD to 0 and LVION to 0 in that order.



Figure 12-4. Timing of Low-Voltage Detector Internal Reset Signal Generation

- **Notes 1.** The LVIMK flag is set to "1" by reset signal generation.
  - 2. The LVIF flag may be set (1).
  - 3. LVIRF is bit 0 of the reset control flag register (RESF). For details of RESF, refer to **CHAPTER 10 RESET FUNCTION**.

**Remark** <1> to <6> in Figure 12-4 above correspond to <1> to <6> in the description of "when starting operation" in **12.4** (1) When used as reset.

### (2) When used as interrupt

- · When starting operation
- <1> Mask the LVI interrupt (LVIMK = 1).
- <2> Set the detection voltage using bits 3 to 0 (LVIS3 to LVIS0) of the low-voltage detection level select register (LVIS).
- <3> Set bit 7 (LVION) of LVIM to 1 (enables LVI operation).
- <4> Use software to instigate a wait of at least 0.2 ms.
- <5> Wait until "supply voltage (VDD) ≥ detection voltage (VLVI)" at bit 0 (LVIF) of LVIM is confirmed.
- <6> Clear the interrupt request flag of LVI (LVIIF) to 0.
- <7> Release the interrupt mask flag of LVI (LVIMK).
- <8> Execute the El instruction (when vector interrupts are used).

Figure 12-5 shows the timing of generating the interrupt signal of the low-voltage detector. Numbers <1> to <7> in this figure correspond to <1> to <7> above.

• When stopping operation

Either of the following procedures must be executed.

- When using 8-bit memory manipulation instruction: Write 00H to LVIM.
- When using 1-bit memory manipulation instruction: Clear LVION to 0.



Figure 12-5. Timing of Low-Voltage Detector Interrupt Signal Generation

- **Notes 1.** The LVIMK flag is set to "1" by reset signal generation.
  - 2. An interrupt request signal (INTLVI) may be generated, and the LVIF and LVIIF flags may be set to 1.

Remark <1> to <7> in Figure 12-5 above correspond to <1> to <7> in the description of "when starting operation" in 12.4 (2) When used as interrupt.

# 12.5 Cautions for Low-Voltage Detector

In a system where the supply voltage ( $V_{DD}$ ) fluctuates for a certain period in the vicinity of the LVI detection voltage ( $V_{LVI}$ ), the operation is as follows depending on how the low-voltage detector is used.

#### <1> When used as reset

The system may be repeatedly reset and released from the reset status.

In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking action (1) below.

### <2> When used as interrupt

Interrupt requests may be frequently generated. Take (b) of action (2) below.

In this system, take the following actions.

#### <Action>

#### (1) When used as reset

After releasing the reset signal, wait for the supply voltage fluctuation period of each system by means of a software counter that uses a timer, and then initialize the ports (see **Figure 12-6**).

# (2) When used as interrupt

- (a) Perform the processing<sup>Note</sup> for low voltage detection. Check that "supply voltage (VDD) ≥ detection voltage (VLVI)" in the servicing routine of the LVI interrupt by using bit 0 (LVIF) of the low-voltage detection register (LVIM). Clear bit 1 (LVIIF) of interrupt request flag register 0 (IF0) to 0.
- (b) In a system where the supply voltage fluctuation period is long in the vicinity of the LVI detection voltage, wait for the supply voltage fluctuation period, check that "supply voltage (VDD) ≥ detection voltage (VLVI)" using the LVIF flag and clear LVIIF flag to 0.

Note For low voltage detection processing, the CPU clock speed is switched to slow speed, etc.

Figure 12-6. Example of Software Processing After Release of Reset (1/2)

• If supply voltage fluctuation is 50 ms or less in vicinity of LVI detection voltage



**Note** A flowchart is shown on the next page.

Figure 12-6. Example of Software Processing After Release of Reset (2/2)

# • Checking reset source



### **CHAPTER 13 OPTION BYTE**

# 13.1 Functions of Option Byte

The address 0080H of the flash memory of the  $\mu$ PD78F9500, 78F9501, 78F9502 is an option byte area. When power is supplied or when starting after a reset, the option byte is automatically referenced, and settings for the specified functions are performed. When using the product, be sure to set the following functions by using the option byte.

### (1) Selection of system clock source

- High-speed internal oscillation clock
- External clock input

# (2) Low-speed internal oscillation clock oscillation

- Cannot be stopped.
- Can be stopped by software.

# (3) Control of RESET pin

- Used as RESET pin
- RESET pin is used as an input-only port pin (P34) (see 13.3 Caution When the RESET Pin Is Used as an Input-Only Port Pin (P34)).
- The on-chip pull-up resistor on RESET pin is selected, or RESET pin is set open.

## (4) Oscillation stabilization time on power application or after reset release

- 2<sup>10</sup>/fx
- 2<sup>12</sup>/fx
- 2<sup>15</sup>/fx
- 2<sup>17</sup>/fx

Figure 13-1. Positioning of Option Byte



# 13.2 Format of Option Byte

Format of option bytes is shown below.

Figure 13-2. Format of Option Byte (1/2)

Address: 0080H

| 7 | 6 | 5 | 4      | 3    | 2       | 1       | 0     |
|---|---|---|--------|------|---------|---------|-------|
| 1 | 1 | 1 | ENPU34 | RMCE | OSCSEL1 | OSCSEL0 | LIOCP |

| ENPU34 | Selection of on-chip pull-up resistor on RESET pin     |  |  |  |
|--------|--------------------------------------------------------|--|--|--|
| 1      | On-chip pull-up resistor on RESET pin is selected.     |  |  |  |
| 0      | On-chip pull-up resistor on RESET pin is not selected. |  |  |  |

**Remark** When used as RESET pin, the pin can be left open by setting ENPU34 to "1".

| RMCE | Control of RESET pin                       |  |  |
|------|--------------------------------------------|--|--|
| 1    | RESET pin is used as is.                   |  |  |
| 0    | RESET pin is used as input port pin (P34). |  |  |

Caution Because the option byte is referenced after reset release, if a low level is input to the RESET pin before the option byte is referenced, then the reset state is not released.

When used as an input-only port (P34), the setting of the on-chip pull-up resistor can be done by PU34 on PU3 register.

| OSCSEL1 | OSCSEL0 | Selection of system clock source      |  |
|---------|---------|---------------------------------------|--|
| 0       | 0       | Setting prohibited                    |  |
| 0       | 1       | External clock input                  |  |
| 1       | ×       | High-speed internal oscillation clock |  |

Caution Because the EXCLK pin is also used as the P23 pin, the condition under which the EXCLK pin can be used differ depending on the selected system clock source.

- External clock input is selected
   Because the pin is used as an external clock input pin, P23 cannot be used as an I/O port pin.
- (2) High-speed internal oscillation clock is selected P23 pin can be used as an I/O port pin.

Remark ×: don't care

Figure 13-2. Format of Option Byte (2/2)

| LIOCP | Low-speed internal oscillates                                                         |  |  |
|-------|---------------------------------------------------------------------------------------|--|--|
| 1     | Cannot be stopped (oscillation does not stop even if 1 is written to the LSRSTOP bit) |  |  |
| 0     | Can be stopped by software (oscillation stops when 1 is written to the LSRSTOP bit)   |  |  |

Cautions 1. If it is selected that low-speed internal oscillator cannot be stopped, the count clock to the watchdog timer (WDT) is fixed to low-speed internal oscillation clock.

2. If it is selected that low-speed internal oscillator can be stopped by software, supply of the count clock to WDT is stopped in the HALT/STOP mode, regardless of the setting of bit 0 (LSRSTOP) of the low-speed internal oscillation mode register (LSRCM). Similarly, clock supply is also stopped when a clock other than the low-speed internal oscillation clock is selected as a count clock to WDT.

While the low-speed internal oscillator is operating (LSRSTOP = 0), the clock can be supplied to the 8-bit timer H1 even in the STOP mode.

**Remarks 1.** ( ): fx = 10 MHz

- 2. For the oscillation stabilization time of the resonator, refer to the characteristics of the resonator to be used.
- 3. An example of software coding for setting the option bytes is shown below.

OPB CSEG AT 0080H

DB 10010001B ; Set to option byte

; Low-speed internal oscillator cannot be stopped

; The RESET pin is used as an input-only port pin (P34).

; Minimum oscillation stabilization time (210/fx)

**4.** For details on the timing at which the option byte is referenced, see **CHAPTER 10 RESET FUNCTION**.

# 13.3 Caution When the RESET Pin Is Used as an Input-Only Port Pin (P34)

Be aware of the following when erasing/writing by on-board programming using a dedicated flash memory programmer once again on the already-written device which has been set as "The  $\overline{\text{RESET}}$  pin is used as an input-only port pin (P34)" by the option byte function.

Before supplying power to the target system, connect a dedicated flash memory programmer and turn its power on. If the power is supplied to the target system beforehand, it cannot be switched to the flash memory programming mode.

# **CHAPTER 14 FLASH MEMORY**

### 14.1 Features

The internal flash memory of the  $\mu$ PD78F9500, 78F9501, 78F9502 has the following features.

- O Erase/write even without preparing a separate dedicated power supply
- O Capacity: 1/2/4 KB
  - Erase unit: 1 block (256 bytes)
  - Write unit: 1 block (at onboard/offboard programming time), 1 byte (at self programming time)
- O Rewriting method
  - Rewriting by communication with dedicated flash memory programmer (on-board/off-board programming)
  - Rewriting flash memory by user program (self programming)
- O Supports rewriting of the flash memory at onboard/offboard programming time through security functions
- O Supports security functions in block units at self programming time through protect bytes

# 14.2 Memory Configuration

The 1/2/4 KB internal flash memory area is divided into 4/8/16 blocks and can be programmed/erased in block units. All the blocks can also be erased at once, by using a dedicated flash memory programmer.



Figure 14-1. Flash Memory Mapping

#### 14.3 Functional Outline

The internal flash memory of the  $\mu$ PD78F9500, 78F9501, 78F9502 can be rewritten by using the rewrite function of the dedicated flash memory programmer, regardless of whether the  $\mu$ PD78F9500, 78F9501, 78F9502 have already been mounted on the target system or not (on-board/off-board programming).

The function for rewriting a program with the user program (self programming), which is ideal for an application when it is assumed that the program is changed after production/shipment of the target system, is provided.

Refer to Table 14-1 for the flash memory writing control function.

In addition, a security function that prohibits rewriting the user program written to the internal flash memory is also supported, so that the program cannot be changed by an unauthorized person.

Refer to 14.7.3 Security settings for details on the security function.

Table 14-1. Rewrite Method

| Rewrite Method        | Functional Outline                                                                                                                                                               | Operation Mode                |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--|
| On-board programming  | Flash memory can be rewritten after the device is mounted on the target system, by using a dedicated flash memory programmer.                                                    | Flash memory programming mode |  |
| Off-board programming | Flash memory can be rewritten before the device is mounted on the target system, by using a dedicated flash memory programmer and a dedicated program adapter board (FA series). |                               |  |
| Self programming      | Flash memory can be rewritten by executing a user program that has been written to the flash memory in advance by means of on-board/off-board programming.                       | Self programming mode         |  |

- Remarks 1. The FA series is a product of Naito Densei Machida Mfg. Co., Ltd.
  - 2. Refer to the following sections for details on the flash memory writing control function.
    - •14.7 On-Board and Off-Board Flash Memory Programming
    - •14.8 Flash Memory Programming by Self Programming

# 14.4 Writing with Flash Memory Programmer

The following two types of dedicated flash memory programmers can be used for writing data to the internal flash memory of the  $\mu$ PD78F9500, 78F9501, 78F9502.

- FlashPro4 (PG-FP4, FL-PR4)
- <R> FlashPro5 (PG-FP5, FL-PR5)

Data can be written to the flash memory on-board or off-board, by using a dedicated flash memory programmer.

# (1) On-board programming

The contents of the flash memory can be rewritten after the  $\mu$ PD78F9500, 78F9501, 78F9502 have been mounted on the target system. The connectors that connect the dedicated flash memory programmer must be mounted on the target system.

### (2) Off-board programming

Data can be written to the flash memory with a dedicated program adapter (FA series) before the  $\mu$ PD78F9500, 78F9501, 78F9502 are mounted on the target system.

<R> Remark The FL-PR4, FL-PR5 and FA series are products of Naito Densei Machida Mfg. Co., Ltd.

# 14.5 Programming Environment

<R>

The environment required for writing a program to the flash memory is illustrated below.

### Figure 14-2. Environment for Writing Program to Flash Memory (FlashPro4/FlashPro5/QB-MINI2)



<R> Note When using FlashPro5 and QB-MINI2, the signals do not have to be connected.

A host machine that controls the dedicated flash memory programmer is necessary. When using the PG-FP4, FL-PR4, PG-FP5, or FL-PR5, data can be written with just the dedicated flash memory programmer after downloading the program from the host machine.

UART is used for manipulation such as writing and erasing when interfacing between the dedicated flash memory programmer and the  $\mu$ PD78F9500, 78F9501, 78F9502. To write the flash memory off-board, a dedicated program adapter (FA series) is necessary.

Download the latest programmer firmware, GUI, and parameter file from the download site for development tools (http://www.necel.com/micro/ods/eng/index.html).

Table 14-2. Wiring Between  $\mu$ PD78F9500, 78F9501, 78F9502 and FlashPro4/FlashPro5/QB-MINI2

| F                            | FlashPro4/Flas                                    | hPro5/QB-MINI2 Connection Pin                      | μPD78F9500, 78F9501, 78F9502<br>Connection Pin |         |  |
|------------------------------|---------------------------------------------------|----------------------------------------------------|------------------------------------------------|---------|--|
| Pin Name                     | in Name I/O Pin Function                          |                                                    | Pin Name                                       | Pin No. |  |
| CLK <sup>Note 1</sup>        | Output                                            | Clock to μPD78F9500, 78F9501, 78F9502              | EXCLK/P23                                      | 5       |  |
| FLMD0 <sup>Notes 1, 2</sup>  | Output                                            | On-board mode signal                               |                                                |         |  |
| SI/RxD <sup>Notes 1, 2</sup> | SI/RxD <sup>Notes 1, 2</sup> Input Receive signal |                                                    | P22                                            | 6       |  |
| SO/TxD <sup>Note 1</sup>     | Output                                            | Receive signal/on-board mode signal                |                                                |         |  |
| /RESET                       | Output                                            | Reset signal                                       | RESET/P34                                      | 7       |  |
| V <sub>DD</sub>              | _                                                 | V <sub>DD</sub> voltage generation/voltage monitor | V <sub>DD</sub>                                | 4       |  |
| GND                          | -                                                 | Ground                                             | Vss                                            | 3       |  |

- **Notes 1.** In the μPD78F9500, 78F9501, 78F9502, the CLK and FLMD0 signals are connected to the EXCLK pin; therefore, these signals need to be directly connected.
  - 2. When using FlashPro5 and QB-MINI2, the signals do not have to be connected.

Figure 14-3. Wiring diagram with FlashPro4/FlashPro5/QB-MINI2



Note When using FlashPro5 and QB-MINI2, the signals do not have to be connected.

# 14.6 Processing of Pins on Board

To write the flash memory on-board, connectors that connect the dedicated flash memory programmer must be provided on the target system. First provide a function that selects the normal operation mode or flash memory programming mode on the board.

When the flash memory programming mode is set, all the pins not used for programming the flash memory are in the same status as immediately after reset. Therefore, if the external device does not recognize the state immediately after reset, the pins must be processed as described below.

The state of the pins in the self programming mode is the same as that in the HALT mode.

### 14.6.1 EXCLK pin

The EXCLK pin is used as the serial interface of flash memory programming. Therefore, if the EXCLK pin is connected to an external device, a signal conflict occurs. To prevent the conflict of signals, isolate the connection with the external device.

When connected a capacitor to the EXCLK pin, waveform at the time of communication is changed. Therefore there is a possibility that cannot communicate depending on capacitor capacitance. When perform flash memory programming, isolate connection with a condenser.

<R>

<R>

<R>

# 14.6.2 RESET pin

If the reset signal of the dedicated flash memory programmer is connected to the RESET pin that is connected to the reset signal generator on the board, signal collision takes place. To prevent this collision, isolate the connection with the reset signal generator.

If the reset signal is input from the user system while the flash memory programming mode is set, the flash memory will not be correctly programmed. Do not input any signal other than the reset signal of the dedicated flash memory programmer.

Figure 14-4. Signal Collision (RESET Pin)



In the flash memory programming mode, the signal output by the reset signal generator collides with the signal output by the dedicated flash programmer. Therefore, isolate the signal of the reset signal generator.

#### 14.6.3 Port pins

When the flash memory programming mode is set, all the pins not used for flash memory programming enter the same status as that immediately after reset. If external devices connected to the ports do not recognize the port status immediately after reset, the port pin must be connected to VDD or Vss via a resistor.

The state of the pins in the self programming mode is the same as that in the HALT mode.

### 14.6.4 Power supply

Connect the  $V_{\text{DD}}$  pin to  $V_{\text{DD}}$  of the flash memory programmer, and the  $V_{\text{SS}}$  pin to  $V_{\text{SS}}$  of the flash memory programmer.

# 14.7 On-Board and Off-Board Flash Memory Programming

### 14.7.1 Flash memory programming mode

To rewrite the contents of the flash memory by using the dedicated flash memory programmer, set the  $\mu$ PD78F9500, 78F9501, 78F9502 in the flash memory programming mode. When the  $\mu$ PD78F9500, 78F9501, 78F9502 are connected to the flash memory programmer and a communication command is transmitted to the microcontroller, the microcontroller is set in the flash memory programming mode.

Change the mode by using a jumper when writing the flash memory on-board.

#### 14.7.2 Communication commands

The dedicated flash memory programmer controls the  $\mu$ PD78F9500, 78F9501, 78F9502 by using commands. The signals sent from the flash memory programmer to the  $\mu$ PD78F9500, 78F9501, 78F9502 are called communication commands, and the commands sent from the  $\mu$ PD78F9500, 78F9501, 78F9502 to the dedicated flash memory programmer are called response.

<R>

Figure 14-5. Communication Commands



Communication commands are listed in the table below. All these communication commands are issued from the programmer and the  $\mu$ PD78F9500, 78F9501, 78F9502 perform processing corresponding to the respective communication commands.

Classification Communication Command Name **Function** Erase Batch erase (chip erase) command Erases the contents of the entire memory Block erase command Erases the contents of the memory of the specified block Write Write command Writes to the specified address range and executes a verify check of the contents. Checksum Checksum command Reads the checksum of the specified address range and compares with the written data. Blank check Blank check command Confirms the erasure status of the entire memory. Security Security set command Prohibits batch erase (chip erase) command, block erase command, and write command to prevent operation by third parties.

Table 14-3. Communication Commands

The  $\mu$ PD78F9500, 78F9501, 78F9502 return a response for the communication command issued by the dedicated flash memory programmer. The response names sent from the  $\mu$ PD78F9500, 78F9501, 78F9502 are listed below.

Table 14-4. Response Name

| Command Name | Function                           |  |  |
|--------------|------------------------------------|--|--|
| ACK          | Acknowledges command/data.         |  |  |
| NAK          | Acknowledges illegal command/data. |  |  |

## 14.7.3 Security settings

The operations shown below can be prohibited using the security setting command.

• Batch erase (chip erase) is prohibited

Execution of the block erase and batch erase (chip erase) commands for entire blocks in the flash memory is prohibited. Once execution of the batch erase (chip erase) command is prohibited, all the prohibition settings can no longer be cancelled.

Caution After the security setting of the batch erase is set, erasure cannot be performed for the device. In addition, even if a write command is executed, data different from that which has already been written to the flash memory cannot be written because the erase command is disabled.

### Block erase is prohibited

Execution of the block erase command in the flash memory is prohibited. This prohibition setting can be cancelled using the batch erase (chip erase) command.

### Write is prohibited

Execution of the write and block erase commands for entire blocks in the flash memory is prohibited. This prohibition setting can be cancelled using the batch erase (chip erase) command.

**Remark** The security setting is valid when the programming mode is set next time.

The batch erase (chip erase), block erase, and write commands are enabled by the default setting when the flash memory is shipped. The above security settings are possible only for on-board/off-board programming. Each security setting can be used in combination.

Table 14-5 shows the relationship between the erase and write commands when the  $\mu$ PD78F9500, 78F9501, 78F9502 security function is enabled.

Table 14-5. Relationship Between Commands When Security Function Is Enabled

| Command                                                     | Batch Erase (Chip<br>Erase) Command | Block Erase<br>Command | Write Command           |
|-------------------------------------------------------------|-------------------------------------|------------------------|-------------------------|
| When batch erase (chip erase) security operation is enabled | Disabled                            | Disabled               | Enabled <sup>Note</sup> |
| When block erase security operation is enabled              | Enabled                             |                        | Enabled                 |
| When write security operation is enabled                    |                                     |                        | Disabled                |

**Note** Since the erase command is disabled, data different from that which has already been written to the flash memory cannot be written.

Table 14-6 shows the relationship between the security setting and the operation in each programming mode.

Table 14-6. Relationship Between Security Setting and Operation In Each Programming Mode

| Programming Mode         | On-Board/Off-Bo  | ard Programming         | Self Programming |                           |  |
|--------------------------|------------------|-------------------------|------------------|---------------------------|--|
| Security Setting         | Security Setting | Security Operation      | Security Setting | Security Operation        |  |
| Batch erase (chip erase) | Possible         | Valid <sup>Note 1</sup> | Impossible       | Invalid <sup>Note 2</sup> |  |
| Block erase              |                  |                         |                  |                           |  |
| Write                    |                  |                         |                  |                           |  |

Notes 1. Execution of each command is prohibited by the security setting.

2. Execution of self programming command is possible regardless of the security setting.

## 14.8 Flash Memory Programming by Self Programming

The  $\mu$ PD78F9500, 78F9501, 78F9502 support a self programming function that can be used to rewrite the flash memory via a user program, making it possible to upgrade programs in the field.

Caution Self programming processing must be included in the program before performing self programming.

Remarks 1. For usages of self programming, refer to use example mentioned in after 14.8.4.

**2.** To use the internal flash memory of the  $\mu$ PD78F9500, 78F9501, 78F9502 as the external EEPROM for storing data, refer to **78K0S/Kx1+ EEPROM Emulation Application Note (U17379E)**.

### 14.8.1 Outline of self programming

To execute self programming, shift the mode from the normal operation of the user program (normal mode) to the self programming mode. Write/erase processing for the flash memory, which has been set to the register in advance, is performed by executing the HALT instruction during self programming mode. The HALT state is automatically released when processing is completed.

To shift to the self programming mode, execute a specific sequence for a specific register. Refer to 14.8.4 Example of shifting normal mode to self programming mode for details.

**Remark** Data written by self programming can be referenced with the MOV instruction.

Table 14-7. Self Programming Mode

| Mode                  | User Program Execution  | Execution of Write/erase for Flash<br>Memory with HALT Instruction |
|-----------------------|-------------------------|--------------------------------------------------------------------|
| Normal mode           | Enabled                 | _                                                                  |
| Self programming mode | Enabled <sup>Note</sup> | Enabled                                                            |

**Note** Maskable interrupt servicing is disabled during self programming mode.

Figure 14-6 shows a block diagram for self programming, Figure 14-7 shows the self programming state transition diagram, Table 14-8 lists the commands for controlling self programming.



Figure 14-6. Block Diagram of Self Programming

User's Manual U18681EJ2V0UD



Figure 14-7. Self Programming State Transition Diagram

**Table 14-8. Self Programming Controlling Commands** 

| Command Name       | Function                                                                                                                                                     | Time Taken from HALT Instruction Execution to Command Execution End         |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Internal verify 1  | This command is used to check if data has been correctly written to the flash memory. It is used to check whether data has been written to an entire block.  | Internal verify for 1 block (internal verify command executed once): 6.8 ms |
| Internal verify 2  | This command is used to check if data has been correctly written to the flash memory. It is used to check whether data has been written in the same block.   | Internal verify for 1 byte: 27 $\mu$ s                                      |
| Block erasure Note | This command is used to erase a specified block. Specify the block number before execution.                                                                  | 8.5 ms                                                                      |
| Block blank check  | This command is used to check if data in a specified block has been erased. Specify the block number, then execute this command.                             | 480 μs                                                                      |
| Byte write         | This command is used to write 1-byte data to the specified address in the flash memory. Specify the write address and write data, then execute this command. | 150 <i>μ</i> s                                                              |

<R> Note Set the number of retrials larger than the block erasure time divided by the time (8.5 ms) for one erase, in accordance with the time (MAX. value) required for flash memory block erasures.

**Remark** The command internal verify 1 can be executed by specifying an address in the same block but internal verify 2 is recommended if data is written to two or more addresses in the same block.

### 14.8.2 Cautions on self programming function

- No instructions can be executed while a self programming command is being executed. Therefore, clear and restart the watchdog timer counter in advance so that the watchdog timer does not overflow during self programming. Refer to Table 14-8 for the time taken for the execution of self programming.
- Interrupts that occur during self programming can be acknowledged after self programming mode ends. To avoid this operation, disable interrupt servicing (by setting MK0 to FFH, and executing the DI instruction) before a mode is shifted from the normal mode to the self programming mode with a specific sequence.
- RAM is not used while a self programming command is being executed.
- If the supply voltage drops or the reset signal is input while the flash memory is being written or erased, writing/erasing is not guaranteed.
- The value of the blank data set during block erasure is FFH.
- Set the CPU clock so that it is 1 MHz or more during self programming.
- Execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, then execute self programming. At this time, the HALT instruction is automatically released after 10 μs (MAX.) + 2 CPU clocks (fcpu).
- If the clock of the oscillator or an external clock is selected as the system clock, execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, wait for 8 μs after releasing the HALT status, and then execute self programming.
- Check FPRERR using a 1-bit memory manipulation instruction.
- The state of the pins in self programming mode is the same as that in HALT mode.
- Since the security function set via on-board/off-board programming is disabled in self programming mode, the self programming command can be executed regardless of the security function setting. To disable write or erase processing during self programming, set the protect byte.
- Be sure to clear bits 4 to 7 of flash address pointer H (FLAPH) and flash address pointer H compare register (FLAPHC) to 0 before executing the self programming command. If the value of these bits is 1 when executing the self programming command, there is a possibility that device does not operate normally.
- Clear the value of the FLCMD register to 00H immediately before setting self-programming mode and normal operation mode.

### 14.8.3 Registers used for self-programming function

The following registers are used for the self-programming function.

- Flash programming mode control register (FLPMC)
- Flash protect command register (PFCMD)
- Flash status register (PFS)
- Flash programming command register (FLCMD)
- Flash address pointers H and L (FLAPH and FLAPL)
- Flash address pointer H compare register and flash address pointer L compare register (FLAPHC and FLAPLC)
- Flash write buffer register (FLW)

The µPD78F9500, 78F9501, 78F9502 have an area called a protect byte at address 0081H of the flash memory.

## (1) Flash programming mode control register (FLPMC)

This register is used to set the operation mode when data is written to the flash memory in the self-programming mode, and to read the set value of the protect byte.

Data can be written to FLPMC only in a specific sequence (refer to 14.8.3 (2) Flash protect command register (PFCMD)) so that the application system does not stop by accident because of malfunction due to noise or program hand-up.

This register is set with an 8-bit memory manipulation instruction.

Reset signal generation makes the contents of this register undefined.

Figure 14-8. Format of Flash Programming Mode Control Register (FLPMC)

| Address: F | FA2H A | After reset: \ | Indefined <sup>Note 1</sup> R/W <sup>Note 2</sup> |         | te 2    |         |   |       |
|------------|--------|----------------|---------------------------------------------------|---------|---------|---------|---|-------|
| Symbol     | 7      | 6              | 5                                                 | 4       | 3       | 2       | 1 | 0     |
| FLPMC      | 0      | PRSELF4        | PRSELF3                                           | PRSELF2 | PRSELF1 | PRSELF0 | 0 | FLSPM |

| FLSPM | Selection of operation mode during self-programming mode                                                                                                                                                                                                   |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | Normal mode  This is the normal operation status. Executing the HALT instruction sets standby status.                                                                                                                                                      |  |  |  |  |  |
| 1     | Self-programming mode Self programming commands can be executed by executing the specific sequence to change modes while in normal mode. Set a command, an address, and data to be written, then execute the HALT instruction to execute self programming. |  |  |  |  |  |

| PRSELF4 | PRSELF3 | PRSELF2 | PRSELF1 | PRSELF0 | The set value of the protect byte |
|---------|---------|---------|---------|---------|-----------------------------------|
|         |         |         |         |         | is read to these bits.            |

**Notes 1.** Bit 0 (FLSPM) is cleared to 0 when reset is released. The set value of the protect byte is read to bits 2 to 6 (PRSELF0 to PRSELF4) after reset is released.

2. Bits 2 to 6 (PRSELF0 to PRSELF4) are read-only.

# Cautions 1. Cautions in the case of setting the self programming mode, refer to 14.8.2 Cautions on self programming function.

- 2. Set the CPU clock so that it is 1 MHz or more during self programming.
- 3. Execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, then execute self programming. At this time, the HALT instruction is automatically released after 10  $\mu$ s (MAX.) + 2 CPU clocks (fcpu).
- 4. If the clock of the oscillator or an external clock is selected as the system clock, execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, wait for 8  $\mu$ s after releasing the HALT status, and then execute self programming.
- 5. Clear the value of the FLCMD register to 00H immediately before setting selfprogramming mode and normal operation mode.

## (2) Flash protect command register (PFCMD)

If the application system stops inadvertently due to malfunction caused by noise or program hang-up, an operation to write the flash programming mode control register (FLPMC) may have a serious effect on the system. PFCMD is used to protect FLPMC from being written, so that the application system does not stop inadvertently.

Writing FLPMC is enabled only when a write operation is performed in the following specific sequence.

- <1> Write a specific value to PFCMD (A5H)
- <2> Write the value to be set to bit 0 (FLSPM) of the FLPMC (writing in this step is invalid)
- <3> Write the inverted value of the value to be set to bit 0 (FLSPM) of the FLPMC (writing in this step is invalid)
- <4> Write the value to be set to bit 0 (FLSPM) of the FLPMC (writing in this step is valid)

Caution Interrupt servicing cannot be executed in self-programming mode. Disable interrupt servicing (by executing the DI instruction while MK0 = FFH) before executing the specific sequence that sets self-programming mode and after executing the specific sequence that changes the mode to the normal mode.

This rewrites the value of the register, so that the register cannot be written illegally.

Occurrence of an illegal store operation can be checked by bit 0 (FPRERR) of the flash status register (PFS). Check FPRERR using a 1-bit memory manipulation instruction.

A5H must be written to PFCMD each time the value of FLPMC is changed.

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

Reset signal generation makes PFCMD undefined.

Figure 14-9. Format of Flash Protect Command Register (PFCMD)

| Address: F | FA0H A | After reset: \ | r reset: Undefined |      |      |      |      |      |
|------------|--------|----------------|--------------------|------|------|------|------|------|
| Symbol     | 7      | 6              | 5                  | 4    | 3    | 2    | 1    | 0    |
| PFCMD      | REG7   | REG6           | REG5               | REG4 | REG3 | REG2 | REG1 | REG0 |

### (3) Flash status register (PFS)

If data is not written to the flash programming mode control register (FLPMC), which is protected, in the correct sequence (writing the flash protect command register (PFCMD)), FLPMC is not written and a protection error occurs. If this happens, bit 0 of PFS (FPRERR) is set to 1.

When FPRERR is 1, it can be cleared to 0 by writing 0 to it.

Errors that may occur during self-programming are reflected in bit 1 (VCERR) and bit 2 (WEPRERR) of PFS. VCERR or WEPRERR can be cleared by writing 0 to them.

All the flags of the PFS register must be pre-cleared to 0 to check if the operation is performed correctly.

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

Reset signal generation clears PFS to 00H.

Caution Check FPRERR using a 1-bit memory manipulation instruction.

Figure 14-10. Format of Flash Status Register (PFS)

| Address: FFA1H |   | After reset: ( | 0H R/W |   |   |         |       |        |
|----------------|---|----------------|--------|---|---|---------|-------|--------|
| Symbol         | 7 | 6              | 5      | 4 | 3 | 2       | 1     | 0      |
| PFS            | 0 | 0              | 0      | 0 | 0 | WEPRERR | VCERR | FPRERR |

## 1. Operating conditions of FPRERR flag

### <Setting conditions>

- If PFCMD is written when the store instruction operation recently performed on a peripheral register is not to write a specific value (A5H) to FLPMC
- If the first store instruction operation after <1> is on a peripheral register other than FLPMC
- If the first store instruction operation after <2> is on a peripheral register other than FLPMC
- If a value other than the inverted value of the value to be set to FLPMC is written by the first store instruction after <2>
- If the first store instruction operation after <3> is on a peripheral register other than FLPMC
- If a value other than the value to be set to FLPMC (value written in <2>) is written by the first store instruction after <3>

Remark The numbers in angle brackets above correspond to those in (2) Flash protect command register (PFCMD).

#### <Reset conditions>

- If 0 is written to the FPRERR flag
- · If the reset signal is generation

## 2. Operating conditions of VCERR flag

## <Setting conditions>

- Erasure verification error
- Internal writing verification error

If VCERR is set, it means that the flash memory has not been erased or written correctly. Erase or write the memory again in the specified procedure.

Remark The VCERR flag may also be set if an erase or write protect error occurs.

### <Reset conditions>

- When 0 is written to the VCERR flag
- · When the reset signal generation

## 3. Operating conditions of WEPRERR flag

### <Setting conditions>

- If the area specified by the protect byte to be protected from erasing or writing is specified by the flash address pointer H (FLAPH) and a command is executed to this area
- If 1 is written to a bit that has not been erased (a bit for which the data is 0).

### <Reset conditions>

- · When 0 is written to the WEPRERR flag
- When the reset signal generation

# (4) Flash programming command register (FLCMD)

This register is used to specify whether the flash memory is erased, written, or verified in the self-programming mode.

This register is set by using a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

Figure 14-11. Format of Flash Programming Command Register (FLCMD)

| Address: F | FA3H A | After reset: ( | 00H R/V | V |   |        |        |        |
|------------|--------|----------------|---------|---|---|--------|--------|--------|
| Symbol     | 7      | 6              | 5       | 4 | 3 | 2      | 1      | 0      |
| FLCMD      | 0      | 0              | 0       | 0 | 0 | FLCMD2 | FLCMD1 | FLCMD0 |

| FLCMD2 | FLCMD1       | FLCMD0             | Command Name       | Function                                                                                                                                                                                                                                                                                                            |
|--------|--------------|--------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0            | 1                  | Internal verify 1  | This command is used to check if data has been correctly written to the flash memory. It is used to check whether data has been written to an entire block. If an error occurs, bit 1 (VCERR) or bit 2 (WEPRERR) of the flash status register (PFS) is set to 1.                                                    |
| 0      | 1            | 0                  | Internal verify 2  | This command is used to check if data has been correctly written to the flash memory. It is used to check whether data has been written in the same block. If an error occurs, bit 1 (VCERR) or bit 2 (WEPRERR) of the flash status register (PFS) is set to 1.                                                     |
| 0      | 1            | 1                  | Block erase        | This command is used to erase specified block. It is used both in the on-board mode and self-programming mode.                                                                                                                                                                                                      |
| 1      | 0            | 0                  | Block blank check  | This command is used to check if the specified block has been erased.                                                                                                                                                                                                                                               |
| 1      | 0            | 1                  | Byte write         | This command is used to write 1-byte data to the specified address in the flash memory. Specify the write address and write data, then execute this command.  If 1 is written to a bit that has not been erased (a bit for which the data is 0), then bit 2 (WEPRERR) of the flash status register (PFS) becomes 1. |
| Oth    | er than abov | re <sup>Note</sup> | Setting prohibited | 1                                                                                                                                                                                                                                                                                                                   |

**Note** If any command other than those above is executed, command execution may immediately be terminated, and bit 1 or 2 (WEPRERR or VCERR) of the flash status register (PFS) may be set to 1.

# (5) Flash address pointers H and L (FLAPH and FLAPL)

These registers are used to specify the start address of the flash memory when the memory is erased, written, or verified in the self-programming mode.

FLAPH and FLAPL consist of counters, and they are incremented until the values match with those of FLAPHC and FLAPLC when the programming command is not executed. When the programming command is executed, therefore, set the value again.

These registers are set with a 1-bit or 8-bit memory manipulation instruction.

After reset: 00H

Reset signal generation makes these registers undefined.

Address: FFA4H, FFA5H

Figure 14-12. Format of Flash Address Pointer H/L (FLAPH/FLAPL)

R/W

FLAPH (FFA5H) FLAPL (FFA4H) FLA FLA 0 0 0 0 FLA P11 P10 P9 P8 P7 P6 P5 P4 Р3 P2 P1 P0

Caution Be sure to clear bits 4 to 7 of FLAPH and FLAPHC to 0 before executing the self programming command. If the self programming command is executed with these bits set to 1, the device may malfunction.

# (6) Flash address pointer H compare register and flash address pointer L compare register (FLAPHC and FLAPLC)

These registers are used to specify the address range in which the internal sequencer operates when the flash memory is verified in the self-programming mode.

Set FLAPHC to the same value as that of FLAPH. Set the last address of the range in which verification is to be executed to FLAPLC.

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

After reset: 00H

Reset signal generation clears these registers to 00H.

Address: FFA6H, FFA7H

Figure 14-13. Format of Flash Address Pointer H/L Compare Registers (FLAPHC/FLAPLC)

R/W

FLAPHC (FFA6H) FLAPLC (FFA7H) FLAP FLAP FLAP 0 0 0 **FLAP** FLAP **FLAP FLAP** FLAP FLAP **FLAP FLAP FLAP** C11 C10 C9 C8 C7 C6 C5 СЗ C2 C1 C4 C0

- Cautions 1. Be sure to clear bits 4 to 7 of FLAPH and FLAPHC to 0 before executing the self programming command. If the self programming command is executed with these bits set to 1, the device may malfunction.
  - 2. Set the number of the block subject to a block erase, verify, or blank check (same value as FLAPH) to FLAPHC.
  - 3. Clear FLAPLC to 00H when a block erase is performed, and set this register to FFH when a blank check is performed.

# (7) Flash write buffer register (FLW)

This register is used to store the data to be written to the flash memory.

This register is set with an 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.

Figure 14-14. Format of Flash Write Buffer Register (FLW)

| Address: F | FA8H A | After reset: 0 | 00H R/V | <b>/</b> |      |      |      |      |
|------------|--------|----------------|---------|----------|------|------|------|------|
| Symbol     | 7      | 6              | 5       | 4        | 3    | 2    | 1    | 0    |
| FLW        | FLW7   | FLW6           | FLW5    | FLW4     | FLW3 | FLW2 | FLW1 | FLW0 |

## (8) Protect byte

This protect byte is used to specify the area that is to be protected from writing or erasing. The specified area is valid only in the self-programming mode. Because self-programming of the protected area is invalid, the data written to the protected area is guaranteed.

Figure 14-15. Format of Protect Byte (1/2)

Address: 0081H

7 6 5 4 3 2 1 0

1 PRSELF4 PRSELF3 PRSELF2 PRSELF1 PRSELF0 1 1

## • μ PD78F9500

| PRSELF4 | PRSELF3 | PRSELF2         | PRSELF1            | PRSELF0 | Status                                   |
|---------|---------|-----------------|--------------------|---------|------------------------------------------|
| 0       | 1       | 1               | 1                  | 0       | Blocks 3 to 0 are protected.             |
| 0       | 1       | 1               | 1                  | 1       | Blocks 1 and 0 are protected.            |
| U       |         |                 |                    |         | Blocks 2 and 3 can be written or erased. |
| 1       | 1       | 1               | 1                  | 1       | All blocks can be written or erased.     |
|         | C       | Other than abov | Setting prohibited |         |                                          |

### • μ PD78F9501

| PRSELF4 | PRSELF3 | PRSELF2         | PRSELF1            | PRSELF0 | Status                                   |
|---------|---------|-----------------|--------------------|---------|------------------------------------------|
| 0       | 1       | 1               | 0                  | 0       | Blocks 7 to 0 are protected.             |
| 0       | 1       | 1               | 0                  | 1       | Blocks 5 to 0 are protected.             |
| U       |         |                 |                    |         | Blocks 6 and 7 can be written or erased. |
| 0       | 1       | 1               | 1                  | 0       | Blocks 3 to 0 are protected.             |
| 0       |         |                 |                    |         | Blocks 4 to 7 can be written or erased.  |
| 0       | 1 1     | 1               | 1                  | 1       | Blocks 1 and 0 are protected.            |
| 0       |         | ı               |                    |         | Blocks 2 to 7 can be written or erased.  |
| 1       | 1       | 1               | 1                  | 1       | All blocks can be written or erased.     |
|         | C       | Other than abov | Setting prohibited |         |                                          |

Figure 14-15. Format of Protect Byte (2/2)

## • μ PD78F9502

| PRSELF4 | PRSELF3 | PRSELF2         | PRSELF1            | PRSELF0 | Status                                     |
|---------|---------|-----------------|--------------------|---------|--------------------------------------------|
| 0       | 1       | 0               | 0                  | 0       | Blocks 15 to 0 are protected.              |
| 0       | 1       | 0               | 0                  | 1       | Blocks 13 to 0 are protected.              |
| U       |         | 0               |                    |         | Blocks 14 and 15 can be written or erased. |
| 0       |         | 0               | 1                  | 0       | Blocks 11 to 0 are protected.              |
| U       | I       |                 |                    |         | Blocks 12 to 15 can be written or erased.  |
| 0       | 1       | 0               | 1                  | 1       | Blocks 9 to 0 are protected.               |
| U       |         |                 |                    |         | Blocks 10 to 15 can be written or erased.  |
| 0       | 1       | 1               | 0                  | 0       | Blocks 7 to 0 are protected.               |
| U       |         |                 |                    |         | Blocks 8 to 15 can be written or erased.   |
| 0       | 1       | 1               | 0                  | 1       | Blocks 5 to 0 are protected.               |
|         |         |                 |                    |         | Blocks 6 to 15 can be written or erased.   |
| 0       | 1       | 1 1             | 1                  | 0       | Blocks 3 to 0 are protected.               |
| U       |         |                 |                    |         | Blocks 4 to 15 can be written or erased.   |
| 0       | 1       | 1 1             | 1                  | 1       | Blocks 1 and 0 are protected.              |
| U       |         |                 |                    |         | Blocks 2 to 15 can be written or erased.   |
| 1       | 1       | 1               | 1                  | 1       | All blocks can be written or erased.       |
|         | C       | Other than abov | Setting prohibited |         |                                            |

## 14.8.4 Example of shifting normal mode to self programming mode

The operating mode must be shifted from normal mode to self programming mode before performing self programming.

An example of shifting to self programming mode is explained below.

- <1> Disable interrupts if the interrupt function is used (by setting the interrupt mask flag registers (MK0) to FFH and executing the DI instruction).
- <2> Clear FLCMD (FLCMD=00H).
- <3> Clear the flash status register (PFS).
- <4> Set self programming mode using a specific sequence. Note
  - Write a specific value (A5H) to PFCMD.
  - Write 01H to FLPMC (writing in this step is invalid).
  - Write 0FEH (inverted value of 01H) to FLPMC (writing in this step is invalid).
  - Write 01H to FLPMC (writing in this step is valid).
- <5> Execute NOP instruction and HALT instruction.
- <6> Check the execution result of the specific sequence using bit 0 (FPRERR) of PFS. Abnormal  $\rightarrow$  <3>, normal  $\rightarrow$  <7>
- <7> Mode shift is completed.

Note Set the CPU clock so that it is 1 MHz or more during self programming.

Caution Be sure to perform the series of operations described above using the user program at an address where data is not erased or written.



Figure 14-16. Example of Shifting to Self Programming Mode

Caution Be sure to perform the series of operations described above using the user program at an address where data is not erased or written.

Remark <1> to <7> in Figure 14-16 correspond to <1> to <7> in 14.8.4 (previous page).

An example of the program that shifts the mode to self programming mode is shown below.

| START  |        |                 |                                                         |
|--------|--------|-----------------|---------------------------------------------------------|
| ,      | MOV    | MK0,#1111111B   | ; Masks all interrupts                                  |
|        | MOV    | FLCMD,#00H      | ; Clear FLCMD register                                  |
|        | DI     |                 |                                                         |
| Iode0n | Loop:  |                 | ; Configure settings so that the CPU clock $\geq$ 1 MHz |
|        | MOV    | PFS,#00H        | ; Clears flash status register                          |
|        | MOV    | PFCMD,#0A5H     | ; PFCMD register control                                |
|        | MOV    | FLPMC,#01H      | ; FLPMC register control (sets value)                   |
|        | MOV    | FLPMC, #0FEH    | ; FLPMC register control (inverts set value)            |
|        | MOV    | FLPMC, #01H     | ; Sets self programming mode with FLPMC register        |
|        |        |                 | ; control (sets value)                                  |
|        | NOP    |                 |                                                         |
|        | HALT   |                 |                                                         |
|        | BT PFS | .0,\$ModeOnLoop | ; Checks completion of write to specific registers      |
|        |        |                 | ; Repeats the same processing when an error occurs      |
|        |        |                 |                                                         |
| END    |        |                 |                                                         |

## 14.8.5 Example of shifting self programming mode to normal mode

The operating mode must be returned from self programming mode to normal mode after performing self programming.

An example of shifting to normal mode is explained below.

- <1> Clear FLCMD (FLCMD=00H).
- <2> Clear the flash status register (PFS).
- <3> Set normal mode using a specific sequence.
  - Write the specific value (A5H) to PFCMD.
  - Write 00H to FLPMC (writing in this step is invalid)
  - Write 0FFH (inverted value of 00H) to FLPMC (writing in this step is invalid)
  - Write 00H to FLPMC (writing in this step is valid)
- <4> Check the execution result of the specific sequence using bit 0 (FPRERR) of PFS.
  - Abnormal  $\rightarrow$  <2>, normal  $\rightarrow$  <5>
- <5> Enable interrupt servicing (by executing the El instruction and changing MK0) to restore the original state.
- <6> Mode shift is completed

**Note** After the specific sequence is correctly executed, restore the CPU clock to its setting before the self programming.

Caution Be sure to perform the series of operations described above using the user program at an address where data is not erased or written.



Figure 14-17. Example of Shifting to Normal Mode

Caution Be sure to perform the series of operations described above using the user program at an address where data is not erased or written.

Remark <1> to <6> in Figure 14-17 correspond to <1> to <6> in 14.8.5 (previous page).

An example of a program that shifts the mode to normal mode is shown below.

;-----;START ;-----MOV FLCMD,#00H ; Clear FLCMD register ModeOffLoop: MOV PFS,#00H ; Clears flash status register MOV PFCMD,#0A5H ; PFCMD register control MOV FLPMC, #00H ; FLPMC register control (sets value) FLPMC, #0FFH MOV ; FLPMC register control (inverts set value) FLPMC, #00H ; Sets normal mode via FLPMC register control (sets value) MOV BT PFS.0, \$ModeOffLoop ; Checks completion of write to specific registers ; Repeats the same processing when an error occurs ; Restore the CPU clock to its setting before the self ; programming MK0,#INT\_MK0 MOV ; Restores interrupt mask flag ΕI ;-----; END ;-----

## 14.8.6 Example of block erase operation in self programming mode

An example of the block erase operation in self programming mode is explained below.

- <1> Set 03H (block erase) to the flash program command register (FLCMD).
- <2> Set the block number to be erased, to flash address pointer H (FLAPH).
- <3> Set flash address pointer L (FLAPL) to 00H.
- <4> Write the same value as FLAPH to the flash address pointer H compare register (FLAPHC).
- <5> Set the flash address pointer L compare register (FLAPLC) to 00H.
- <6> Clear the flash status register (PFS).
- <7> Write ACH to the watchdog timer enable register (WDTE) (clear and restart the watchdog timer counter) Note.
- <8> Execute the HALT instruction then start self programming. (Execute an instruction immediately after the HALT instruction if self programming has been executed.)
- <9> Check if a self programming error has occurred using bit 1 (VCERR) and bit 2 (WEPRERR) of PFS.
  - Abnormal  $\rightarrow$  <10>
  - Normal  $\rightarrow$  <11>
- <10> Block erase processing is abnormally terminated.
- <11> Block erase processing is normally terminated.

Note This setting is not required when the watchdog timer is not used.



Figure 14-18. Example of Block Erase Operation in Self Programming Mode

**Note** This setting is not required when the watchdog timer is not used.

**Remark** <1> to <11> in Figure 14-18 correspond to <1> to <11> in **14.8.6** (previous page).

An example of a program that performs a block erase in self programming mode is shown below.

| ;START         |             |                                                                 |
|----------------|-------------|-----------------------------------------------------------------|
| ;              |             |                                                                 |
| FlashBlockEras | se:         |                                                                 |
| MOV            | FLCMD,#03H  | ; Sets flash control command (block erase)                      |
| MOV            | FLAPH,#07H  | ; Sets number of block to be erased (block 7 is specified here) |
| MOV            | FLAPL,#00H  | ; Fixes FLAPL to "00H"                                          |
| MOV            | FLAPHC,#07H | ; Sets erase block compare number (same value as that of FLAPH) |
| MOV            | FLAPLC,#00H | ; Fixes FLAPLC to "00H"                                         |
|                |             |                                                                 |
| MOV            | PFS,#00H    | ; Clears flash status register                                  |
| MOV            | WDTE,#0ACH  | ; Clears & restarts WDT                                         |
| HALT           |             | ; Self programming is started                                   |
| MOV            | A,PFS       |                                                                 |
| MOV            | CmdStatus,A | ; Execution result is stored in variable                        |
|                |             | ; (CmdStatus = 0: normal termination, other than 0: abnormal    |
|                |             | ; termination)                                                  |
|                |             |                                                                 |
| ;              |             |                                                                 |
| ; END          |             |                                                                 |
| ;              |             |                                                                 |

## 14.8.7 Example of block blank check operation in self programming mode

An example of the block blank check operation in self programming mode is explained below.

- <1> Set 04H (block blank check) to the flash program command register (FLCMD).
- <2> Set the number of block for which a blank check is performed, to flash address pointer H (FLAPH).
- <3> Set flash address pointer L (FLAPL) to 00H.
- <4> Write the same value as FLAPH to the flash address pointer H compare register (FLAPHC).
- <5> Set the flash address pointer L compare register (FLAPLC) to FFH.
- <6> Clear the flash status register (PFS).
- <7> Write ACH to the watchdog timer enable register (WDTE) (clear and restart the watchdog timer counter) Note.
- <8> Execute the HALT instruction then start self programming. (Execute an instruction immediately after the HALT instruction if self programming has been executed.)
- <9> Check if a self programming error has occurred using bit 1 (VCERR) and bit 2 (WEPRERR) of PFS.
  - Abnormal  $\rightarrow$  <10>
  - Normal  $\rightarrow$  <11>
- <10> Block blank check is abnormally terminated.
- <11> Block blank check is normally terminated.

**Note** This setting is not required when the watchdog timer is not used.

Block blank check <1> Set block blank check command (FLCMD = 04H) <2> Set no. of block for blank check to FLAPH <3> Set FLAPL to 00H <4> Set the same value as that of FLAPH to FLAPHC <5> Set FLAPLC to FFH <6> Clear PFS <7> Clear & restart WDT counter  $(WDTE = ACH)^{Note}$ <8> Execute HALT instruction <9> Check execution result Abnormal (VCERR and WEPRERR flags) Normal <10> Abnormal termination <11> Normal termination

Figure 14-19. Example of Block Blank Check Operation in Self Programming Mode

**Note** This setting is not required when the watchdog timer is not used.

Remark <1> to <11> in Figure 14-19 correspond to <1> to <11> in 14.8.7 (previous page).

An example of a program that performs a block blank check in self programming mode is shown below.

;-----;START ;-----FlashBlockBlankCheck: MOV FLCMD, #04H ; Sets flash control command (block blank check) FLAPH,#07H ; Sets number of block for blank check (block 7 is specified MOV ; here) MOV FLAPL, #00H ; Fixes FLAPL to "00H" MOV FLAPHC,#07H ; Sets blank check block compare number (same value as that of ; FLAPH) VOM FLAPLC, #0FFH ; Fixes FLAPLC to "FFH" VOM PFS,#00H ; Clears flash status register VOM WDTE, #0ACH ; Clears & restarts WDT HALT ; Self programming is started MOV A,PFS ; Execution result is stored in variable MOV CmdStatus, A ; (CmdStatus = 0: normal termination, other than 0: abnormal ; termination) ;-----; END ;-----

## 14.8.8 Example of byte write operation in self programming mode

An example of the byte write operation in self programming mode is explained below.

- <1> Set 05H (byte write) to the flash program command register (FLCMD).
- <2> Set the number of block to which data is to be written, to flash address pointer H (FLAPH).
- <3> Set the address at which data is to be written, to flash address pointer L (FLAPL).
- <4> Set the data to be written, to the flash write buffer register (FLW).
- <5> Clear the flash status register (PFS).
- <6> Write ACH to the watchdog timer enable register (WDTE) (clear and restart the watchdog timer counter) Note.
- <7> Execute the HALT instruction then start self programming. (Execute an instruction immediately after the HALT instruction if self programming has been executed.)
- <8> Check if a self programming error has occurred using bit 1 (VCERR) and bit 2 (WEPRERR) of PFS.
  - Abnormal  $\rightarrow$  <9>
  - Normal  $\rightarrow$  <10>
- <9> Byte write processing is abnormally terminated.
- <10> Byte write processing is normally terminated.

**Note** This setting is not required when the watchdog timer is not used.

Caution If a write results in failure, erase the block once and write to it again.



Figure 14-20. Example of Byte Write Operation in Self Programming Mode

**Note** This setting is not required when the watchdog timer is not used.

Remark <1> to <10> in Figure 14-20 correspond to <1> to <10> in 14.8.8 (previous page).

An example of a program that performs a byte write in self programming mode is shown below.

| ;           |             |                                                              |
|-------------|-------------|--------------------------------------------------------------|
| ;START      |             |                                                              |
| ;           |             |                                                              |
| FlashWrite: |             |                                                              |
| MOV         | FLCMD,#05H  | ; Sets flash control command (byte write)                    |
| MOV         | FLAPH,#07H  | ; Sets address to which data is to be written, with          |
|             |             | ; FLAPH (block 7 is specified here)                          |
| MOV         | FLAPL,#20H  | ; Sets address to which data is to be written, with          |
|             |             | ; FLAPL (address 20H is specified here)                      |
| MOV         | FLW,#10H    | ; Sets data to be written (10H is specified here)            |
|             |             |                                                              |
| MOV         | PFS,#00H    | ; Clears flash status register                               |
| MOV         | WDTE,#0ACH  | ; Clears & restarts WDT                                      |
| HALT        |             | ; Self programming is started                                |
| MOV         | A,PFS       |                                                              |
| MOV         | CmdStatus,A | ; Execution result is stored in variable                     |
|             |             | ; (CmdStatus = 0: normal termination, other than 0: abnormal |
|             |             | ; termination)                                               |
|             |             |                                                              |
| ;           |             |                                                              |
| ; END       |             |                                                              |
| ;           |             |                                                              |

## 14.8.9 Example of internal verify operation in self programming mode

An example of the internal verify operation in self programming mode is explained below.

### Internal verify 1

- <1> Set 01H (internal verify 1) to the flash program command register (FLCMD).
- <2> Set the number of block for which internal verify is performed, to flash address pointer H (FLAPH).
- <3> Sets the flash address pointer L (FLAPL) to 00H.
- <4> Write the same value as that of FLAPH to the flash address pointer H compare register (FLAPHC).
- <5> Sets the flash address pointer L compare register (FLAPLC) to FFH.
- <6> Clear the flash status register (PFS).
- <7> Write ACH to the watchdog timer enable register (WDTE) (clear and restart the watchdog timer counter)<sup>Note</sup>.
- <8> Execute the HALT instruction then start self programming. (Execute an instruction immediately after the HALT instruction if self programming has been executed.)
- <9> Check if a self programming error has occurred using bit 1 (VCERR) and bit 2 (WEPRERR) of PFS.

```
Abnormal \rightarrow <10> Normal \rightarrow <11>
```

- <10> Internal verify processing is abnormally terminated.
- <11> Internal verify processing is normally terminated.

### Internal verify 2

- <1> Set 02H (internal verify 2) to the flash program command register (FLCMD).
- <2> Set the number of block for which internal verify is performed, to flash address pointer H (FLAPH).
- <3> Sets flash address pointer L (FLAPL) to the start address.
- <4> Write the same value as that of FLAPH to the flash address pointer H compare register (FLAPHC).
- <5> Sets flash address pointer L compare register (FLAPLC) to the end address.
- <6> Clear the flash status register (PFS).
- <7> Write ACH to the watchdog timer enable register (WDTE) (clear and restart the watchdog timer counter)<sup>Note</sup>.
- <8> Execute the HALT instruction then start self programming. (Execute an instruction immediately after the HALT instruction if self programming has been executed.)
- <9> Check if a self programming error has occurred using bit 1 (VCERR) and bit 2 (WEPRERR) of PFS.

```
Abnormal \rightarrow <10> Normal \rightarrow <11>
```

<10> Internal verify processing is abnormally terminated.

<11> Internal verify processing is normally terminated.

Note This setting is not required when the watchdog timer is not used.



Figure 14-21. Example of Internal Verify Operation in Self Programming Mode

Note This setting is not required when the watchdog timer is not used.

Remark <1> to <11> in Figure 14-21 correspond to Internal verify 1 <1> to <11> in 14.8.9 (previous page).

Internal verify 2 <1> Set internal verify 2 command (FLCMD = 02H) <2> Set No. of block for internal verify, to FLAPH <3> Sets FLAPL to the start address <4> Set the same value as that of FLAPH to FLAPHC <5> Sets FLAPLC to the end address <6> Clear PFS <7> Clear & restart WDT counter (WDTE = ACH)<sup>Note</sup> <8> Execute HALT instruction <9> Check execution result Abnormal (VCERR and WEPRERR flags) Normal <11> Normal termination <10> Abnormal termination

Figure 14-22. Example of Internal Verify Operation in Self Programming Mode

Note This setting is not required when the watchdog timer is not used.

Remark <1> to <11> in Figure 14-22 correspond to Internal verify 2 <1> to <11> in 14.8.9 (the page before last).

An example of a program that performs an internal verify in self programming mode is shown below.

## • Internal verify 1

```
;-----
:START
;-----
FlashVerify:
      MOV
             FLCMD, #01H
                          ; Sets flash control command (internal verify 1)
      VOM
            FLAPH,#07H
                          ; Set the number of block for which internal verify is
                           ; performed, to FLAPH (Example: Block 7 is specified here)
      VOM
             FLAPL,#00H
                           ; Sets FLAPL to 00H
      MOV
              FLAPHC, #07H
      MOV
              FLAPLC, #FFH
                          ; Sets FLAPLC to FFH
              PFS,#00H
      MOV
                          ; Clears flash status register
              WDTE, #0ACH
      MOV
                           ; Clears & restarts WDT
      HALT
                           ; Self programming is started
      MOV
              A.PFS
      MOV
              CmdStatus, A
                           ; Execution result is stored in variable
                            ; (CmdStatus = 0: normal termination, other than 0: abnormal
                            ; termination)
; END
;-----
• Internal verify 2
;-----
:START
;-----
FlashVerify:
                          ; Sets flash control command (internal verify 2)
      MOV
            FLCMD, #02H
      MOV
             FLAPH,#07H
                           ; Set the number of block for which internal verify is
                           ; performed, to FLAPH (Example: Block 7 is specified here)
      MOV
             FLAPL,#00H
                           ; Sets FLAPL to the start address for verify (Example: Address
                           ; 00H is specified here)
      VOM
              FLAPHC, #07H
              FLAPLC, #20H
                           ; Sets FLAPLC to the end address for verify (Example: Address
      MOV
                            ; 20H is specified here)
              PFS,#00H
                           ; Clears flash status register
      MOV
      VOM
              WDTE, #0ACH
                           ; Clears & restarts WDT
      HALT
                            ; Self programming is started
      MOV
              A,PFS
      MOV
              CmdStatus, A
                           ; Execution result is stored in variable
                            ; (CmdStatus = 0: normal termination, other than 0: abnormal
                            ; termination)
;-----
; END
;-----
```

# 14.8.10 Examples of operation when command execution time should be minimized in self programming mode

Examples of operation when the command execution time should be minimized in self programming mode are explained below.

## (1) Erasure to blank check

- <1> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <2> Execution of block erase → Error check (<1> to <11> in 14.8.6)
- <3> Execution of block blank check → Error check (<1> to <11> in 14.8.7)
- <4> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)

Figure 14-23. Example of Operation When Command Execution Time Should Be Minimized (from Erasure to Blank Check)



Note Perform processing to shift to normal mode in order to return to normal processing.

**Remark** <1> to <4> in Figure 14-23 correspond to <1> to <4> in **14.8.10 (1)** above.

An example of a program when the command execution time (from erasure to black check) should be minimized in self programming mode is shown below.

```
;-----
:START
;-----
      MOV
               MKO, #11111111B ; Masks all interrupts
               FLCMD, #00H
      MOV
                            ; Clears FLCMD register
      DI
                               ; Configure settings so that the CPU clock \geq 1 MHz
ModeOnLoop:
                               ; Clears flash status register
      MOV
               PFS,#00H
      MOV
               PFCMD, #0A5H
                               ; PFCMD register control
      MOV
               FLPMC, #01H
                               ; FLPMC register control (sets value)
      MOV
               FLPMC, #0FEH
                               ; FLPMC register control (inverts set value)
      MOV
               FLPMC, #01H
                               ; Sets self programming mode with FLPMC register control (sets
                               ; value)
      NOP
      HALT
                               ; Checks completion of write to specific registers
      BT PFS.0, $ModeOnLoop
                               ; Repeats the same processing when an error occurs.
FlashBlockErase:
               FLCMD, #03H
      MOV
                               ; Sets flash control command (block erase)
                               ; Sets number of block to be erased (block 7 is specified
      VOM
               FLAPH,#07H
                               ; here)
      MOV
               FLAPL, #00H
                               ; Fixes FLAPL to "00H"
               FLAPHC, #07H
                               ; Sets erase block compare number (same value as that of
      MOV
                               ; FLAPH)
                               ; Fixes FLAPLC to "00H"
      MOV
               FLAPLC, #00H
      MOV
               WDTE, #0ACH
                               ; Clears & restarts WDT
      HALT
                               ; Self programming is started
      MOV
               A, PFS
               A,#00H
      CMP
      BNZ
               $StatusError
                               ; Checks erase error
                               ; Performs abnormal termination processing when an error
                               ; occurs.
FlashBlockBlankCheck:
      MOV
               FLCMD, #04H
                               ; Sets flash control command (block blank check)
      MOV
               FLAPH,#07H
                               ; Sets number of block for blank check (block 7 is specified
                               ; here)
      MOV
               FLAPL,#00H
                               ; Fixes FLAPL to "00H"
      MOV
               FLAPHC, #07H
                               ; Sets blank check block compare number (same value as of
                               ; FLAPH)
```

#### **CHAPTER 14 FLASH MEMORY**

```
MOV
             FLAPLC, #0FFH
                          ; Fixes FLAPLC to "FFH"
     MOV
             WDTE, #OACH
                          ; Clears & restarts WDT
     HALT
                           ; Self programming is started
     VOM
             A, PFS
     CMP
             A,#00H
     BNZ
             $StatusError
                          ; Checks blank check error
                           ; Performs abnormal termination processing when an error
                           ; occurs.
     MOV
             FLCMD, #00H
                           ; Clears FLCMD register
ModeOffLoop:
     MOV
             PFS,#00H
                          ; Clears flash status register
             PFCMD, #0A5H
                           ; PFCMD register control
     MOV
     MOV
             FLPMC, #00H
                          ; FLPMC register control (sets value)
     MOV
             FLPMC, #0FFH
                           ; FLPMC register control (inverts set value)
     MOV
             FLPMC, #00H
                           ; Sets normal mode via FLPMC register control (sets value)
     BT PFS.0, $ModeOffLoop
                          ; Checks completion of write to specific registers
                           ; Repeats the same processing when an error occurs.
                           ; After the specific sequence is correctly executed, restore
                           ; the CPU clock to its setting before the self programming
     MOV
             MK0, #INT_MK0
                          ; Restores interrupt mask flag
     ΕI
     BR
             StatusNormal
;-----
;END (abnormal termination processing); Perform processing to shift to
    normal mode in order to return to normal processing
;-----
StatusError:
;-----
;END (normal termination processing)
;-----
```

StatusNormal:

# (2) Write to internal verify

- <1> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <2> Specification of source data for write
- <3> Execution of byte write → Error check (<1> to <10> in 14.8.8)
- <4> <3> is repeated until all data are written.
- <5> Execution of internal verify → Error check (<1> to <11> in 14.8.9)
- <6> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)

Figure 14-24. Example of Operation When Command Execution Time Should Be Minimized (from Write to Internal Verify)



Note Perform processing to shift to normal mode in order to return to normal processing.

**Remark** <1> to <6> in Figure 14-24 correspond to <1> to <6> in 14.8.10 (2) above.

An example of a program when the command execution time (from write to internal verify) should be minimized in self programming mode is shown below.

```
;-----
:START
:-----
      MOV
              MKO, #11111111B ; Masks all interrupts
              FLCMD, #00H
      MOV
                              ; Clears FLCMD register
      DΤ
ModeOnLoop:
                               ; Configure settings so that the CPU clock ≥ 1 MHz
      MOV
              PFS,#00H
                              ; Clears flash status register
              PFCMD, #0A5H
                              ; PFCMD register control
      MOV
      MOV
              FLPMC, #01H
                              ; FLPMC register control (sets value)
      MOV
              FLPMC, #0FEH
                              ; FLPMC register control (inverts set value)
      MOV
              FLPMC, #01H
                              ; Sets self programming mode with FLPMC register control
                               ; (sets value)
      NOP
      HALT
                              ; Checks completion of write to specific registers
      BT PFS.0, $ModeOnLoop
                               ; Repeats the same processing when an error occurs.
FlashWrite:
                             ; Sets address at which data to be written is located
      MOVW
              HL, #DataAdrTop
                              ; Sets address at which data is to be written
      MOVAM
              DE,#WriteAdr
FlashWriteLoop:
      MOV
              FLCMD, #05H
                              ; Sets flash control command (byte write)
      MOV
              A,D
      MOV
              FLAPH, A
                              ; Sets address at which data is to be written
      MOV
              A,E
      MOV
              FLAPL, A
                               ; Sets address at which data is to be written
      MOV
              A,[HL]
      MOV
              FLW,A
                              ; Sets data to be written
      MOV
              WDTE, #0ACH
                              ; Clears & restarts WDT
      HALT
                               ; Self programming is started
      MOV
              A, PFS
              A,#00H
      CMP
      BNZ
               $StatusError
                              ; Checks write error
                               ; Performs abnormal termination processing when an error
                               ; occurs.
                               ; address at which data to be written is located + 1
      INCW
      MVVOM
              AX,HL
      CMPW
              AX, #DataAdrBtm ; Performs internal verify processing
      BNC
               $FlashVerify
                              ; if write of all data is completed
```

```
INCW
                                                               DE
                                                                                                                                    ; Address at which data is to be written + 1
                                                               FlashWriteLoop
                            BR
FlashVerify:
                            MOVW
                                                               HL,#WriteAdr
                                                                                                                      ; Sets verify address
                            VOM
                                                               FLCMD, #02H
                                                                                                                              ; Sets flash control command (internal verify 2)
                            MOV
                                                               A,H
                            VOM
                                                               FLAPH, A
                                                                                                                                   ; Sets verify start address
                            VOM
                                                               A,L
                            MOV
                                                               FLAPL, A
                                                                                                                                  ; Sets verify start address
                            MOV
                                                               A,D
                                                               FLAPHC, A
                            VOM
                                                                                                                                  ; Sets verify end address
                            MOV
                                                               A,E
                            MOV
                                                               FLAPLC, A
                                                                                                                                   ; Sets verify end address
                            MOV
                                                               WDTE, #0ACH
                                                                                                                                   ; Clears & restarts WDT
                            HALT
                                                                                                                                    ; Self programming is started
                            MOV
                                                               A, PFS
                                                               A,#00H
                            CMP
                                                                $StatusError
                                                                                                                               ; Checks internal verify error
                            BNZ
                                                                                                                                    ; Performs abnormal termination processing when an error % \left( 1\right) =\left( 1\right) \left( 
                                                                                                                                    ; occurs.
                            MOV
                                                               FLCMD, #00H
                                                                                                                                  ; Clears FLCMD register
ModeOffLoop:
                            MOV
                                                               PFS,#00H
                                                                                                                                  ; Clears flash status register
                            MOV
                                                               PFCMD, #0A5H
                                                                                                                                   ; PFCMD register control
                                                               FLPMC, #00H
                            MOV
                                                                                                                                    ; FLPMC register control (sets value)
                            VOM
                                                               FLPMC, #0FFH
                                                                                                                                   ; FLPMC register control (inverts set value)
                            MOV
                                                               FLPMC, #00H
                                                                                                                                    ; Sets normal mode via FLPMC register control (sets value)
                                                                                                                                  ; Checks completion of write to specific registers
                            BT PFS.0, $ModeOffLoop
                                                                                                                                    ; Repeats the same processing when an error occurs.
                                                                                                                                    ; After the specific sequence is correctly executed, restore
                                                                                                                                    ; the CPU clock to its setting before the self programming
                            MOV
                                                              MK0,#INT_MK0
                                                                                                                                   ; Restores interrupt mask flag
                            EI
                            BR
                                                               StatusNormal
 ;-----
 ; END (abnormal termination processing); Perform processing to shift to
                       normal mode in order to return to normal processing
 :-----
StatusError:
```

178

```
;-----
; END (normal termination processing)
;-----
StatusNormal:
; Data to be written
;-----
DataAdrTop:
  DB
      XXH
      XXH
  DB
  DB
      XXH
  DB
      XXH
  DB
      XXH
DataAdrBtm:
;-----
```

Remark Internal verify 2 is used in the above program example. Use internal verify 1 to verify s whole block.

#### 14.8.11 Examples of operation when interrupt-disabled time should be minimized in self programming mode

Examples of operation when the interrupt-disabled time should be minimized in self programming mode are explained below.

#### (1) Erasure to blank check

- <1> Specification of block erase command (<1> to <5> in 14.8.6)
- <2> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <3> Execution of block erase command -> Error check (<6> to <11> in 14.8.6)
- <4> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)
- <5> Specification of block blank check command (<1> to <5> in 14.8.7)
- <6> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <7> Execution of block blank check command  $\rightarrow$  Error check (<6> to <11> in 14.8.7)
- <8> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)

Erasure to blank check Figure 14-18 <1> Specify block erase command <1> to <5> <2> Shift to self programming Figure 14-16 <1> to <7> mode <3> Execute block erase command Figure 14-18 <6> to <11> Abnormal 3> Check execution result (VCERR and WEPRERR flags) Normal Figure 14-17 <4> Shift to normal mode <1> to <6> <5> Specify block blank Figure 14-19 check command <1> to <5> <6> Shift to self programming Figure 14-16 mode <1> to <7> <7> Execute block blank check command Figure 14-19 <6> to <11> <7> Check execution result Abnormal (VCERR and WEPRERR flags) Normal Figure 14-17 <8> Shift to normal mode <1> to <6> Abnormal termination Note Normal termination

Figure 14-25. Example of Operation When Interrupt-Disabled Time Should Be Minimized (from Erasure to Blank Check)

**Note** Perform processing to shift to normal mode in order to return to normal processing.

**Remark** <1> to <8> in Figure 14-25 correspond to <1> to <8> in 14.8.11 (1) (previous page).

An example of a program when the interrupt-disabled time (from erasure to blank check) should be minimized in self programming mode is shown below.

```
;-----
:START
;-----
FlashBlockErase:
      ; Sets erase command
              FLCMD, #03H
      MOV
                            ; Sets flash control command (block erase)
      MOV
              FLAPH,#07H
                            ; Sets number of block to be erased (block 7 is specified here)
              FLAPL, #00H
                             ; Fixes FLAPL to "00H"
      MOV
              FLAPHC,#07H
      MOV
                             ; Sets erase block compare number (same value as that of FLAPH)
              FLAPLC, #00H
                             ; Fixes FLAPLC to "00H"
      VOM
      CALL
               !ModeOn
                             ; Shift to self programming mode
      ; Execution of erase command
      MOV
               PFS,#00H
                             ; Clears flash status register
      MOV
              WDTE, #0ACH
                             ; Clears & restarts WDT
      HALT
                             ; Self programming is started
              A, PFS
      MOV
              A,#00H
      CMP
      BNZ
               $StatusError
                             ; Checks erase error
                             ; Performs abnormal termination processing when an error
                             ; occurs.
      CALL
               !ModeOff
                             ; Shift to normal mode
      ; Sets blank check command
      VOM
              FLCMD, #04H
                             ; Sets flash control command (block blank check)
              FLAPH,#07H
      MOV
                             ; Sets block number for blank check (block 7 is specified here)
                             ; Fixes FLAPL to "00H"
              FLAPL,#00H
      MOV
      MOV
              FLAPHC, #07H
                             ; Sets blank check block compare number (same value as that of
                             : FLAPH)
              FLAPLC, #0FFH
                             ; Fixes FLAPLC to "FFH"
      MOV
      CALL
              !ModeOn
                             ; Shift to self programming mode
      ; Execution of blank check command
      MOV
               PFS,#00H
                             ; Clears flash status register
      VOM
              WDTE, #0ACH
                             ; Clears & restarts WDT
      HALT
                             ; Self programming is started
      VOM
              A, PFS
      CMP
              A,#00H
      BNZ
               $StatusError
                             ; Checks blank check error
                             ; Performs abnormal termination processing when an error occurs
```

```
!ModeOff
                      ; Shift to normal mode
     CALL
           StatusNormal
     BR
;END (abnormal termination processing); Perform processing to shift to
    normal mode in order to return to normal processing
StatusError:
;-----
; END (normal termination processing)
;-----
StatusNormal:
;------
; Processing to shift to self programming mode
;-----
ModeOn:
     MOV
           MKO, #11111111B ; Masks all interrupts
     VOM
           FLCMD, #00H ; Clears FLCMD register
     DI
ModeOnLoop:
                       ; Configure settings so that the CPU clock \geq 1 MHz
     MOV
           PFS,#00H
                       ; Clears flash status register
           PFCMD,#0A5H
                       ; PFCMD register control
     VOM
     VOM
           FLPMC, #01H
                      ; FLPMC register control (sets value)
           FLPMC, #0FEH
                      ; FLPMC register control (inverts set value)
     VOM
           FLPMC, #01H
                       ; Sets self programming mode via FLPMC register control (sets
     MOV
                       ; value)
     NOP
     HALT
     BT PFS.0, $ModeOnLoop
                      ; Checks completion of write to specific registers
                       ; Repeats the same processing when an error occurs.
     RET
; Processing to shift to normal mode
;-----
ModeOffLoop:
     MOV
           FLCMD, #00H
                      ; Clears FLCMD register
     VOM
           PFS,#00H
                      ; Clears flash status register
     VOM
           PFCMD, #0A5H
                      ; PFCMD register control
```

#### **CHAPTER 14 FLASH MEMORY**

MOV FLPMC, #00H ; FLPMC register control (sets value) MOV FLPMC, #0FFH ; FLPMC register control (inverts set value) FLPMC, #00H ; Sets normal mode via FLPMC register control (sets value) MOV BT PFS.0, \$ModeOffLoop ; Checks completion of write to specific registers ; Repeats the same processing when an error occurs. ; After the specific sequence is correctly executed, restore ; the CPU clock to its setting before the self programming MOV MK0,#INT\_MK0 ; Restores interrupt mask flag ΕI RET

## (2) Write to internal verify

- <1> Specification of source data for write
- <2> Specification of byte write command (<1> to <4> in 14.8.8)
- <3> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <4> Execution of byte write command  $\rightarrow$  Error check (<5> to <10> in 14.8.8)
- <5> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)
- <6> <2> to <5> is repeated until all data are written.
- <7> The internal verify command is specified (<1> to <5> in 14.8.9)
- <8> Mode is shifted from normal mode to self programming mode (<1> to <7> in 14.8.4)
- <9> Execution of internal verify command  $\rightarrow$  Error check (<6> to <11> in 14.8.9)
- <10> Mode is shifted from self programming mode to normal mode (<1> to <6> in 14.8.5)

Write to internal verify <1> Set source data for write Figure 14-20 <2> Specify byte write command <1> to <4> <3> Shift to self programming Figure 14-16 mode <1> to <7> <4> Execute byte write command Figure 14-20 <5> to <10> <4> Check execution result Abnormal (VCERR and WEPRERR flags) Normal Figure 14-17 <5> Shift to normal mode <1> to <6> Yes <6> All data written? No Figure 14-21 <7> Specify internal verify command <1> to <5> <8> Shift to self programming Figure 14-16 mode <1> to <7> <9> Execute internal verify command Figure 14-21 <6> to <11> <9> Check execution result Abnormal (VCERR and WEPRERR flags) Normal Figure 14-17 <10> Shift to normal mode <1> to <6> Abnormal termination<sup>Note</sup> Normal termination

Figure 14-26. Example of Operation When Interrupt-Disabled Time Should Be Minimized (from Write to Internal Verify)

**Note** Perform processing to shift to normal mode in order to return to normal processing.

**Remark** <1> to <10> in Figure 14-26 correspond to <1> to <10> in **14.8.11 (2)** (previous page).

An example of a program when the interrupt-disabled time (from write to internal verify) should be minimized in self programming mode is shown below.

```
;-----
:START
;-----
      ; Sets write command
FlashWrite:
              HL, #DataAdrTop ; Sets address at which data to be written is located
      MOVW
      MOVW
              DE, #WriteAdr ; Sets address at which data is to be written
FlashWriteLoop:
              FLCMD, #05H
                           ; Sets flash control command (byte write)
      MOV
      VOM
              A,D
      VOM
              FLAPH,A
                           ; Sets address at which data is to be written
      VOM
              A,E
      MOV
              FLAPL, A
                            ; Sets address at which data is to be written
      VOM
              A,[HL]
      VOM
              FLW,A
                           ; Sets data to be written
      CALL
              !ModeOn
                            ; Shift to self programming mode
      ; Execution of write command
      MOV
              PFS,#00H
                           ; Clears flash status register
              WDTE, #0ACH
      MOV
                           ; Clears & restarts WDT
                            ; Self programming is started
      HALT
      VOM
              A,PFS
      CMP
              A,#00H
              $StatusError ; Checks write error
      BNZ
                            ; Performs abnormal termination processing when an error
                            ; occurs.
      CALL
              !ModeOff
                            ; Shift to normal mode
      MOV
              MK0, #INT_MK0
                           ; Restores interrupt mask flag
      ΕI
      ; Judgment of writing all data
      INCW
              _{\rm HL}
                            ; Address at which data to be written is located + 1
      MVVM
              AX,HL
      CMPW
              AX, #DataAdrBtm ; Performs internal verify processing
              $FlashVerify ; if write of all data is completed
      BNC
      INCW
              DE
                            ; Address at which data is to be written + 1
      BR
              FlashWriteLoop
      ; Setting internal verify command
```

```
FlashVerify:
           HL,#WriteAdr
     MOVW
                       ; Sets verify address
     MOV
           FLCMD, #02H
                       ; Sets flash control command (internal verify 2)
     MOV
           A,H
     MOV
           FLAPH, A
                       ; Sets verify start address
     MOV
           A,L
     MOV
           FLAPL, A
                       ; Sets verify start address
     MOV
           A,D
     MOV
           FLAPHC, A
                       ; Sets verify end address
           A,E
     MOV
           FLAPLC, A
     MOV
                       ; Sets verify end address
     CALL
           !ModeOn
                       ; Shift to self programming mode
     ; Execution of internal verify command
     MOV
           PFS,#00H
                       ; Clears flash status register
           WDTE, #0ACH
     MOV
                       ; Clears & restarts WDT
     HALT
                       ; Self programming is started
     MOV
           A, PFS
           A,#00H
     CMP
           $StatusError
                       ; Checks internal verify error
     BNZ
                       ; Performs abnormal termination processing when an error occurs
           !ModeOff
                       ; Shift to normal mode
     CALL
     BR
           StatusNormal
;-----
;END (abnormal termination processing); Perform processing to shift to
    normal mode in order to return to normal processing
;-----
StatusError:
;-----
; END (normal termination processing)
;-----
StatusNormal:
;-----
; Processing to shift to self programming mode
;-----
ModeOn:
     MOV
           MKO, #11111111B ; Masks all interrupts
```

; Clears FLCMD register

MOV

FLCMD, #00H

DI

```
; Configure settings so that the CPU clock \geq 1 MHz
ModeOnLoop:
     MOV
             PFS,#00H
                          ; Clears flash status register
     MOV
             PFCMD, #0A5H
                          ; PFCMD register control
      MOV
             FLPMC, #01H
                          ; FLPMC register control (sets value)
      MOV
             FLPMC, #0FEH
                          ; FLPMC register control (inverts set value)
             FLPMC, #01H
      MOV
                          ; Sets self programming mode via FLPMC register control (sets
                          ; value)
      NOP
      HALT
      BT PFS.0, $ModeOnLoop
                          ; Checks completion of write to specific registers
                          ; Repeats the same processing when an error occurs.
      RET
;-----
; Processing to shift to normal mode
;-----
ModeOffLoop:
     MOV
             FLCMD, #00H
                          ; Clears FLCMD register
      MOV
             PFS,#00H
                         ; Clears flash status register
      MOV
             PFCMD, #0A5H
                         ; PFCMD register control
             FLPMC, #00H
                          ; FLPMC register control (sets value)
      VOM
      MOV
             FLPMC, #0FFH
                          ; FLPMC register control (inverts set value)
      MOV
             FLPMC, #00H
                          ; Sets normal mode via FLPMC register control (sets value)
      BT PFS.0, $ModeOffLoop
                         ; Checks completion of write to specific registers
                          ; Repeats the same processing when an error occurs.
                          ; After the specific sequence is correctly executed, restore
                           ; the CPU clock to its setting before the self programming
     MOV
             MK0, #INT_MK0
                          ; Restores interrupt mask flag
      ΕI
      RET
;------
;Data to be written
;-----
DataAdrTop:
     DB
             XXH
      DB
             XXH
      DB
             XXH
```

|        | DB    | XXH |
|--------|-------|-----|
|        |       |     |
|        | :     |     |
|        | :     |     |
|        |       |     |
|        | DB    | HXX |
| DataAd | rBtm: |     |
| ;      |       |     |

**Remark** Internal verify 2 is used in the above program example. Use internal verify 1 to verify s whole block.

## 15.1 Connecting QB-MINI2 to $\mu$ PD78F9500, 78F9501, 78F9502

The  $\mu$  PD78F9500, 78F9501, 78F9502 use  $\overline{\text{RESET}}$ , EXCLK, P22, INTP1, V<sub>DD</sub>, and GND pins to communicate with the host machine via an on-chip debug emulator (QB-MINI2).

Caution Do not use the on-chip debug function in products designated for mass production, because the guaranteed number of rewritable times of the flash memory may be exceeded when this function is used, and product reliability therefore cannot be guaranteed. NEC Electronics is not liable for problems occurring when the on-chip debug function is used.



Figure 15-1. Recommended Circuit Connection

Caution The constants described in the circuit connection example are reference values. If you perform flash programming aiming at mass production, thoroughly evaluate whether the specifications of the target device are satisfied.

- Notes 1. The RESET pin is used to download the monitor program at debugger startup or to implement forced reset. Therefore, a pin that alternately functions as the RESET pin cannot be used. For reset pin connection, refer to QB-MINI2 User's Manual (U18371E).
  - 2. This is the pin connection when the EXCLK and P22 pins are not used in the target system. When using the EXCLK and P22 pins, refer to 15.1.2 Connection of EXCLK and P22 pins.
  - 3. No problem will occur if the dashed line portions are connected.
  - 4. This pin is connected to enhance the accuracy of time measurement between run and break during debugging. Debugging is possible even if this pin is left open, but measurement error occurs in several ms units.

Note 5. The INTP1 pin is used for communication between QB-MINI2 and the target device during debugging. When debugging is performed with QB-MINI2, therefore, the INTP1 pin and its alternate-function pin cannot be used. For INTP1 pin connection, refer to 15.1.1 Connection of INTP1 pin.

Pins for communication depend on whether the monitor program has been written or not. (refer to **Table 15-1**) EXCLK and P22 pins can be used as I/O port pins or the pins for oscillation, after the monitor program has been written.

Table 15-1. Pins for communication with QB-MINI2

| Before writing the monitor program | After writing the monitor program |
|------------------------------------|-----------------------------------|
| EXCLK, P22, RESET, INTP1, VDD, Vss | RESET, INTP1, VDD, VSS            |

#### 15.1.1 Connection of INTP1 pin

The INTP1 pin is used only for communication between QB-MINI2 and the target device during debugging. Design circuits appropriately according to the relevant case among the cases shown below.

- (1) INTP1 pin is not used in target system (as is illustrated in Figure 15-1. Recommended Circuit Connection)
  - $\rightarrow$  See Figure 15-2.
- (2) QB-MINI2 is used only for programming, not for debugging
  - $\rightarrow$  See Figure 15-3.
- (3) QB-MINI2 is used for debugging and debugging of the INTP1 pin is performed only with a real machine
  - $\rightarrow$  See Figure 15-4.

Figure 15-2. Circuit Connection for the Case Where INTP1 Pin Is Not Used in Target System



Figure 15-3. Circuit Connection for the Case Where QB-MINI2 Is Used Only for Programming



Figure 15-4. Circuit Connection for the Case Where QB-MINI2 Is Used for Debugging and Debugging of INTP1 Pin Is Performed Only with Real Machine



Caution If debugging is performed with a real machine running, without using QB-MINI2, write the user program using the QB-Programmer. Programs downloaded by the debugger include the monitor program, and such a program malfunctions if it is not controlled via QB-MINI2.

#### 15.1.2 Connection of EXCLK and P22 pins

The EXCLK and P22 pins are used when the debugger is started for the first time (when downloading the monitor program) and when programming is performed with the QB-Programmer.

Figure 15-5. Circuit Connection for the Case Where EXCLK and P22 Pins Are Used in Target System



\* Jumper setting

When debugger is started for the first time (downloading the monitor program) or when

programming is performed with QB-Programmer: 1-2 shorted
Other than above: 2-3 shorted

## 15.2 Securing of user resources

The user must prepare the following to perform communication between QB-MINI2 and the target device and implement each debug function. For details of the setting, refer to QB-MINI2 User's Manual (U18371E).

#### · Securement of memory space

The shaded portions in Figure 15-6 are the areas reserved for placing the debug monitor program, so user programs cannot be allocated in these spaces.

Internal ROM space

Internal ROM end address

Internal ROM end address

Stack area for debugging (5 bytes)

for software break (2 bytes)

Ox7EH

Ox18H

INTP1 interrupt vector (2 bytes)

Figure 15-6. Memory Spaces Where Debug Monitor Programs Are Allocated

• Securement of serial interface for communication

The register settings, concerning the INTP1 pin used for communication between QB-MINI2 and the target device, performed by the debug monitor program must not be changed.

#### **CHAPTER 16 INSTRUCTION SET OVERVIEW**

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

#### 16.1 Operation

#### 16.1.1 Operand identifiers and description methods

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

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

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

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

Table 16-1. Operand Identifiers and Description Methods

| Identifier          | Description Method                                                                                                                                                |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| r<br>rp<br>sfr      | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7)  AX (RP0), BC (RP1), DE (RP2), HL (RP3)  Special function register symbol                          |
| saddr<br>saddrp     | FE20H to FF1FH Immediate data or labels FE20H to FF1FH Immediate data or labels (even addresses only)                                                             |
| addr16<br>addr5     | 0000H to FFFFH Immediate data or labels (only even addresses for 16-bit data transfer instructions) 0040H to 007FH Immediate data or labels (even addresses only) |
| word<br>byte<br>bit | 16-bit immediate data or label 8-bit immediate data or label 3-bit immediate data or label                                                                        |

**Remark** For symbols of special function registers, see **Table 3-3 Special Function Registers**.

#### 16.1.2 Description of "Operation" column

A: A register; 8-bit accumulator

X: X registerB: B registerC: C registerD: D registerE: 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

XH, XL: Higher 8 bits and lower 8 bits of 16-bit register

\( \): Logical product (AND)\( \): Logical sum (OR)

∀: Exclusive logical sum (exclusive OR)

—: Inverted data

addr16: 16-bit immediate data or label

jdisp8: Signed 8-bit data (displacement value)

#### 16.1.3 Description of "Flag" column

(Blank): Unchanged
0: Cleared to 0
1: Set to 1

X: Set/cleared according to the resultR: Previously saved value is stored

# 16.2 Operation List

| Mnemonic | Operand        |        | Bytes | Clocks | Operation                       | Flag |    |    |
|----------|----------------|--------|-------|--------|---------------------------------|------|----|----|
|          |                |        |       |        |                                 | Z    | AC | CY |
| MOV      | r, #byte       |        | 3     | 6      | $r \leftarrow \text{byte}$      |      |    |    |
|          | saddr, #byte   |        | 3     | 6      | (saddr) ← byte                  |      |    |    |
|          | sfr, #byte     |        | 3     | 6      | $sfr \leftarrow byte$           |      |    |    |
|          | A, r           | Note 1 | 2     | 4      | $A \leftarrow r$                |      |    |    |
|          | r, A           | Note 1 | 2     | 4      | $r \leftarrow A$                |      |    |    |
|          | A, saddr       |        | 2     | 4      | $A \leftarrow (saddr)$          |      |    |    |
|          | saddr, A       |        | 2     | 4      | $(saddr) \leftarrow A$          |      |    |    |
|          | A, sfr         |        | 2     | 4      | A ← sfr                         |      |    |    |
|          | sfr, A         |        | 2     | 4      | sfr ← A                         |      |    |    |
|          | A, !addr16     |        | 3     | 8      | $A \leftarrow (addr16)$         |      |    |    |
|          | !addr16, A     |        | 3     | 8      | (addr16) ← A                    |      |    |    |
|          | PSW, #byte     |        | 3     | 6      | PSW ← byte                      | ×    | ×  | ×  |
|          | A, PSW         |        | 2     | 4      | $A \leftarrow PSW$              |      |    |    |
|          | PSW, A         |        | 2     | 4      | $PSW \leftarrow A$              | ×    | ×  | ×  |
|          | A, [DE]        |        | 1     | 6      | $A \leftarrow (DE)$             |      |    |    |
|          | [DE], A        |        | 1     | 6      | $(DE) \leftarrow A$             |      |    |    |
|          | A, [HL]        |        | 1     | 6      | $A \leftarrow (HL)$             |      |    |    |
|          | [HL], A        |        | 1     | 6      | $(HL) \leftarrow A$             |      |    |    |
|          | A, [HL + byte] |        | 2     | 6      | $A \leftarrow (HL + byte)$      |      |    |    |
|          | [HL + byte], A |        | 2     | 6      | $(HL + byte) \leftarrow A$      |      |    |    |
| XCH      | A, X           |        | 1     | 4      | $A \leftrightarrow X$           |      |    |    |
|          | A, r           | Note 2 | 2     | 6      | $A \leftrightarrow r$           |      |    |    |
|          | A, saddr       |        | 2     | 6      | $A \leftrightarrow (saddr)$     |      |    |    |
|          | A, sfr         |        | 2     | 6      | $A \leftrightarrow sfr$         |      |    |    |
|          | A, [DE]        |        | 1     | 8      | $A \leftrightarrow (DE)$        |      |    |    |
|          | A, [HL]        |        | 1     | 8      | $A \leftrightarrow (HL)$        |      |    |    |
|          | A, [HL, byte]  |        | 2     | 8      | $A \leftrightarrow (HL + byte)$ |      |    |    |

**Notes 1.** Except r = A.

**2.** Except r = A, X.

**Remark** One instruction clock cycle is one CPU clock cycle (fcpu) selected by the processor clock control register (PCC).

| Mnemonic | Operand        |      | Bytes | Clocks | Operation                                      |   | Flag | ,  |
|----------|----------------|------|-------|--------|------------------------------------------------|---|------|----|
|          |                |      |       |        |                                                | Z | AC   | CY |
| MOVW     | rp, #word      |      | 3     | 6      | $rp \leftarrow word$                           |   |      |    |
|          | AX, saddrp     |      | 2     | 6      | $AX \leftarrow (saddrp)$                       |   |      |    |
|          | saddrp, AX     |      | 2     | 8      | $(saddrp) \leftarrow AX$                       |   |      |    |
|          | AX, rp         | Note | 1     | 4      | $AX \leftarrow rp$                             |   |      |    |
|          | rp, AX         | Note | 1     | 4      | $rp \leftarrow AX$                             |   |      |    |
| XCHW     | AX, rp         | Note | 1     | 8      | $AX \leftrightarrow rp$                        |   |      |    |
| ADD      | A, #byte       |      | 2     | 4      | A, CY ← A + byte                               | × | ×    | ×  |
|          | saddr, #byte   |      | 3     | 6      | (saddr), CY $\leftarrow$ (saddr) + byte        | × | ×    | ×  |
|          | A, r           |      | 2     | 4      | $A, CY \leftarrow A + r$                       | × | ×    | ×  |
|          | A, saddr       |      | 2     | 4      | $A,CY \leftarrow A + (saddr)$                  | × | ×    | ×  |
|          | A, !addr16     |      | 3     | 8      | $A, CY \leftarrow A + (addr16)$                | × | ×    | ×  |
|          | A, [HL]        |      | 1     | 6      | $A,CY \leftarrow A + (HL)$                     | × | ×    | ×  |
|          | A, [HL + byte] |      | 2     | 6      | $A, CY \leftarrow A + (HL + byte)$             | × | ×    | ×  |
| ADDC     | A, #byte       |      | 2     | 4      | $A,CY \leftarrow A + byte + CY$                | × | ×    | ×  |
|          | saddr, #byte   |      | 3     | 6      | (saddr), $CY \leftarrow$ (saddr) + byte + $CY$ | × | ×    | ×  |
|          | A, r           |      | 2     | 4      | $A,CY \leftarrow A + r + CY$                   | × | ×    | ×  |
|          | A, saddr       |      | 2     | 4      | $A,CY \leftarrow A + (saddr) + CY$             | × | ×    | ×  |
|          | A, !addr16     |      | 3     | 8      | $A, CY \leftarrow A + (addr16) + CY$           | × | ×    | ×  |
|          | A, [HL]        |      | 1     | 6      | $A,CY \leftarrow A + (HL) + CY$                | × | ×    | ×  |
|          | A, [HL + byte] |      | 2     | 6      | $A,CY \leftarrow A + (HL + byte) + CY$         | × | ×    | ×  |
| 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.

**Remark** One instruction clock cycle is one CPU clock cycle (fcpu) selected by the processor clock control register (PCC).

| Mnemonic | Operand        | Bytes | Clocks | Operation                               |   | Flag | lag |  |
|----------|----------------|-------|--------|-----------------------------------------|---|------|-----|--|
|          |                |       |        |                                         | Z | AC   | CY  |  |
| SUBC     | A, #byte       | 2     | 4      | A, CY ← A – byte – CY                   | × | ×    | ×   |  |
|          | saddr, #byte   | 3     | 6      | (saddr), CY ← (saddr) – byte – CY       | × | ×    | ×   |  |
|          | A, r           | 2     | 4      | $A, CY \leftarrow A - r - CY$           | × | ×    | ×   |  |
|          | A, saddr       | 2     | 4      | $A,CY\leftarrow A-(saddr)-CY$           | × | ×    | ×   |  |
|          | A, !addr16     | 3     | 8      | A, CY ← 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 \wedge 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 \wedge (saddr)$         | × |      |     |  |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \land (addr16)$         | × |      |     |  |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \wedge (HL)$            | × |      |     |  |
|          | A, [HL + byte] | 2     | 6      | A ← A ∧ (HL + byte)                     | × |      |     |  |
| OR       | A, #byte       | 2     | 4      | $A \leftarrow A \lor byte$              | × |      |     |  |
|          | saddr, #byte   | 3     | 6      | $(saddr) \leftarrow (saddr) \lor byte$  | × |      |     |  |
|          | A, r           | 2     | 4      | $A \leftarrow A \lor r$                 | × |      |     |  |
|          | A, saddr       | 2     | 4      | $A \leftarrow A \lor (saddr)$           | × |      |     |  |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \lor (addr16)$          | × |      |     |  |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \lor (HL)$              | × |      |     |  |
|          | A, [HL + byte] | 2     | 6      | $A \leftarrow A \lor (HL + byte)$       | × |      |     |  |
| XOR      | A, #byte       | 2     | 4      | $A \leftarrow A \forall byte$           | × |      |     |  |
|          | saddr, #byte   | 3     | 6      | (saddr) ← (saddr) → byte                | × |      |     |  |
|          | A, r           | 2     | 4      | $A \leftarrow A \forall r$              | × |      |     |  |
|          | A, saddr       | 2     | 4      | $A \leftarrow A \forall (saddr)$        | × |      |     |  |
|          | A, !addr16     | 3     | 8      | $A \leftarrow A \forall (addr16)$       | × |      |     |  |
|          | A, [HL]        | 1     | 6      | $A \leftarrow A \lor (HL)$              | × |      |     |  |
|          | A, [HL + byte] | 2     | 6      | A ← A ∀ (HL + byte)                     | × |      |     |  |

**Remark** One instruction clock cycle is one CPU clock cycle (fcpu) selected by the processor clock control register (PCC).

| Mnemonic | Operand        | Bytes | Clocks | Operation                                                                 |   | Flag | J  |
|----------|----------------|-------|--------|---------------------------------------------------------------------------|---|------|----|
|          |                |       |        |                                                                           | 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) ← (saddr) + 1                                                     | × | ×    |    |
| DEC      | r              | 2     | 4      | r ← r – 1                                                                 | × | ×    |    |
|          | saddr          | 2     | 4      | (saddr) ← (saddr) - 1                                                     | × | ×    |    |
| INCW     | rp             | 1     | 4      | rp ← rp + 1                                                               |   |      |    |
| DECW     | rp             | 1     | 4      | rp ← rp − 1                                                               |   |      |    |
| ROR      | A, 1           | 1     | 2      | $(CY,A_7 \leftarrow A_0,A_{m-1} \leftarrow A_m) \times 1$                 |   |      | ×  |
| ROL      | A, 1           | 1     | 2      | $(CY,A_0 \leftarrow A_7,A_{m+1} \leftarrow A_m) \times 1$                 |   |      | ×  |
| RORC     | A, 1           | 1     | 2      | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1$ |   |      | ×  |
| ROLC     | A, 1           | 1     | 2      | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$ |   |      | ×  |
| SET1     | saddr.bit      | 3     | 6      | $(saddr.bit) \leftarrow 1$                                                |   |      |    |
|          | sfr.bit        | 3     | 6      | sfr.bit ← 1                                                               |   |      |    |
|          | A.bit          | 2     | 4      | A.bit ← 1                                                                 |   |      |    |
|          | PSW.bit        | 3     | 6      | PSW.bit ← 1                                                               | × | ×    | ×  |
|          | [HL].bit       | 2     | 10     | (HL).bit $\leftarrow$ 1                                                   |   |      |    |
| CLR1     | saddr.bit      | 3     | 6      | $(\text{saddr.bit}) \leftarrow 0$                                         |   |      |    |
|          | sfr.bit        | 3     | 6      | sfr.bit ← 0                                                               |   |      |    |
|          | A.bit          | 2     | 4      | A.bit $\leftarrow$ 0                                                      |   |      |    |
|          | PSW.bit        | 3     | 6      | PSW.bit ← 0                                                               | × | ×    | ×  |
|          | [HL].bit       | 2     | 10     | (HL).bit ← 0                                                              |   |      |    |
| SET1     | CY             | 1     | 2      | CY ← 1                                                                    |   |      | 1  |
| CLR1     | CY             | 1     | 2      | CY ← 0                                                                    |   |      | 0  |
| NOT1     | CY             | 1     | 2      | $CY \leftarrow \overline{CY}$                                             |   |      | ×  |

**Remark** One instruction clock cycle is one CPU clock cycle (fcpu) selected by the processor clock control register (PCC).

| Mnemonic | Operand             | Bytes | Clocks | Operation                                                                                                                                                                  |   | Flag | l  |
|----------|---------------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
|          |                     |       |        |                                                                                                                                                                            | Z | AC   | CY |
| CALL     | !addr16             | 3     | 6      | $(SP-1) \leftarrow (PC+3)$ H, $(SP-2) \leftarrow (PC+3)$ L, $PC \leftarrow addr16$ , $SP \leftarrow SP-2$                                                                  |   |      |    |
| CALLT    | [addr5]             | 1     | 8      | $(SP - 1) \leftarrow (PC + 1)_H, (SP - 2) \leftarrow (PC + 1)_L,$<br>$PC_H \leftarrow (00000000, addr5 + 1),$<br>$PC_L \leftarrow (00000000, addr5), SP \leftarrow SP - 2$ |   |      |    |
| RET      |                     | 1     | 6      | $PCH \leftarrow (SP + 1), PCL \leftarrow (SP), SP \leftarrow SP + 2$                                                                                                       |   |      |    |
| RETI     |                     | 1     | 8      | $\begin{aligned} & PCH \leftarrow (SP+1), PCL \leftarrow (SP), \\ & PSW \leftarrow (SP+2), SP \leftarrow SP+3, NMIS \leftarrow 0 \end{aligned}$                            | R | R    | R  |
| PUSH     | PSW                 | 1     | 2      | $(SP-1) \leftarrow PSW, SP \leftarrow SP-1$                                                                                                                                |   |      |    |
|          | rp                  | 1     | 4      | $(SP-1) \leftarrow rp_H, (SP-2) \leftarrow rp_L, SP \leftarrow SP-2$                                                                                                       |   |      |    |
| POP      | PSW                 | 1     | 4      | $PSW \leftarrow (SP),SP \leftarrow SP + 1$                                                                                                                                 | R | R    | R  |
|          | rp                  | 1     | 6      | $rpH \leftarrow (SP + 1), rpL \leftarrow (SP), SP \leftarrow SP + 2$                                                                                                       |   |      |    |
| MOVW     | SP, AX              | 2     | 8      | SP ← AX                                                                                                                                                                    |   |      |    |
|          | AX, SP              | 2     | 6      | $AX \leftarrow SP$                                                                                                                                                         |   |      |    |
| BR       | !addr16             | 3     | 6      | PC ← addr16                                                                                                                                                                |   |      |    |
|          | \$addr16            | 2     | 6      | PC ← PC + 2 + jdisp8                                                                                                                                                       |   |      |    |
|          | AX                  | 1     | 6      | $PCH \leftarrow A, PCL \leftarrow X$                                                                                                                                       |   |      |    |
| ВС       | \$saddr16           | 2     | 6      | PC ← PC + 2 + jdisp8 if CY = 1                                                                                                                                             |   |      |    |
| BNC      | \$saddr16           | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } CY = 0$                                                                                                                         |   |      |    |
| BZ       | \$saddr16           | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 1$                                                                                                                          |   |      |    |
| BNZ      | \$saddr16           | 2     | 6      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 0$                                                                                                                          |   |      |    |
| ВТ       | saddr.bit, \$addr16 | 4     | 10     | PC ← PC + 4 + jdisp8 if (saddr.bit) = 1                                                                                                                                    |   |      |    |
|          | sfr.bit, \$addr16   | 4     | 10     | PC ← PC + 4 + jdisp8 if sfr.bit = 1                                                                                                                                        |   |      |    |
|          | A.bit, \$addr16     | 3     | 8      | PC ← PC + 3 + jdisp8 if A.bit = 1                                                                                                                                          |   |      |    |
|          | PSW.bit, \$addr16   | 4     | 10     | PC ← PC + 4 + jdisp8 if PSW.bit = 1                                                                                                                                        |   |      |    |
| BF       | saddr.bit, \$addr16 | 4     | 10     | PC ← PC + 4 + jdisp8 if (saddr.bit) = 0                                                                                                                                    |   |      |    |
|          | sfr.bit, \$addr16   | 4     | 10     | $PC \leftarrow PC + 4 + jdisp8 \text{ if sfr.bit} = 0$                                                                                                                     |   |      |    |
|          | A.bit, \$addr16     | 3     | 8      | $PC \leftarrow PC + 3 + jdisp8 \text{ if A.bit} = 0$                                                                                                                       |   |      |    |
|          | PSW.bit, \$addr16   | 4     | 10     | PC ← 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      | $(\text{saddr}) \leftarrow (\text{saddr}) - 1$ , then<br>PC $\leftarrow$ PC + 3 + jdisp8 if $(\text{saddr}) \neq 0$                                                        |   |      |    |
| NOP      |                     | 1     | 2      | No Operation                                                                                                                                                               |   |      |    |
| El       |                     | 3     | 6      | IE ← 1 (Enable Interrupt)                                                                                                                                                  |   |      |    |
| DI       |                     | 3     | 6      | IE ← 0 (Disable Interrupt)                                                                                                                                                 |   |      |    |
| HALT     |                     | 1     | 2      | Set HALT Mode                                                                                                                                                              |   |      |    |
| STOP     |                     | 1     | 2      | Set STOP Mode                                                                                                                                                              |   |      |    |

**Remark** One instruction clock cycle is one CPU clock cycle (fcpu) selected by the processor clock control register (PCC).

# 16.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<br>1st Operand | #byte | А   | r                   | sfr | saddr | !addr16 | PSW | [DE] | [HL] | [HL + byte] | \$addr16 | 1    | None        |
|----------------------------|-------|-----|---------------------|-----|-------|---------|-----|------|------|-------------|----------|------|-------------|
| A                          | ADD   |     | MOV <sup>Note</sup> | MOV | MOV   | MOV     | MOV | MOV  | MOV  | MOV         |          | ROR  |             |
|                            | ADDC  |     | XCH <sup>Note</sup> | XCH | XCH   |         |     | XCH  | XCH  | XCH         |          | 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<br>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         |
| СҮ          |          | SET1<br>CLR1<br>NOT1 |

# (4) Call instructions/branch instructions

CALL, CALLT, BR, BC, BNC, BZ, BNZ, DBNZ

| 2nd Operand           | AX | !addr16    | [addr5] | \$addr16                     |
|-----------------------|----|------------|---------|------------------------------|
| 1st Operand           |    |            |         |                              |
| 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 17 ELECTRICAL SPECIFICATIONS**

Absolute Maximum Ratings (TA = 25°C)

| Parameter            | Symbol          | Conditions                                 | Ratings                                       | Unit |
|----------------------|-----------------|--------------------------------------------|-----------------------------------------------|------|
| Supply voltage       | V <sub>DD</sub> |                                            | -0.3 to +6.5                                  | V    |
|                      | Vss             |                                            | -0.3 to +0.3                                  | V    |
| Input voltage        | Vı              | P20 to P23, P32, P34, P40, P43             | $-0.3$ to $V_{DD} + 0.3^{Note}$               | V    |
| Output voltage       | Vo              |                                            | $-0.3$ to $V_{DD} + 0.3^{Note}$               | V    |
| Analog input voltage | Van             |                                            | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note</sup> | V    |
| Output current, high | Іон             | Per pin                                    | -10.0                                         | mA   |
|                      |                 | Total of P20 to P23, P32, P40, P43         | -44.0                                         | mA   |
| Output current, low  | loL             | Per pin                                    | 20.0                                          | mA   |
|                      |                 | Total of P20 to P23, P32, P40, P43         | 44.0                                          | mA   |
| Operating ambient    | Та              | In normal operation mode                   | -40 to +85                                    | °C   |
| temperature          |                 | During flash memory programming            |                                               |      |
| Storage temperature  | Tstg            | Flash memory blank status                  | -65 to +150                                   | °C   |
|                      |                 | Flash memory programming already performed | -40 to +125                                   | °C   |

Note Must be 6.5 V or lower

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.

## Oscillator Characteristics (TA = -40 to +85°C, VDD = 2.0 to 5.5 VNote 1, VSS = 0 V)

| Resonator | Recommended Circuit | Parameter                                               | Conditions                                            | MIN.  | TYP. | MAX. | Unit |
|-----------|---------------------|---------------------------------------------------------|-------------------------------------------------------|-------|------|------|------|
| External  |                     | External main                                           | $2.7~V \leq V_{DD} \leq 5.5~V$                        | 2.0   |      | 10.0 | MHz  |
| clock     | EXCLK 8             | system clock<br>frequency<br>(fexclk) <sup>Note 2</sup> | 2.0 V ≤ V <sub>DD</sub> < 2.7 V                       | 2.0   |      | 5.0  |      |
|           |                     | External main                                           | $2.7 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V}$ | 0.045 |      | 0.25 | μs   |
|           | $\vdash$            | system clock<br>input high-/low-<br>level width         | 2.0 V ≤ V <sub>DD</sub> < 2.7 V                       | 0.09  |      | 0.25 |      |
|           |                     | (texclkh, texclkl)                                      |                                                       |       |      |      |      |

- **Notes 1.** Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage ( $V_{POC}$ ) of the power-on clear (POC) circuit is 2.1 V  $\pm$ 0.1 V.
  - 2. Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.

**Remark** For the resonator selection and oscillator constant, users are required to either evaluate the oscillation themselves or apply to the resonator manufacturer for evaluation.

## High-Speed Internal Oscillator Characteristics (TA = -40 to +85°C, VDD = 2.0 to 5.5 VNote 1, VSS = 0 V)

| Resonator           | Parameter                                    | Conditions                                        |                                             | MIN. | TYP. | MAX. | Unit |
|---------------------|----------------------------------------------|---------------------------------------------------|---------------------------------------------|------|------|------|------|
| High-speed internal | Oscillation frequency (fx) <sup>Note 2</sup> | $2.7~V \leq V_{DD} \leq 5.5~V$                    | $T_A = -10 \text{ to } +85^{\circ}\text{C}$ |      |      | ±2   | %    |
| oscillator          |                                              |                                                   | $TA = -40 \text{ to } +85^{\circ}C$         |      |      | ±5   | %    |
|                     |                                              | $2.0 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$ |                                             | 5.5  |      |      | MHz  |

- **Notes 1.** Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (V<sub>POC</sub>) of the power-on-clear (POC) circuit is 2.1 V ±0.1 V.
  - 2. Indicates only oscillator characteristics. Refer to AC Characteristics for instruction execution time.

## Low-Speed Internal Oscillator Characteristics (TA = −40 to +85°C, VDD = 2.0 to 5.5 VNote, VSS = 0 V)

| Resonator                     | Parameter                   | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------|-----------------------------|------------|------|------|------|------|
| Low-speed internal oscillator | Oscillation frequency (fRL) |            | 120  | 240  | 480  | kHz  |

**Note** Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage ( $V_{POC}$ ) of the power-on clear (POC) circuit is 2.1 V  $\pm$ 0.1 V.

<R><R>

DC Characteristics (T<sub>A</sub> = -40 to +85°C, V<sub>DD</sub> = 2.0 to 5.5 V<sup>Note</sup>, V<sub>SS</sub> = 0 V) (1/2)

|         | Parameter                    | Symbol           | Conditions                                                                                                                  |           | ons                                                           | MIN.                  | TYP. | MAX.               | Unit |
|---------|------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------|---------------------------------------------------------------|-----------------------|------|--------------------|------|
|         | Output current, high         | Іон              | Per pin                                                                                                                     |           | $2.0~V \leq V_{\text{DD}} \leq 5.5~V$                         |                       |      | <b>-</b> 5         | mA   |
|         |                              |                  | Total of all pins                                                                                                           |           | $4.0~V \leq V_{DD} \leq 5.5~V$                                |                       |      | -25                | mA   |
|         |                              |                  |                                                                                                                             |           | $2.0~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.0~\textrm{V}$ |                       |      | -15                | mA   |
|         | Output current, low          | loL              | Per pin                                                                                                                     |           | $2.0~V \leq V_{\text{DD}} \leq 5.5~V$                         |                       |      | 10                 | mA   |
|         |                              |                  | Total of all pins                                                                                                           |           | $4.0~V \leq V_{DD} \leq 5.5~V$                                |                       |      | 30                 | mA   |
|         |                              |                  | $2.0 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$                                                                           |           |                                                               |                       | 15   | mA                 |      |
| <r></r> | Input voltage, high          | V <sub>IH1</sub> |                                                                                                                             |           |                                                               | 0.8V <sub>DD</sub>    |      | $V_{DD}$           | V    |
| <r></r> | Input voltage, low           | V <sub>IL1</sub> |                                                                                                                             |           |                                                               | 0                     |      | 0.2V <sub>DD</sub> | V    |
|         | Output voltage, high         | Vон              | Total of output pins $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$ $1_{OH} = -15 \text{ mA}$ $1_{OH} = -5 \text{ mA}$ |           | V <sub>DD</sub> – 1.0                                         |                       |      | ٧                  |      |
|         |                              |                  | Іон = -100 <i>µ</i> А                                                                                                       |           | $2.0~V \leq V_{DD} < 4.0~V$                                   | V <sub>DD</sub> - 0.5 |      |                    | ٧    |
|         | Output voltage, low          | Vol              | Total of output pin                                                                                                         | s         | $4.0~V \leq V_{DD} \leq 5.5~V$                                |                       |      | 1.3                | ٧    |
|         |                              |                  | IoL = 30 mA                                                                                                                 |           | IoL = 10 mA                                                   |                       |      |                    |      |
|         |                              |                  | $2.0 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$                                                                           | V         |                                                               |                       |      | 0.4                | V    |
|         |                              |                  | IoL = 400 μA                                                                                                                |           |                                                               |                       |      |                    |      |
|         | Input leakage current, high  | Ішн              | $V_{I} = V_{DD}$                                                                                                            | Pins ot   | her than EXCLK                                                |                       |      | 1                  | μΑ   |
|         | Input leakage current, low   | ILIL             | V1 = 0 V                                                                                                                    | Pins ot   | her than EXCLK                                                |                       |      | -1                 | μΑ   |
|         | Output leakage current, high | Ісон             | Vo = V <sub>DD</sub>                                                                                                        | Pins ot   | her than EXCLK                                                |                       |      | 1                  | μΑ   |
|         | Output leakage current, low  | ILOL             | Vo = 0 V                                                                                                                    | Pins ot   | her than EXCLK                                                |                       |      | -1                 | μΑ   |
|         | Pull-up resistance value     | Rpu              | $V_{I} = 0 V$                                                                                                               |           | 10                                                            | 30                    | 100  | kΩ                 |      |
|         |                              |                  | V <sub>I</sub> = 0 V (P34, rese                                                                                             | et status | )                                                             | 10                    | 30   | 100                | kΩ   |

Note Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (V<sub>POC</sub>) of the power-on clear (POC) circuit is  $2.1 \text{ V} \pm 0.1 \text{ V}$ .

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

DC Characteristics (TA = -40 to +85°C, VDD = 2.0 to 5.5 V<sup>Note 1</sup>, VSS = 0 V) (2/2)

| Parameter                        | Symbol           |                                                                  | Condition                                                               | s                                                | MIN. | TYP. | MAX. | Unit |
|----------------------------------|------------------|------------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------|------|------|------|------|
| Supply current <sup>Note 2</sup> | DD1 Note 3       | External clock input oscillation                                 | $fx = 10 \text{ MHz}$ $V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$ |                                                  |      | 6.1  | 12.2 | mA   |
|                                  |                  | operating<br>mode <sup>Note 6</sup>                              | $fx = 6 \text{ MHz}$ $V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$  |                                                  |      | 5.5  | 11.0 | mA   |
|                                  |                  |                                                                  | fx = 5  MHz<br>$V_{DD} = 3.0 \text{ V} \pm 10\%^{\text{Note 5}}$        |                                                  |      | 3.0  | 6.0  | mA   |
|                                  | I <sub>DD2</sub> | External clock                                                   | fx = 10 MHz                                                             | When peripheral functions are stopped            |      | 1.7  | 3.8  | mA   |
|                                  |                  | input HALT<br>mode <sup>Note 6</sup>                             | $V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$                       | When peripheral functions are operating          |      |      | 6.7  |      |
|                                  |                  |                                                                  | fx = 6  MHz<br>$V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$        | When peripheral functions are stopped            |      | 1.3  | 3.0  | mA   |
|                                  |                  |                                                                  |                                                                         | When peripheral functions are operating          |      |      | 6.0  |      |
|                                  |                  |                                                                  | fx = 5 MHz                                                              | When peripheral functions are stopped            |      | 0.48 | 1    | mA   |
|                                  |                  | $V_{DD} = 3.0 \text{ V} \pm 10\%^{\text{Note 5}}$                | When peripheral functions are operating                                 |                                                  |      | 2.1  |      |      |
|                                  | in               | High-speed internal oscillation operating mode <sup>Note 7</sup> | $f_X = 8 \text{ MHz}$ $V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$ |                                                  |      | 5.0  | 10.0 | mA   |
|                                  | I <sub>DD4</sub> | High-speed                                                       | fx = 8 MHz                                                              | When peripheral functions are stopped            |      | 1.4  | 3.2  | mA   |
|                                  |                  | internal oscillation<br>HALT mode <sup>Note 7</sup>              | $V_{DD} = 5.0 \text{ V} \pm 10\%^{\text{Note 4}}$                       | When peripheral functions are operating          |      |      | 5.9  |      |
|                                  | I <sub>DD5</sub> | STOP mode                                                        | $V_{DD} = 5.0 \text{ V} \pm 10\%$                                       | When low-speed internal oscillation is stopped   |      | 3.5  | 20.0 | μΑ   |
|                                  |                  |                                                                  |                                                                         | When low-speed internal oscillation is operating |      | 17.5 | 32.0 |      |
|                                  |                  | V <sub>DD</sub> = 3.0 V ±10%                                     | When low-speed internal oscillation is stopped                          |                                                  | 3.5  | 15.5 | μΑ   |      |
|                                  |                  |                                                                  |                                                                         | When low-speed internal oscillation is operating |      | 11.0 | 26.0 |      |

- Notes 1. Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (V<sub>POC</sub>) of the power-on clear (POC) circuit is  $2.1 \text{ V} \pm 0.1 \text{ V}$ .
  - 2. Total current flowing through the internal power supply (VDD). However, the current that flows through the pull-up resistors of ports is not included.
  - 3. IDD1 and IDD3 include peripheral operation current.
  - 4. When the processor clock control register (PCC) is set to 00H.
  - **5.** When the processor clock control register (PCC) is set to 02H.
  - 6. When external clock input is selected as the system clock source using the option byte.
  - 7. When high-speed internal oscillation clock is selected as the system clock source using the option byte.

## **AC Characteristics**

Basic operation (TA = -40 to +85°C, VDD = 2.0 to 5.5 V<sup>Note</sup>, VSS = 0 V)

| Parameter                   | Symbol | Condition                             | าร                                                            | MIN. | TYP. | MAX. | Unit |
|-----------------------------|--------|---------------------------------------|---------------------------------------------------------------|------|------|------|------|
| Cycle time (minimum         | Tcy    | External clock input                  | $4.0~V \leq V_{DD} \leq 5.5~V$                                | 0.2  |      | 16   | μs   |
| instruction execution time) |        |                                       | $3.0 \text{ V} \leq \text{V}_{DD} < 4.0 \text{ V}$            | 0.33 |      | 16   | μs   |
|                             |        |                                       | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.0~\textrm{V}$ | 0.4  |      | 16   | μs   |
|                             |        |                                       | 2.0 V ≤ V <sub>DD</sub> < 2.7 V                               | 1    |      | 16   | μs   |
|                             |        | High-speed internal oscillation clock | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V}$         | 0.23 |      | 4.22 | μs   |
|                             |        |                                       | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$             | 0.47 |      | 4.22 | μs   |
|                             |        |                                       | $2.0 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$             | 0.95 |      | 4.22 | μs   |
| Interrupt input high-level  | tinth, |                                       |                                                               | 1    |      |      | μs   |
| width, low-level width      | tintl  |                                       |                                                               |      |      |      |      |
| RESET input low-level       | trsl   |                                       |                                                               | 2    |      |      | μs   |
| width                       |        |                                       |                                                               |      |      |      |      |

Note Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (V<sub>POC</sub>) of the power-on clear (POC) circuit is  $2.1 \text{ V} \pm 0.1 \text{ V}$ .

#### **CPU Clock Frequency, Peripheral Clock Frequency**

| Parameter           | Conditions                                        | CPU Clock (fcpu)                     | Peripheral Clock (fxp)                             |
|---------------------|---------------------------------------------------|--------------------------------------|----------------------------------------------------|
| External clock      | $4.0~V \leq V_{DD} \leq 5.5~V$                    | 125 kHz ≤ fcpu ≤ 10 MHz              | 500 kHz ≤ fxp ≤ 10 MHz                             |
|                     | $3.0 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$ | 125 kHz ≤ fcpu ≤ 6 MHz               |                                                    |
| -                   | $2.7 \text{ V} \le \text{V}_{DD} < 3.0 \text{ V}$ | 125 kHz ≤ fcpu ≤ 5 MHz               |                                                    |
|                     | $2.0~V \leq V_{\text{DD}} < 2.7~V^{\text{Note}}$  | 125 kHz ≤ fcpu ≤ 2 MHz               | $500 \text{ kHz} \le \text{fxp} \le 5 \text{ MHz}$ |
| High-speed internal | $4.0~V \leq V_{DD} \leq 5.5~V$                    | 500 kHz (TYP.) ≤ fcpu ≤ 8 MHz (TYP.) | 2 MHz (TYP.) $\leq$ fxp $\leq$ 8 MHz (TYP.)        |
| oscillator          | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$ | 500 kHz (TYP.) ≤ fcpu ≤ 4 MHz (TYP.) |                                                    |
|                     | $2.0~V \leq V_{DD} < 2.7~V^{\text{Note}}$         | 500 kHz (TYP.) ≤ fcpu ≤ 2 MHz (TYP.) | 2 MHz (TYP.) $\leq$ fxp $\leq$ 4 MHz (TYP.)        |

Note Use this product in a voltage range of 2.2 to 5.5 V because the detection voltage (VPOC) of the power-on-clear (POC) circuit is 2.1 V  $\pm$ 0.1 V.

TCY vs. VDD (External Clock Input)



Tcy vs. VdD (High-speed internal oscillator Clock)



# **AC Timing Test Points (Excluding EXCLK Input)**



# **Clock Timing**



# Interrupt Input Timing



# **RESET** Input Timing



# POC Circuit Characteristics ( $T_A = -40 \text{ to } +85^{\circ}\text{C}$ )

| Parameter                               | Symbol       | Conditions                                                       | MIN. | TYP. | MAX. | Unit |
|-----------------------------------------|--------------|------------------------------------------------------------------|------|------|------|------|
| Detection voltage                       | VPOC         |                                                                  | 2.0  | 2.1  | 2.2  | V    |
| Power supply rise time                  | <b>t</b> PTH | VDD: $0 \text{ V} \rightarrow 2.1 \text{ V}$                     | 1.5  |      |      | μs   |
| Response delay time 1 Note 1            | tртно        | When power supply rises, after reaching detection voltage (MAX.) |      |      | 3.0  | ms   |
| Response delay time 2 <sup>Note 2</sup> | <b>t</b> PD  | When power supply falls                                          |      |      | 1.0  | ms   |
| Minimum pulse width                     | tpw          |                                                                  | 0.2  |      |      | ms   |

- **Notes 1.** Time required from voltage detection to internal reset release.
  - 2. Time required from voltage detection to internal reset signal generation.

# **POC Circuit Timing**



## LVI Circuit Characteristics ( $T_A = -40 \text{ to } +85^{\circ}\text{C}$ )

| Parameter                                           | Symbol            | Conditions | MIN. | TYP. | MAX. | Unit |
|-----------------------------------------------------|-------------------|------------|------|------|------|------|
| Detection voltage                                   | VLVIO             |            | 4.1  | 4.3  | 4.5  | V    |
|                                                     | V <sub>LVI1</sub> |            | 3.9  | 4.1  | 4.3  | V    |
|                                                     | V <sub>LVI2</sub> |            | 3.7  | 3.9  | 4.1  | V    |
|                                                     | <b>V</b> LVI3     |            | 3.5  | 3.7  | 3.9  | ٧    |
|                                                     | V <sub>LVI4</sub> |            | 3.3  | 3.5  | 3.7  | ٧    |
|                                                     | V <sub>LVI5</sub> |            | 3.15 | 3.3  | 3.45 | V    |
|                                                     | V <sub>LVI6</sub> |            | 2.95 | 3.1  | 3.25 | ٧    |
|                                                     | V <sub>LVI7</sub> |            | 2.7  | 2.85 | 3.0  | ٧    |
|                                                     | V <sub>LVI8</sub> |            | 2.5  | 2.6  | 2.7  | V    |
|                                                     | V <sub>LVI9</sub> |            | 2.25 | 2.35 | 2.45 | V    |
| Response time <sup>Note 1</sup>                     | tld               |            |      | 0.2  | 2.0  | ms   |
| Minimum pulse width                                 | tuw               |            | 0.2  |      |      | ms   |
| Operation stabilization wait time <sup>Note 2</sup> | tlwait            |            |      | 0.1  | 0.2  | ms   |

Notes 1. Time required from voltage detection to interrupt output or internal reset signal generation.

2. Time required from setting LVION to 1 to operation stabilization.

**Remarks 1.**  $V_{LV10} > V_{LV11} > V_{LV12} > V_{LV13} > V_{LV15} > V_{LV16} > V_{LV16} > V_{LV18} > V_{LV19}$ 

**2.**  $V_{POC} < V_{LVIm} (m = 0 \text{ to } 9)$ 

## **LVI Circuit Timing**



## Data Memory STOP Mode Low Supply Voltage Data Retention Characteristics (T<sub>A</sub> = -40 to +85°C)

| Parameter                     | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
|-------------------------------|--------|------------|------|------|------|------|
| Data retention supply voltage | VDDDR  |            | 2.0  |      | 5.5  | ٧    |
| Release signal set time       | tsrel  |            | 0    |      |      | μs   |

Flash Memory Programming Characteristics (T<sub>A</sub> = −40 to +85°C, 2.7 V ≤ V<sub>DD</sub> ≤ 5.5 V, V<sub>SS</sub> = 0 V)

| Parameter                                     | Symbol                              | Condition                                                                          | s                                                             | MIN. | TYP. | MAX. | Unit  |
|-----------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------|------|------|------|-------|
| Supply current                                | I <sub>DD</sub>                     | V <sub>DD</sub> = 5.5 V                                                            |                                                               |      |      | 7.0  | mA    |
| Erasure count <sup>Note 1</sup> (per 1 block) | Nerase                              | T <sub>A</sub> = -40 to +85°C                                                      |                                                               | 1000 |      |      | Times |
| Chip erase time                               | TCERASE                             | $T_A = -10 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$    |      |      | 0.8  | s     |
|                                               |                                     | Nerase ≤ 100                                                                       | $3.5~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.5~\textrm{V}$ |      |      | 1.0  | s     |
|                                               |                                     |                                                                                    | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.5~\textrm{V}$ |      |      | 1.2  | s     |
|                                               |                                     | $T_A = -10 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 4.8  | s     |
|                                               |                                     | Nerase ≤ 1000                                                                      | $3.5~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.5~\textrm{V}$ |      |      | 5.2  | s     |
|                                               |                                     |                                                                                    | 2.7 V ≤ V <sub>DD</sub> < 3.5 V                               |      |      | 6.1  | s     |
|                                               |                                     | $T_A = -40 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 1.6  | s     |
|                                               |                                     | Nerase ≤ 100                                                                       | $3.5 \text{ V} \le \text{V}_{DD} < 4.5 \text{ V}$             |      |      | 1.8  | s     |
|                                               |                                     |                                                                                    | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.5~\textrm{V}$ |      |      | 2.0  | s     |
|                                               |                                     | $T_{\text{A}} = -40 \text{ to } +85^{\circ}\text{C},$ $N_{\text{ERASE}} \leq 1000$ | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 9.1  | s     |
|                                               |                                     |                                                                                    | 3.5 V ≤ V <sub>DD</sub> < 4.5 V                               |      |      | 10.1 | s     |
|                                               |                                     |                                                                                    | 2.7 V ≤ V <sub>DD</sub> < 3.5 V                               |      |      | 12.3 | s     |
| Block erase time                              | TBERASE                             | $T_A = -10 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 0.4  | s     |
|                                               |                                     | Nerase ≤ 100                                                                       | $3.5 \text{ V} \le \text{V}_{DD} < 4.5 \text{ V}$             |      |      | 0.5  | s     |
|                                               |                                     |                                                                                    | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.5~\textrm{V}$ |      |      | 0.6  | s     |
|                                               |                                     | $T_A = -10 \text{ to } +85^{\circ}\text{C},$ Nerase $\leq 1000$                    | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 2.6  | s     |
|                                               |                                     |                                                                                    | $3.5~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.5~\textrm{V}$ |      |      | 2.8  | s     |
|                                               |                                     |                                                                                    | $2.7~V \leq V_{DD} < 3.5~V$                                   |      |      | 3.3  | s     |
|                                               |                                     | $T_A = -40 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 0.9  | s     |
|                                               |                                     | Nerase ≤ 100                                                                       | $3.5~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.5~\textrm{V}$ |      |      | 1.0  | s     |
|                                               |                                     |                                                                                    | $2.7~V \leq V_{DD} < 3.5~V$                                   |      |      | 1.1  | s     |
|                                               |                                     | $T_A = -40 \text{ to } +85^{\circ}\text{C},$                                       | $4.5~V \leq V_{DD} \leq 5.5~V$                                |      |      | 4.9  | s     |
|                                               |                                     | Nerase ≤ 1000                                                                      | $3.5~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.5~\textrm{V}$ |      |      | 5.4  | S     |
|                                               |                                     |                                                                                    | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.5~\textrm{V}$ |      |      | 6.6  | s     |
| Byte write time                               | TWRITE                              | $T_A = -40 \text{ to } +85^{\circ}\text{C}, \text{ Nerase} \leq 1$                 | 000                                                           |      |      | 150  | μs    |
| Internal verify                               | Internal verify TVERIFY Per 1 block |                                                                                    |                                                               |      |      | 6.8  | ms    |
|                                               |                                     | Per 1 byte                                                                         |                                                               |      |      | 27   | μs    |
| Blank check                                   | Твікснк                             | Per 1 block                                                                        |                                                               |      |      | 480  | μs    |
| Retention years                               |                                     | $T_A = 85^{\circ}C^{\text{Note 2}}, \text{ Nerase} \le 1000$                       |                                                               | 10   |      |      | Years |

**Notes 1.** Depending on the erasure count (Nerase), the erase time varies. Refer to the chip erase time and block erase time parameters.

**Remark** When a product is first written after shipment, "erase → write" and "write only" are both taken as one rewrite.

<sup>2.</sup> When the average temperature when operating and not operating is 85°C.

## **CHAPTER 18 PACKAGE DRAWING**

# 10-PIN PLASTIC SSOP (5.72 mm (225))







## NOTE

Each lead centerline is located within 0.13 mm of its true position (T.P.) at maximum material condition.

|      | (UNIT:mm)              |
|------|------------------------|
| ITEM | DIMENSIONS             |
| Α    | 3.60±0.10              |
| В    | 0.50                   |
| С    | 0.65 (T.P.)            |
| D    | 0.24±0.08              |
| E    | 0.10±0.05              |
| F    | 1.45 MAX.              |
| G    | 1.20±0.10              |
| Н    | 6.40±0.20              |
| I    | 4.40±0.10              |
| J    | 1.00±0.20              |
| K    | $0.17^{+0.08}_{-0.07}$ |
| L    | 0.50                   |
| М    | 0.13                   |
| N    | 0.10                   |
| Р    | 3° + 5°                |
| Т    | 0.25 (T.P.)            |
| U    | 0.60±0.15              |
| V    | 0.25 MAX.              |
| W    | 0.15 MAX.              |
|      | P10MA-65-CAC           |

### **CHAPTER 19 RECOMMENDED SOLDERING CONDITIONS**

These products should be soldered and mounted under the following recommended conditions. For technical information, see the following website.

Semiconductor Device Mount Manual (http://www.necel.com/pkg/en/mount/index.html)

- Cautions 1. Products with -A at the end of the part number are lead-free products.
  - 2. For soldering methods and conditions other than those recommended below, contact an NEC Electronics sales representative.

**Table 19-1. Surface Mounting Type Soldering Conditions** 

• 10-pin plastic SSOP (lead-free products)

μPD78F9500MA-CAC-A, 78F9501MA-CAC-A, 78F9502MA-CAC-A

| Soldering Method | Soldering Conditions                                                                                                                                                                          | Recommended<br>Condition Symbol |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow  | Package peak temperature: 260°C, Time: 60 seconds max. (at 220°C or higher), Count: 3 times or less, Exposure limit: 7 days <sup>Note</sup> (after that, prebake at 125°C for 10 to 72 hours) | IR60-107-3                      |
| Wave soldering   | 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).

### APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for development of systems using the  $\mu$ PD78F9500, 78F9501, 78F9502. Figure A-1 shows development tools.

Compatibility with PC98-NX series
 Unless stated otherwise, products which are supported by IBM PC/AT<sup>™</sup> and compatibles can also be used with the PC98-NX series. When using the PC98-NX series, therefore, refer to the explanations for IBM PC/AT and compatibles.

Figure A-1. Development Tools (1/2)

### (1) When using the in-circuit emulator QB-78K0SKX1



- **Notes 1.** The C library source file is not included in the software package.
  - The Project Manager PM+ is included in the assembler package.
     PM+ is used only in the Windows<sup>™</sup> environment.
  - 3. The in-circuit emulator QB-78K0SKX1 is provided with the integrated debugger ID78K0S-QB, the onchip debug emulator with programming function QB-MINI2, a USB interface cable, a power supply unit, and a target cable. Other products are optional.
  - **4.** Under development for the  $\mu$ PD78F9500, 78F9501, 78F9502

Figure A-1. Development Tools (2/2)

## (2) When using the on-chip debug emulator with programming function QB-MINI2



- **Notes 1.** The C library source file is not included in the software package.
  - 2. The Project Manager PM+ is included in the assembler package. PM+ is used only in the Windows environment.
  - **3.** The on-chip debug emulator with programming function QB-MINI2 is provided with a USB interface cable, and a target cable.
  - 4. The integrated debugger ID78K0S-QB is not included with the QB-MINI2. The integrated debugger ID78K0S-QB is available on the following website. http://www.necel.com/micro/ods/eng/
  - **5.** Under development for the  $\mu$ PD78F9500, 78F9501, 78F9502

## A.1 Software Package

| SP78K0S          | This is a package that bundles the software tools required for development of the 78K/0S Series.                                    |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Software package | The following tools are included.                                                                                                   |
|                  | RA78K0S, CC78K0S, ID78K0S-NS, SM+ for 78K0S/Kx1+ <sup>Note 1</sup> , SM78K0S <sup>Note 2</sup> , and device files <sup>Note 3</sup> |
|                  | Part number: μSxxxSP78K0S                                                                                                           |

- Notes 1. SM+ for 78K0S/Kx1+ is not included in SP78K0S Ver. 2.00 or earlier.
  - 2. The SM78K0S does not support the 78K0S/Kx1+.
  - 3. The DF789234 is not included in SP78K0S Ver. 2.00 or earlier.

**Remark** ×××× in the part number differs depending on the operating system to be used.



## A.2 Language Processing Software

| RA78K0S<br>Assembler package | Program that converts program written in mnemonic into object code that can be executed by microcontroller.                                                                      |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | In addition, automatic functions to generate symbol table and optimize branch instructions are also provided. Used in combination with device file (DF789234) (sold separately). |
|                              | <caution environment="" in="" pc="" used="" when=""></caution>                                                                                                                   |
|                              | The assembler package is a DOS-based application but may be used under the Windows environment by using PM+ of Windows (included in the assembler package).                      |
|                              | Part number: µSxxxRA78K0S                                                                                                                                                        |
| CC78K0S<br>C library package | Program that converts program written in C language into object codes that can be executed by microcontroller.                                                                   |
|                              | Used in combination with assembler package (RA78K0S) and device file (DF789234) (both sold separately).                                                                          |
|                              | <caution environment="" in="" pc="" used="" when=""></caution>                                                                                                                   |
|                              | The C compiler package is a DOS-based application but may be used under the Windows environment by using PM+ of Windows (included in the assembler package).                     |
|                              | Part number: µSxxxxCC78K0S                                                                                                                                                       |
| DF789234 <sup>Note 1</sup>   | File containing the information inherent to the device.                                                                                                                          |
| Device file                  | Used in combination with other tools (RA78K0S, CC78K0S, ID78K0S-QB, or SM+ for 78K0S/Kx1+) (all sold separately).                                                                |
|                              | Part number: µSxxxDF789234                                                                                                                                                       |
| CC78K0S-L <sup>Note 2</sup>  | Source file of functions constituting object library included in C compiler package.                                                                                             |
| C library source file        | Necessary for changing object library included in C compiler package according to customer's specifications.                                                                     |
|                              | Since this is the source file, its working environment does not depend on any particular operating system.                                                                       |
|                              | Part number: µSxxxxCC78K0S-L                                                                                                                                                     |

- **Notes 1.** DF789234 is a common file that can be used with RA78K0S, CC78K0S, ID78K0S-QB and SM+ for 78K0S/Kx1+.
  - 2. CC78K0S-L is not included in the software package (SP78K0S).

 $\begin{array}{l} \mu \text{S} \times \times \times \text{RA78K0S} \\ \mu \text{S} \times \times \times \text{CC78K0S} \\ \mu \text{S} \times \times \times \times \text{CC78K0S-L} \end{array}$ 

| ×××× | Host Machine                               | os                                                                  | Supply Media |  |
|------|--------------------------------------------|---------------------------------------------------------------------|--------------|--|
| AB17 | PC-9800 series, IBM PC/AT Japanese Windows |                                                                     | CD-ROM       |  |
| BB17 | and compatibles                            | d compatibles English Windows                                       |              |  |
| 3P17 | HP9000 series 700 <sup>™</sup>             | HP-UX <sup>™</sup> (Rel.10.10)                                      |              |  |
| 3K17 | SPARCstation™                              | SunOS <sup>™</sup> (Rel.4.1.4),<br>Solaris <sup>™</sup> (Rel.2.5.1) |              |  |

 $\mu$ S $\times \times \times$ DF789234

| ×××× | Host Machine              | OS               | Supply Media |
|------|---------------------------|------------------|--------------|
| AB13 | PC-9800 series, IBM PC/AT | Japanese Windows | 3.5" 2HD FD  |
| BB13 | and compatibles           | English Windows  |              |

#### A.3 Control Software

| PM+             | This is control software designed so that the user program can be efficiently developed  |
|-----------------|------------------------------------------------------------------------------------------|
| Project manager | in the Windows environment. With this software, a series of user program                 |
|                 | development operations, including starting the editor, build, and starting the debugger, |
|                 | can be executed on the PM+.                                                              |
|                 | <caution></caution>                                                                      |
|                 | The PM+ is included in the assembler package (RA78K0S). It can be used only in the       |
|                 | Windows environment.                                                                     |

#### A.4 Flash Memory Writing Tools

FlashPro4 (FL-PR4, PG-FP4) Flash memory programmer dedicated to the microcontrollers incorporating a flash <R> FlashPro5 (FL-PR5, PG-FP5) memory Flash memory programmer QB-MINI2 This is a flash memory programmer dedicated to microcontrollers incorporating a flash On-chip debug emulator with memory. It is available also as an on-chip debug emulator which serves to debug programming function hardware and software when developing application systems using all flash microcontrollers (including the 78K0S/Kx1+). FA-78F9202MA-CAC-MX Flash memory writing adapter. Used in connection with the flash memory Flash memory writing adapter programmer.

**Remark** FL-PR4, FL-PR5, and FA-78F9202MA-CAC-MX are products of Naito Densei Machida Mfg. Co., Ltd. For further information, contact: Naito Densei Machida Mfg. Co., Ltd. (TEL +81-42-750-4172)

## A.5 Debugging Tools (Hardware)

## A.5.1 When using in-circuit emulator QB-78K0SKX1

| QB-78K0SKX1<br>In-circuit emulator            | This in-circuit emulator serves to debug hardware and software when developing application systems using the 78K0S/Kx1+. It supports the integrated debugger (ID78K0S-QB). It is connected to the included AC adapter, target cable, and host machine via a USB interface cable. |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QB-50-EP-01T<br>Emulation probe               | This emulation probe is a flexible type and is used to connect the in-circuit emulator and target system.                                                                                                                                                                        |
| QB-10MA-EA-01T<br>Exchange adapter            | This exchange adapter is used to perform pin conversion from the in-circuit emulator to target connector.                                                                                                                                                                        |
| QB-10MA-NQ-01T<br>Target connector            | This target connector is used to mount on the target system.                                                                                                                                                                                                                     |
| Specifications of pin header on target system | 0.635 mm × 0.635 mm (height: 6 mm)                                                                                                                                                                                                                                               |

## A.5.2 When using on-chip debug emulator QB-MINI2

| QB-MINI2 On-chip debug emulator with programming function | This is an on-chip debug emulator which serves to debug hardware and software when developing application systems using all flash microcontrollers (including the 78K0S/Kx1+). It is available also as a flash memory programmer dedicated to microcontrollers incorporating a flash memory. |
|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Specifications of pin header on target system             | 16-pin general-purpose connector (2.54 mm pitch)                                                                                                                                                                                                                                             |

## A.6 Debugging Tools (Software)

| ID78K0S-QB<br>(supporting QB-78K0SKX1<br>and QB-MINI2)<br>Integrated debugger<br>(accessory) | This debugger supports the in-circuit emulators for the 78K0S/Kx1+ Series. ID78K0S-QB is Windows-based software.  Provided with the debug function supporting C language, source programming, disassemble display, and memory display are possible. This is used with the device file (DF789234) (sold separately).  It is provided with the in-circuit emulator QB-78K0SKX1.                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                              | Ordering number: μSxxxID78K0S-QB (not for sale)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SM+ for 78K0S/Kx1+ <sup>Note 1</sup> System simulator                                        | This is a system simulator for the 78K/0S series. SM+ for 78K0S/Kx1+ is Windows-based software.  This simulator can execute C-source-level or assembler-level debugging while simulating the operations of the target system on the host machine.  By using SM+ for 78K0S/Kx1+, the logic and performance of the application can be verified independently of hardware development. Therefore, the development efficiency can be enhanced and the software quality can be improved.  This simulator is used with a device file (DF789234) (sold separately). |
|                                                                                              | Part number: μSxxxxSM789234-B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DF789234 <sup>Note 2</sup> Device file                                                       | This is a file that has device-specific information.  It is used with the RA78K0S, CC78K0S, ID78K0S-QB, and SM+ for 78K0S/Kx1+  (all sold separately).                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                              | Part number: μSxxxDF789234                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Notes 1.** Under development for the  $\mu$ PD78F9500, 78F9501, 78F9502

**2.** DF789234 is a common file that can be used with the RA78K0S, CC78K0S, ID78K0S-QB, and SM+ for 78K0S/Kx1+.

<R>

This chapter shows areas on the target system where component mounting is prohibited and areas where there are component mounting height restrictions when the QB-78K0SKX1 is used.

For the package drawings of the target connector, exchange adapter, and emulation probe, see the following website.

http://www.necel.com/micro/en/development/asia/iecube/outline\_QB.html

Figure B-1. When using the 78K0S/Kx1+ emulation probe (For 10-Pin MA Package)



] : Exchange adapter tip area ightarrow Components up to 3.5 mm high can be mounted.

 $\blacksquare$ : Exchange adapter mounted-component area  $\rightarrow$  Components up to 2.0 mm high can be mounted.

: Target connector area

## Overview



Note EP: Emulation probe

EA: Exchange adapter

TC: Target connector

Figure B-2. When using the 78K0S/Kx1+ target cable (single track)



- $\Box$ : A interval pin header  $\rightarrow$  More than 2.54mm
- $\square$ : A contact area of a pin header  $\rightarrow$  0.635  $\times$  0.635mm (Height: 6mm)

## Overview



#### APPENDIX C REGISTER INDEX

## C.1 Register Index (Register Name) 8-bit timer H compare register 01 (CMP01) ... 74 8-bit timer H compare register 11 (CMP11) ... 74 8-bit timer H mode register 1 (TMHMD1) ... 75 [E] External interrupt mode register 0 (INTM0) ... 101 [F] Flash address pointer H compare register (FLAPHC)... 152 Flash address pointer L compare register (FLAPLC) ... 152 Flash address pointer H (FLAPH) ... 152 Flash address pointer L (FLAPL) ... 152 Flash programming command register (FLCMD) ... 151 Flash programming mode control register (FLPMC) ... 147 Flash protect command register (PFCMD) ... 148 Flash status register (PFS) ... 149 Flash write buffer register (FLW) ... 153 Ш Interrupt mask flag register 0 (MK0) ... 101 Interrupt request flag register 0 (IF0) ... 100 [L] Low-speed internal oscillation mode register (LSRCM) ... 64 Low-voltage detect register (LVIM) ... 124 Low-voltage detection level select register (LVIS) ... 125 [P] Port mode register 2 (PM2) ... 56, 77 Port mode register 3 (PM3) ... 56 Port mode register 4 (PM4) ... 56 Port register 2 (P2) ... 57 Port register 3 (P3) ... 57 Port register 4 (P4) ... 57 Preprocessor clock control register (PPCC) ... 63 Processor clock control register (PCC) ... 63 Pull-up resistor option register 2 (PU2) ... 58

#### [R]

Reset control flag register (RESF) ... 118

Pull-up resistor option register 3 (PU3) ... 58 Pull-up resistor option register 4 (PU4) ... 58

#### [W]

Watchdog timer enable register (WDTE) ... 91 Watchdog timer mode register (WDTM) ... 90

## C.2 Register Index (Symbol)

[C]

CMP01: 8-bit timer H compare register 01 ... 74
CMP11: 8-bit timer H compare register 11 ... 74

[F]

FLAPH: Flash address pointer H ... 152

FLAPHC: Flash address pointer H compare register ... 152

FLAPL: Flash address pointer L ... 152

FLAPLC: Flash address pointer L compare register ... 152
FLCMD: Flash programming command register ... 151
FLPMC: Flash programming mode control register ... 147

FLW: Flash write buffer register ... 153

[1]

IF0: Interrupt request flag register 0 ... 100
INTM0: External interrupt mode register 0 ... 101

[L]

LSRCM: Low-speed internal oscillation mode register ... 64

LVIM: Low-voltage detect register ... 124

LVIS: Low-voltage detection level select register ... 125

[M]

MK0: Interrupt mask flag register 0 ... 101

[P]

P2: Port register 2 ... 57
P3: Port register 3 ... 57
P4: Port register 4 ... 57

PCC: Processor clock control register ... 63
PFCMD: Flash protect command register ... 148

PFS: Flash status register ... 149
PM2: Port mode register 2 ... 56, 77
PM3: Port mode register 3 ... 56
PM4: Port mode register 4 ... 56

PPCC: Preprocessor clock control register ... 63
PU2: Pull-up resistor option register 2 ... 58
PU3: Pull-up resistor option register 3 ... 58
PU4: Pull-up resistor option register 4 ... 58

[R]

RESF: Reset control flag register ... 118

[T]

TMHMD1: 8-bit timer H mode register 1 ... 75

[W]

WDTE: Watchdog timer enable register ... 91
WDTM: Watchdog timer mode register ... 90

## APPENDIX D LIST OF CAUTIONS

This appendix lists cautions described in this document.

"Classification (hard/soft)" in table is as follows.

Hard: Cautions for microcontroller internal/external hardware
Soft: Cautions for software such as register settings or programs

|           |                |                   |                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | (                                                                                                                                                      | 1/7)  |  |
|-----------|----------------|-------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|
| Chapter   | Classification | Function          | Details of<br>Function                            | Cautions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Page                                                                                                                                                   | 9     |  |
| Chapter 2 | Hard           | Pin<br>functions  | P22,<br>P23/EXCLK,<br>P34/RESET                   | The P22 and P23/EXCLK pins are pulled down during reset. The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit.                                                                                                                                                                                                                                                                                                                                                                              | pp. 19-<br>21                                                                                                                                          |       |  |
| Chapter 3 | Soft           | Memory space      | SP: stack pointer                                 | Since reset signal generation makes the SP contents undefined, be sure to initialize the SP before using the stack memory.                                                                                                                                                                                                                                                                                                                                                                                                          | p. 32                                                                                                                                                  |       |  |
| Cha       |                |                   |                                                   | Stack pointers can be set only to the high-speed RAM area, and only the lower 10 bits can be actually set.  0FF00H is in the SFR area, not the high-speed RAM area, so it was converted to 0FB00H that is in the high-speed RAM area. When the value is actually pushed onto the stack, 1 is subtracted from 0FB00H to become 0FAFFH, but that value is not in the high-speed RAM area, so it is converted to 0FEFFH, which is the same value as when 0FF00H is set to the stack pointer.                                           | p. 32                                                                                                                                                  |       |  |
| Chapter 4 | Hard           | Port functions    | Port functions                                    | P22,<br>P23/EXCLK,<br>P34/RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | The P22 and P23/EXCLK pins are pulled down during reset. The P34/RESET pin is pulled up during reset by the reset pin function/power-on clear circuit. | p. 48 |  |
| 0         |                |                   | P34                                               | Because the P34 pin functions alternately as the RESET pin, if it is used as an input port pin, the function to input an external reset signal to the RESET pin cannot be used. The function of the port is selected by the option byte. For details, refer to CHAPTER 13 OPTION BYTE.  Also, since the option byte is referenced after the reset release, if low level is input to the RESET pin before the referencing, then the reset state is not released. When it is used as an input port pin, connect the pull-up resistor. | p. 54                                                                                                                                                  |       |  |
|           |                |                   | P21, P32                                          | Because P21 and P32 are also used as external interrupt pins, the corresponding interrupt request flag is set if each of these pins is set to the output mode and its output level is changed. To use the port pin in the output mode, therefore, set the corresponding interrupt mask flag to 1 in advance.                                                                                                                                                                                                                        | p. 56                                                                                                                                                  |       |  |
|           |                |                   | -                                                 | Although a 1-bit memory manipulation instruction manipulates 1 bit, it accesses a port in 8-bit units. Therefore, the contents of the output latch of a pin in the input mode, even if it is not subject to manipulation by the instruction, are undefined in a port with a mixture of inputs and outputs.                                                                                                                                                                                                                          | p. 59                                                                                                                                                  |       |  |
| Chapter 6 | Soft           | 8-bit timer<br>H1 | CMP01: 8-bit<br>timer H<br>compare<br>register 01 | CMP01 cannot be rewritten during timer count operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | p. 74                                                                                                                                                  |       |  |

(2/7)**Function** Details of Cautions Page Classification Chapter **Function** Soft CMP11: 8-bit 8-bit timer In the PWM output mode, be sure to set CMP11 when starting the timer count p. 74 H1 timer H operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) compare (be sure to set again even if setting the same value to CMP11). register 11 TMHMD1: 8-bit When TMHE1 = 1, setting the other bits of the TMHMD1 register is prohibited. p. 76 timer H mode In the PWM output mode, be sure to set 8-bit timer H compare register 11 p. 76 register 1 (CMP11) when starting the timer count operation (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register). Hard PWM output In PWM output mode, the setting value for the CMP11 register can be changed p. 82 during timer count operation. However, three operation clocks (signal selected using the CKS12 to CKS10 bits of the TMHMD1 register) or more are required to transfer the register value after rewriting the CMP11 register value. Soft Be sure to set the CMP11 register when starting the timer count operation p. 82 (TMHE1 = 1) after the timer count operation was stopped (TMHE1 = 0) (be sure to set again even if setting the same value to the CMP11 register). Make sure that the CMP11 register setting value (M) and CMP01 register setting p. 82 value (N) are within the following range.  $00H \le CMP11 (M) < CMP01 (N) \le FFH$ Watchdog Soft WDTM: Set bits 7, 6, and 5 to 0, 1, and 1, respectively. Do not set the other values. p. 90 Chapter timer Watchdog timer p. 91 After reset is released, WDTM can be written only once by an 8-bit memory mode register manipulation instruction. If writing is attempted a second time, an internal reset signal is generated. However, at the first write, if "1" and "x" are set for WDCS4 and WDCS3 respectively and the watchdog timer is stopped, then the internal reset signal does not occur even if the following are executed. • Second write to WDTM • 1-bit memory manipulation instruction to WDTE • Writing of a value other than "ACH" to WDTE WDTM cannot be set by a 1-bit memory manipulation instruction. p. 91 When using the flash memory self programming by self writing, set the overflow p. 91 time for the watchdog timer so that enough overflow time is secured (Example 1byte writing: 200  $\mu$ s MIN., 1-block deletion: 10 ms MIN.). WDTE: If a value other than ACH is written to WDTE, an internal reset signal is p. 91 Watchdog timer generated. enable register If a 1-bit memory manipulation instruction is executed for WDTE, an internal reset p. 91 signal is generated. The value read from WDTE is 9AH (this differs from the written value (ACH)). p. 91 Hard When "low-In this mode, operation of the watchdog timer cannot be stopped even during p. 92 speed internal STOP instruction execution. For 8-bit timer H1 (TMH1), a division of the lowoscillator cannot speed internal oscillation clock can be selected as the count source, so clear the be stopped" is watchdog timer using the interrupt request of TMH1 before the watchdog timer selected by overflows after STOP instruction execution. If this processing is not performed, option byte an internal reset signal is generated when the watchdog timer overflows after STOP instruction execution. when "low-In this mode, watchdog timer operation is stopped during HALT/STOP instruction p. 94 speed internal execution. After HALT/STOP mode is released, counting is started again using oscillator can be the operation clock of the watchdog timer set before HALT/STOP instruction stopped by execution by WDTM. At this time, the counter is not cleared to 0 but holds its software" is value. selected by option byte

(3/7)Function Classification Details of Cautions Page Chapter **Function** Soft Chapter 8 Interrupt IF0: Interrupt Because P21 and P32 have an alternate function as external interrupt inputs, pp. 100, functions request flag when the output level is changed by specifying the output mode of the port 101 registers, function, an interrupt request flag is set. Therefore, the interrupt mask flag should be set to 1 before using the output mode. MK0: Interrupt mask flag registers INTM0: External Be sure to clear bits 0, 1, 6, and 7 to 0. p. 101 interrupt mode p. 102 Before setting the INTM0 register, be sure to set the corresponding interrupt mask register 0 flag ( $\times \times MK \times = 1$ ) to disable interrupts. After setting the INTM0 register, clear the interrupt request flag ( $\times \times IF \times = 0$ ), then clear the interrupt mask flag ( $\times \times MK \times = 0$ ), which will enable interrupts. Interrupt Interrupt requests will be held pending while the interrupt request flag registers p. 104 requests are (IF0) or interrupt mask flag registers (MK0) are being accessed. held pending p. 105 Interrupt Multiple interrupts can be acknowledged even for low-priority interrupts. request pending Soft Standby The LSRSTOP setting is valid only when "Can be stopped by software" is set for p. 107 Chapter Function the low-speed internal oscillator by the option byte. Hard STOP mode When shifting to the STOP mode, be sure to stop the peripheral hardware p. 108 operation before executing STOP instruction (except the peripheral hardware that operates on the low-speed internal oscillation clock). If the low-speed internal oscillator is operating before the STOP mode is set, p. 108 oscillation of the low-speed internal oscillation clock cannot be stopped in the STOP mode (refer to Table 9-1). HALT mode Soft Because an interrupt request signal is used to clear the standby mode, if there is p. 109 setting and an interrupt source with the interrupt request flag set and the interrupt mask flag clear, the standby mode is immediately cleared if set. operating statuses STOP mode p. 111 Because an interrupt request signal is used to clear the standby mode, if there is setting and an interrupt source with the interrupt request flag set and the interrupt mask flag operating reset, the standby mode is immediately cleared if set. Thus, in the STOP mode, statuses the normal operation mode is restored after the STOP instruction is executed and then the operation is stopped for 34  $\mu s$  (TYP.). Hard p. 114 Reset For an external reset, input a low level for 2  $\mu$ s or more to the  $\overline{RESET}$  pin. Chapter 10 function During reset signal generation, the system clock and low-speed internal oscillation p. 114 clock stop oscillating. When the  $\overline{\text{RESET}}$  pin is used as an input-only port pin (P34), the  $\mu$ PD78F9500, p. 114 78F9501, 78F9502 is reset if a low level is input to the RESET pin after reset is released by the POC circuit, the LVI circuit and the watchdog timer and before the option byte is referenced again. The reset status is retained until a high level is input to the RESET pin. The LVI circuit is not reset by the internal reset signal of the LVI circuit. p. 115 p. 116 Timing of reset The watchdog timer is also reset in the case of an internal reset of the watchdog by overflow of watchdog timer RESF: Reset Do not read data by a 1-bit memory manipulation instruction. p. 118 L control flag register

(4/7)

|            |                | 1                           | ,                                             |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                     | (4   | 1/7)                                                                                                                                    |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|------------|----------------|-----------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|--|--|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|--|
| Chapter    | Classification | Function                    | Details of<br>Function                        | Cautions                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                     | Page |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
| Chapter 11 | Soft           | Power-<br>on-clear          | Functions of power-on-clear                   | If an internal reset signal is generated in the POC circuit, the reset control flag register (RESF) is cleared to 00H.                                                                                                                                                                                                                                                                    | p. <sup>-</sup>                                                                                                                                                                                                                                     | 119  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
| Chap       | Hard           | circuit                     | circuit                                       | Because the detection voltage (V <sub>POC</sub> ) of the POC circuit is in a range of 2.1 V $\pm$ 0.1 V, use a voltage in the range of 2.2 to 5.5 V.                                                                                                                                                                                                                                      | p. <sup>-</sup>                                                                                                                                                                                                                                     | 119  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            | Soft           |                             | Cautions for power-on-clear circuit           | In a system where the supply voltage (V <sub>DD</sub> ) fluctuates for a certain period in the vicinity of the POC detection voltage (V <sub>POC</sub> ), the system may be repeatedly reset and released from the reset status. In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking the following action. | p. <sup>-</sup>                                                                                                                                                                                                                                     | 121  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
| Chapter 12 | Soft           | Low-<br>voltage<br>detector | LVIM: Low-<br>voltage detect<br>register      | To stop LVI, follow either of the procedures below.  • When using 8-bit manipulation instruction: Write 00H to LVIM.  • When using 1-bit memory manipulation instruction: Clear LVION to 0.                                                                                                                                                                                               | p. <sup>-</sup>                                                                                                                                                                                                                                     | 124  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
| Γ          |                |                             |                                               | Be sure to set bits 2 to 6 to 0.                                                                                                                                                                                                                                                                                                                                                          | p. <sup>-</sup>                                                                                                                                                                                                                                     | 124  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             | LVIS: Low-                                    | Bits 4 to 7 must be set to 0.                                                                                                                                                                                                                                                                                                                                                             | p. <sup>-</sup>                                                                                                                                                                                                                                     | 125  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             | voltage<br>detection level<br>select register | If a value other than the above is written during LVI operation, the value becomes undefined at the very moment it is written, and thus be sure to stop LVI (bit 7 (LVION) = 0 on the LVIM register) before writing.                                                                                                                                                                      | p. <sup>-</sup>                                                                                                                                                                                                                                     | 125  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             |                                               |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                     |      |                                                                                                                                         |                 |     |  |  | When used as reset | <1> must always be executed. When LVIMK = 0, an interrupt may occur immediately after the processing in <3>.                                                                                                                                             | p. <sup>-</sup> | 126 |  |
|            |                |                             |                                               |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                     |      | If supply voltage ( $V_{DD}$ ) $\geq$ detection voltage ( $V_{LVI}$ ) when LVIM is set to 1, an internal reset signal is not generated. | p. <sup>-</sup> | 126 |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             |                                               | Cautions for<br>low-voltage<br>detector                                                                                                                                                                                                                                                                                                                                                   | In a system where the supply voltage ( $V_{DD}$ ) fluctuates for a certain period in the vicinity of the LVI detection voltage ( $V_{LVI}$ ), the operation is as follows depending on how the low-voltage detector is used. <1> When used as reset | p. · | 130                                                                                                                                     |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             |                                               |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                     |      |                                                                                                                                         |                 |     |  |  |                    | The system may be repeatedly reset and released from the reset status.  In this case, the time from release of reset to the start of the operation of the microcontroller can be arbitrarily set by taking action (1) below.  <2> When used as interrupt |                 |     |  |
|            | _              | 0 "                         | 0                                             | Interrupt requests may be frequently generated. Take (b) of action (2) below.                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                     |      | $\overline{}$                                                                                                                           |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
| Chapter 13 | Hard           | Option<br>byte              | Control of RESET pin                          | Because the option byte is referenced after reset release, if a low level is input to the RESET pin before the option byte is referenced, then the reset state is not released.  When used as an input-only port (P34), the setting of the on-chip pull-up resistor can be done by PU34 on PU3 register.                                                                                  | p. <sup>-</sup>                                                                                                                                                                                                                                     | 134  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             | Selection of<br>system clock<br>source        | Because the EXCLK pin is also used as the P23 pin, the condition under which the EXCLK pin can be used differ depending on the selected system clock source.  (1) External clock input is selected  Because the pin is used as an external clock input pin, P23 cannot be used as an I/O port pin.  (2) High-speed internal oscillation clock is selected                                 | p                                                                                                                                                                                                                                                   | 134  |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |
|            |                |                             |                                               | P23 pin can be used as an I/O port pin.                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                     |      |                                                                                                                                         |                 |     |  |  |                    |                                                                                                                                                                                                                                                          |                 |     |  |

| _          |                |                 | T                                | <del>,</del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ı                                                                                           | (5/7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|------------|----------------|-----------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|
| Chapter    | Classification | Function        | Details of<br>Function           | Cautions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Pag                                                                                         | je                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
| Chapter 13 | Hard           | Option byte     | Low-speed internal               | If it is selected that low-speed internal oscillator cannot be stopped, the count clock to the watchdog timer (WDT) is fixed to low-speed internal oscillation clock.                                                                                                                                                                                                                                                                                                                                                                                  | p. 135                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
| Cha        |                |                 | oscillates                       | If it is selected that low-speed internal oscillator can be stopped by software, supply of the count clock to WDT is stopped in the HALT/STOP mode, regardless of the setting of bit 0 (LSRSTOP) of the low-speed internal oscillation mode register (LSRCM). Similarly, clock supply is also stopped when a clock other than the low-speed internal oscillation clock is selected as a count clock to WDT. While the low-speed internal oscillator is operating (LSRSTOP = 0), the clock can be supplied to the 8-bit timer H1 even in the STOP mode. | p. 135                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Caution When<br>the RESET Pin<br>Is Used as an<br>Input-Only Port<br>Pin (P34)              | Be aware of the following when erasing/writing by on-board programming using a dedicated flash memory programmer once again on the already-written device which has been set as "The RESET pin is used as an input-only port pin (P34)" by the option byte function.  Before supplying power to the target system, connect a dedicated flash memory programmer and turn its power on. If the power is supplied to the target system beforehand, it cannot be switched to the flash memory programming mode. | p. 135                                                                                                                                                                                                                                                                                                                  |                      |                                                                                                                                                                                                                                                                                          |        |  |
| Chapter 14 | Soft           | Flash<br>memory |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 8                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         | Security<br>settings | After the security setting of the batch erase is set, erasure cannot be performed for the device. In addition, even if a write command is executed, data different from that which has already been written to the flash memory cannot be written because the erase command is disabled. | p. 143 |  |
|            |                |                 |                                  | Self programming                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Self programming processing must be included in the program before performing self writing. | p. 144                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 | executed. There that the watchdo | No instructions can be executed while a self programming command is being executed. Therefore, clear and restart the watchdog timer counter in advance so that the watchdog timer does not overflow during self programming. Refer to Table 14-8 for the time taken for the execution of self programming.                                                                                                                                                                                                                                             | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Interrupts that occur during self programming can be acknowledged after self programming mode ends. To avoid this operation, disable interrupt servicing (by setting MK0 to FFH, and executing the DI instruction) before a mode is shifted from the normal mode to the self programming mode with a specific sequence. | p. 147               |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | RAM is not used while a self programming command is being executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | If the supply voltage drops or the reset signal is input while the flash memory is being written or erased, writing/erasing is not guaranteed.                                                                                                                                                                                                                                                                                                                                                                                                         | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | The value of the blank data set during block erasure is FFH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | Set the CPU clock so that it is 1 MHz or more during self programming.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | Execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, then execute self programming. At this time, the HALT instruction is automatically released after 10 $\mu$ s (MAX.) + 2 CPU clocks (fcPu).                                                                                                                                                                                                                                                                                         | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | If the clock of the oscillator or an external clock is selected as the system clock, execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, wait for 8 $\mu$ s after releasing the HALT status, and then execute self programming.                                                                                                                                                                                                                                                        | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  | Check FPRERR using a 1-bit memory manipulation instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | p. 147                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |
|            |                |                 |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | The state of the pins in self programming mode is the same as that in HALT mode.            | p. 147                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                         |                      |                                                                                                                                                                                                                                                                                          |        |  |

(6/7)**Function** Classification Details of Cautions Page Chapter **Function** Soft Flash Self Since the security function set via on-board/off-board programming is disabled in p. 147 Chapter memory programming self programming mode, the self programming command can be executed function regardless of the security function setting. To disable write or erase processing during self programming, set the protect byte. Be sure to clear bits 4 to 7 of flash address pointer H (FLAPH) and flash address p. 147 pointer H compare register (FLAPHC) to 0 before executing the self programming command. If the value of these bits is 1 when executing the self programming command, there is a possibility that device does not operate normally. Clear the value of the FLCMD register to 00H immediately before setting selfp. 147 programming mode and normal operation mode. FLPMC: Flash Cautions in the case of setting the self programming mode, refer to 14.8.2 p. 148 Cautions on self programming function. programming mode control Set the CPU clock so that it is 1 MHz or more during self programming. p. 148 register p. 148 Execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, then execute self programming. At this time, the HALT instruction is automatically released after 10  $\mu$ s (MAX.) + 2 CPU clocks (fcpu). p. 148 If the clock of the oscillator or an external clock is selected as the system clock, execute the NOP and HALT instructions immediately after executing a specific sequence to set self-programming mode, wait for 8  $\mu$ s after releasing the HALT status, and then execute self programming. Clear the value of the FLCMD register to 00H immediately before setting selfp. 148 programming mode and normal operation mode. PFCMD: Flash Interrupt servicing cannot be executed in self-programming mode. Disable p. 149 protect interrupt servicing (by executing the DI instruction while MK0 and MK1 = FFH) command before executing the specific sequence that sets self-programming mode and register after executing the specific sequence that changes the mode to the normal mode. PFS: Flash Check FPRERR using a 1-bit memory manipulation instruction. p. 149 status register FLAPH, Be sure to clear bits 4 to 7 of FLAPH and FLAPHC to 0 before executing the self p. 152 FLAPL: Flash programming command. If the self programming command is executed with these address bits set to 1, the device may malfunction. pointers H and FLAPHC, Be sure to clear bits 4 to 7 of FLAPH and FLAPHC to 0 before executing the self p. 152 FLAPLC: Flash programming command. If the self programming command is executed with these address pointer bits set to 1, the device may malfunction. H/L compare p. 152 Set the number of the block subject to a block erase, verify, or blank check (same registers value as FLAPH) to FLAPHC. Clear FLAPLC to 00H when a block erase is performed, and FFH when a blank p. 152 check is performed.

233

|            |                |                              |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                             |                            | (7/7)    |
|------------|----------------|------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------|
| Chapter    | Classification | Function                     | Details of<br>Function                                                                                           | Cautions                                                                                                                                                                                                                                                                                                                                                    | Pag                        | е        |
| Chapter 14 | Soft           | Flash<br>memory              | Shifting to self<br>programming<br>mode<br>Shifting to<br>normal mode                                            | Be sure to perform the series of operations described above using the user program at an address where data is not erased or written.                                                                                                                                                                                                                       | pp. 154,<br>155, 15<br>158 |          |
|            |                |                              | Byte write                                                                                                       | If a write results in failure, erase the block once and write to it again.                                                                                                                                                                                                                                                                                  | p. 166                     | <u> </u> |
| Chapter 15 | Hard           | On-chip<br>debug<br>function | Connecting QB-MINI2 to $\mu$ PD78F9500, 78F9501, 78F9502                                                         | Do not use the on-chip debug function in products designated for mass production, because the guaranteed number of rewritable times of the flash memory may be exceeded when this function is used, and product reliability therefore cannot be guaranteed. NEC Electronics is not liable for problems occurring when the on-chip debug function is used.   | p. 190                     |          |
|            |                |                              |                                                                                                                  | The constants described in the circuit connection example are reference values. If you perform flash programming aiming at mass production, thoroughly evaluate whether the specifications of the target device are satisfied.                                                                                                                              | p. 190                     |          |
|            |                |                              | For the case where QB-MINI2 is used for debugging and debugging of INTP1 pin is performed only with real machine | If debugging is performed with a real machine running, without using QB-MINI2, write the user program using the QB-Programmer. Programs downloaded by the debugger include the monitor program, and such a program malfunctions if it is not controlled via QB-MINI2.                                                                                       | p. 192                     |          |
| Chapter 17 | Hard           | Electrical specificati ons   | Absolute<br>maximum<br>ratings                                                                                   | 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. | p. 204                     |          |
| Chapter 19 | Hard           | Recom-                       | Lead-free                                                                                                        | Products with -A at the end of the part number are lead-free products.                                                                                                                                                                                                                                                                                      | p. 215                     |          |
|            |                | mended                       | products                                                                                                         |                                                                                                                                                                                                                                                                                                                                                             |                            | _        |
|            |                | soldering conditions         | -                                                                                                                | For soldering methods and conditions other than those recommended below, contact an NEC Electronics sales representative.                                                                                                                                                                                                                                   | p. 215                     |          |
|            |                |                              |                                                                                                                  | Do not use different soldering methods together (except for partial heating).                                                                                                                                                                                                                                                                               | p. 215                     |          |

## APPENDIX E REVISION HISTORY

## **E.1 Major Revisions in This Edition**

| Page         | Description                                                                                                                           |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| p. 50        | Modification of Figure 4-2 Block Diagram of P20 and P21                                                                               |  |
| p. 52        | Modification of Figure 4-4 Block Diagram of P23                                                                                       |  |
| p. 114       | CHAPTER 10 RESET FUNCTION                                                                                                             |  |
|              | Modification of Caution 3                                                                                                             |  |
| p. 138       | 14.4 Writing with Flash Memory Programmer                                                                                             |  |
|              | Addition of FlashPro5 to Dedicated flash memory programmer                                                                            |  |
|              | Deletion of PG-FPL2 from Dedicated flash memory programmer                                                                            |  |
|              | Modification of Remark                                                                                                                |  |
| pp. 139, 140 | 14.5 Programming Environment                                                                                                          |  |
|              | • Modification of Figure 14-2 Environment for Writing Program to Flash Memory (FlashPro4/FlashPro5/QB-MINI2) and addition of Note     |  |
|              | • Modification of Table 14-2 Wiring Between $\mu$ PD78F9500, 78F9501, 78F9502 and FlashPro4/FlashPro5/QB-MINI2 and Addition of Note 2 |  |
|              | Modification of Figure 14-3 Wiring diagram with FlashPro4/FlashPro5/QB-MINI2                                                          |  |
|              | Deletion of PG-FPL2 from dedicated flash memory programmer                                                                            |  |
| p. 142       | Modification of Figure 14-5 Communication Commands                                                                                    |  |
| p. 146       | Addition of Note in Table 14-8 Self Programming Controlling Commands                                                                  |  |
| p. 190       | Addition of CHAPTER 15 ON-CHIP DEBUG FUNCTION                                                                                         |  |
| pp. 205, 206 | CHAPTER 17 ELECTRICAL SPECIFICATIONS                                                                                                  |  |
|              | Modification of High-Speed Internal Oscillator Characteristics                                                                        |  |
|              | • Modification of Input voltage, high (V <sub>IH1</sub> ) and Input voltage, low (V <sub>IL1</sub> ) of <b>DC Characteristics</b>     |  |
| p. 220       | A.4 Flash Memory Writing Tools                                                                                                        |  |
|              | Addition of FlashPro5                                                                                                                 |  |
|              | Deletion of PG-FPL2                                                                                                                   |  |
| p. 223       | Addition of APPENDIX B NOTES ON DESIGNING TARGET SYSTEM                                                                               |  |
| p. 235       | Addition of APPENDIX E REVISION HISTORY                                                                                               |  |

# For further information, please contact:

#### **NEC Electronics Corporation**

1753, Shimonumabe, Nakahara-ku, Kawasaki, Kanagawa 211-8668, Japan Tel: 044-435-5111 http://www.necel.com/

#### [America]

#### **NEC Electronics America, Inc.**

2880 Scott Blvd. Santa Clara, CA 95050-2554, U.S.A. Tel: 408-588-6000 800-366-9782 http://www.am.necel.com/

#### [Europe]

## **NEC Electronics (Europe) GmbH**

Arcadiastrasse 10 40472 Düsseldorf, Germany Tel: 0211-65030 http://www.eu.necel.com/

#### **Hanover Office**

Podbielskistrasse 166 B 30177 Hannover Tel: 0 511 33 40 2-0

#### **Munich Office**

Werner-Eckert-Strasse 9 81829 München Tel: 0 89 92 10 03-0

#### **Stuttgart Office**

Industriestrasse 3 70565 Stuttgart Tel: 0 711 99 01 0-0

## United Kingdom Branch

Cygnus House, Sunrise Parkway Linford Wood, Milton Keynes MK14 6NP, U.K. Tel: 01908-691-133

#### Succursale Française

9, rue Paul Dautier, B.P. 52 78142 Velizy-Villacoublay Cédex France

Tel: 01-3067-5800

#### Sucursal en España

Juan Esplandiu, 15 28007 Madrid, Spain Tel: 091-504-2787

#### Tyskland Filial

Täby Centrum Entrance S (7th floor) 18322 Täby, Sweden Tel: 08 638 72 00

#### Filiale Italiana

Via Fabio Filzi, 25/A 20124 Milano, Italy Tel: 02-667541

## Branch The Netherlands

Steijgerweg 6 5616 HS Eindhoven The Netherlands Tel: 040 265 40 10

#### [Asia & Oceania]

#### NEC Electronics (China) Co., Ltd

7th Floor, Quantum Plaza, No. 27 ZhiChunLu Haidian District, Beijing 100083, P.R.China Tel: 010-8235-1155 http://www.cn.necel.com/

#### Shanghai Branch

Room 2509-2510, Bank of China Tower, 200 Yincheng Road Central, Pudong New Area, Shanghai, P.R.China P.C:200120 Tel:021-5888-5400 http://www.cn.necel.com/

#### Shenzhen Branch

Unit 01, 39/F, Excellence Times Square Building, No. 4068 Yi Tian Road, Futian District, Shenzhen, P.R.China P.C:518048 Tel:0755-8282-9800 http://www.cn.necel.com/

#### NEC Electronics Hong Kong Ltd.

Unit 1601-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: 2886-9318 http://www.hk.necel.com/

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

7F, No. 363 Fu Shing North Road Taipei, Taiwan, R. O. C. Tel: 02-8175-9600 http://www.tw.necel.com/

## NEC Electronics Singapore Pte. Ltd.

238A Thomson Road, #12-08 Novena Square, Singapore 307684 Tel: 6253-8311 http://www.sg.necel.com/

### NEC Electronics Korea Ltd.

11F., Samik Lavied'or Bldg., 720-2, Yeoksam-Dong, Kangnam-Ku, Seoul, 135-080, Korea Tel: 02-558-3737 http://www.kr.necel.com/

G0706