**User's Manual** 



# $\mu$ PD178054 Subseries

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

μ**PD178053** μ**PD178054** μ**PD178F054** 

Document No. U15104EJ2V0UD00 (2nd edition) Date Published January 2002 N CP(K)

© NEC Corporation 2001 Printed in Japan [MEMO]

#### **1** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

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

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

#### Note:

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

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

#### Note:

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

FIP and IEBus are trademarks of NEC Corporation.

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

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

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

SPARCstation is a trademark of SPARC International, Inc.

Solaris and SunOS are trademarks of Sun Microsystems, Inc.

Ethernet is a trademark of Xerox Corporation.

TRON is an abbreviation of The Realtime Operating system Nucleus.

ITRON is an abbreviation of Industrial TRON.

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

License not needed: μPD178F054GC-8BT The customer must judge the need for license: μPD178053GC-×××-8BT, 178054GC-×××-8BT

- The information in this document is current as of October, 2001. The information is subject to change without notice. For actual design-in, refer to the latest publications of NEC's data sheets or data books, etc., for the most up-to-date specifications of NEC semiconductor products. Not all products and/or types are available in every country. Please check with an NEC 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 prior written consent of NEC. NEC assumes no responsibility for any errors that may appear in this document.
- NEC 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 semiconductor 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 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 customer's equipment shall be done under the full responsibility of customer. NEC assumes no responsibility for any losses incurred by customers or third parties arising from the use of these circuits, software and information.
- While NEC endeavours to enhance the quality, reliability and safety of NEC semiconductor 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
  semiconductor products, customers must incorporate sufficient safety measures in their design, such as
  redundancy, fire-containment, and anti-failure features.
- NEC semiconductor products are classified into the following three quality grades:
   "Standard", "Special" and "Specific". The "Specific" quality grade applies only to semiconductor products
   developed based on a customer-designated "quality assurance program" for a specific application. The
   recommended applications of a semiconductor product depend on its quality grade, as indicated below.
   Customers must check the quality grade of each semiconductor 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 semiconductor products is "Standard" unless otherwise expressly specified in NEC's data sheets or data books, etc. If customers wish to use NEC semiconductor products in applications not intended by NEC, they must contact an NEC sales representative in advance to determine NEC's willingness to support a given application.

(Note)

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

# **Regional Information**

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

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

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

#### NEC Electronics Inc. (U.S.) Santa Clara, California Tel: 408-588-6000 800-366-9782

800-366-9782 Fax: 408-588-6130 800-729-9288

**NEC Electronics (Germany) GmbH** 

Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490

**NEC Electronics (UK) Ltd.** Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290

#### NEC Electronics Italiana s.r.l.

Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99 NEC Electronics (Germany) GmbH Benelux Office Eindhoven, The Netherlands Tel: 040-2445845 Fax: 040-2444580

NEC Electronics (France) S.A. Velizy-Villacoublay, France Tel: 01-3067-5800 Fax: 01-3067-5899

NEC Electronics (France) S.A. Madrid Office Madrid, Spain Tel: 091-504-2787 Fax: 091-504-2860

NEC Electronics (Germany) GmbH Scandinavia Office Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388 NEC Electronics Hong Kong Ltd. Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

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

NEC Electronics Singapore Pte. Ltd. Novena Square, Singapore Tel: 253-8311 Fax: 250-3583

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

#### NEC do Brasil S.A.

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

J01.2

# Major Revisions in This Edition

| Page        | Description                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Throughout  | Change of $\mu$ PD178053, 178054, and 178F054 status from under development to development completed                                    |
| pp.8, 9     | Modification of Related Documents                                                                                                       |
| p.25        | Modification of 1.5 Development of 8-Bit DTS Series                                                                                     |
| p.55        | Modification of bit units for manipulation for OSTS in Table 3-4 Special Function Registers                                             |
| p.84        | Deletion of pins P10 to P15 from Table 4-3 Port Mode Register and Output Latch Settings When Using Alternate Functions                  |
| p.124       | Modification of description in (3) Oscillation stabilization time select register (OSTS) in 8.3 Registers<br>Controlling Watchdog Timer |
| p.240       | Addition of CHAPTER 19 ELECTRICAL SPECIFICATIONS                                                                                        |
| p.250       | Addition of CHAPTER 20 PACKAGE DRAWING                                                                                                  |
| p.251       | Addition of CHAPTER 21 RECOMMENDED SOLDERING CONDITIONS                                                                                 |
| p.253       | Modification of Figure A-1 Configuration of Development Tools                                                                           |
| pp.255, 256 | Addition of A.1 Software Package and A.3 Control Software                                                                               |
| p.255       | Addition of Note 2 to A.2 Language Processing Software                                                                                  |
| p.257       | Addition of description for IE-78K0-NS-A to A.5 Debugging Tools (Hardware)                                                              |
| p.260       | Deletion of MX78K0 from A.7 Embedded Software                                                                                           |

The mark  $\star$  shows major revised points.

#### PREFACE

| Readers        |                                                                                                                                                                                                           | µPD178054 Subseries                                                                                                                                     | er engineers who wish to unde<br>and design and develop its a                                       |             |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-------------|
| Purpose        | This manual is ir in the Organizat                                                                                                                                                                        | -                                                                                                                                                       | understanding of the functions                                                                      | described   |
| Organization   |                                                                                                                                                                                                           | Subseries manual is se<br>on (common to the 78K/                                                                                                        | parated into two parts: this manu<br>0 Series).                                                     | ual and the |
|                | μPD1780<br>Subserie<br>User's Ma                                                                                                                                                                          | es                                                                                                                                                      | 78K/0 Series<br>User's Manual<br>Instruction                                                        |             |
|                | <ul> <li>Pin functions</li> <li>Internal block</li> <li>Interrupt</li> <li>Other on-chip</li> <li>Electrical species</li> </ul>                                                                           | peripheral functions                                                                                                                                    | <ul> <li>CPU functions</li> <li>Instruction set</li> <li>Explanation of each instruction</li> </ul> | tion        |
| How to Read Th | is Manual Before reading the circuits and mice                                                                                                                                                            |                                                                                                                                                         | ave general knowledge of electri                                                                    | c and logic |
|                | <ul> <li>→ Read this r</li> <li>To know the µ</li> <li>→ Refer to the</li> <li>How to interpresent the cir</li> <li>→ For the cir</li> <li>DF178054</li> <li>named sfrb</li> <li>To know the e</li> </ul> | e <b>78K/0 Series User's</b><br>ret the register format:<br>cled bit number, the bit<br>and RA78K0, and in Co<br>bit.h.<br>electrical specifications of | •                                                                                                   | ed word in  |
| Conventions    | Data representation weight:<br>Active low representations:<br>Note:<br>Caution:<br>Remark:<br>Numeral representations:                                                                                    | $\overline{\times}$ (overscore over p                                                                                                                   | ked with <b>Note</b> in the text.<br>particular attention<br>ation<br><b< th=""><th></th></b<>      |             |

#### ★ Related Documents

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

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

| Document Name                            | Document No. |         |
|------------------------------------------|--------------|---------|
| µPD178054 Subseries User's Manual        | This manual  |         |
| 78K/0 Series Instruction User's Manual   | U12326E      |         |
| 78K/0 Series Application Note Basics (I) |              | U12704E |

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

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

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

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

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

#### **Documents Related to Flash ROM Writing**

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

#### **Other Related Documents**

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

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

### TABLE OF CONTENTS

| CHAPTE | R 1 OU   | TLINE                      | 21 |
|--------|----------|----------------------------|----|
| 1.1    | Featur   | es                         | 21 |
| 1.2    | Applic   | ations                     | 22 |
| 1.3    | Orderi   | ng Information             | 22 |
| 1.4    | Pin Co   | nfiguration (Top View)     | 23 |
| 1.5    | Develo   | ppment of 8-Bit DTS Series | 25 |
| 1.6    | Block    | Diagram                    | 26 |
| 1.7    | Function | onal Outline               | 27 |
|        |          |                            |    |
| CHAPTE | R 2 PIN  | I FUNCTION                 | 28 |
| 2.1    | Pin Fu   | nction List                | 28 |
| 2.2    | Descri   | ption of Pin Functions     | 30 |
|        | 2.2.1    | P00 to P06 (Port 0)        | 30 |
|        | 2.2.2    | P10 to P15 (Port 1)        | 30 |
|        | 2.2.3    | P30 to P37 (Port 3)        | 30 |
|        | 2.2.4    | P40 to P47 (Port 4)        | 31 |
|        | 2.2.5    |                            | 31 |
|        | 2.2.6    |                            | 31 |
|        | 2.2.7    |                            | 31 |
|        | 2.2.8    |                            | 32 |
|        | 2.2.9    |                            | 32 |
|        | 2.2.10   |                            | 32 |
|        | 2.2.11   |                            | 32 |
|        | 2.2.12   |                            | 33 |
|        | 2.2.13   |                            | 33 |
|        | 2.2.14   |                            | 33 |
|        | 2.2.15   |                            | 33 |
|        | 2.2.16   |                            | 33 |
|        | 2.2.17   |                            | 33 |
|        | 2.2.18   |                            | 33 |
|        | 2.2.19   |                            | 33 |
|        | 2.2.20   |                            | 33 |
|        | 2.2.21   |                            | 33 |
|        | 2.2.22   |                            | 33 |
|        | 2.2.23   |                            | 33 |
|        | 2.2.24   |                            | 33 |
|        | 2.2.25   |                            | 34 |
| 2.3    | -        |                            | 35 |
| 210    |          |                            |    |
| СНАРТЕ | R 3 CP   | U ARCHITECTURE             | 38 |
| 3.1    |          |                            | 38 |
|        | 3.1.1    |                            | 42 |
|        | 3.1.2    |                            | 43 |
|        | 3.1.3    |                            | 43 |
|        | 3.1.4    |                            | 44 |
|        |          | ·····                      | -  |

| 3          | 3.2        | Proce          | ssor Registers 47                                                   |
|------------|------------|----------------|---------------------------------------------------------------------|
|            |            | 3.2.1          | Control registers                                                   |
|            |            | 3.2.2          | General-purpose registers                                           |
|            |            | 3.2.3          | Special Function Registers (SFR)                                    |
| 3          | 3.3        | Instru         | ction Address Addressing                                            |
|            |            | 3.3.1          | Relative addressing                                                 |
|            |            | 3.3.2          | Immediate addressing                                                |
|            |            | 3.3.3          | Table indirect addressing   58                                      |
|            |            | 3.3.4          | Register addressing                                                 |
| 3          | 3.4        | Opera          | nd Address Addressing                                               |
|            |            | 3.4.1          | Implied addressing                                                  |
|            |            | 3.4.2          | Register addressing                                                 |
|            |            | 3.4.3          | Direct addressing                                                   |
|            |            | 3.4.4          | Short direct addressing                                             |
|            |            | 3.4.5          | Special Function Register (SFR) addressing                          |
|            |            | 3.4.6          | Register indirect addressing                                        |
|            |            | 3.4.7          | Based addressing                                                    |
|            |            | 3.4.8          | Based indexed addressing                                            |
|            |            | 3.4.9          | Stack addressing                                                    |
|            |            |                | · · · · · · · · · · · · · · · ·                                     |
| СНА        | ΡΤΕΙ       | R4PC           | ORT FUNCTIONS                                                       |
| -          | 1.1        | -              | Functions                                                           |
|            | 1.2        |                | Configuration                                                       |
|            |            | 4.2.1          | Port 0                                                              |
|            |            | 4.2.2          | Port 1                                                              |
|            |            | 4.2.3          | Port 3                                                              |
|            |            | 4.2.4          | Port 4                                                              |
|            |            | 4.2.5          | Port 5                                                              |
|            |            | 4.2.6          | Port 6                                                              |
|            |            | 4.2.7          | Port 7                                                              |
|            |            | 4.2.8          | Port 12                                                             |
|            |            | 4.2.9          | Port 13                                                             |
|            | 1.3        | -              | ters Controlling Port Functions                                     |
|            | +.3<br>1.4 | -              | Function Operations                                                 |
| -          | •.4        | 4.4.1          | •                                                                   |
|            |            | 4.4.1          | Writing to I/O ports       8         Reading from I/O ports       8 |
|            |            | 4.4.2<br>4.4.3 |                                                                     |
|            |            | 4.4.3          | Operations on I/O ports                                             |
| <u>спу</u> | оте        |                | OCK GENERATOR                                                       |
|            | 5.1        |                | OCK GENERATOR                                                       |
| -          |            |                |                                                                     |
|            | 5.2<br>5.3 | -              | -                                                                   |
|            |            | -              |                                                                     |
| 5          | 5.4        | -              | m Clock Oscillator                                                  |
|            |            | 5.4.1          | 99 System clock oscillator                                          |
| -          |            | 5.4.2          | Divider                                                             |
|            | 5.5        |                | Generator Operations                                                |
| 5          | 5.6        | -              | ging System Clock and CPU Clock Settings                            |
|            |            | 5.6.1          | Time required for switching between system clock and CPU clock      |

| CHAPTE | R 6 8-BIT TIMER/EVENT COUNTERS 50 TO 53                                 | 96  |
|--------|-------------------------------------------------------------------------|-----|
| 6.1    | Functions of 8-Bit Timer/Event Counters 50 to 53                        | 96  |
| 6.2    | Configuration of 8-Bit Timer/Event Counters 50 to 53                    | 99  |
| 6.3    | Registers Controlling 8-Bit Timer/Event Counters 50 to 53               | 101 |
| 6.4    | Operations of 8-Bit Timer/Event Counters 50 to 53                       | 105 |
|        | 6.4.1 Operation as interval timer (8-bit)                               | 105 |
|        | 6.4.2 Operation as external event counter (timers 50 to 52)             | 109 |
|        | 6.4.3 Square wave output operation (8-bit resolution) (timers 50 to 52) | 110 |
|        | 6.4.4 8-bit PWM output operation (timers 50 to 52)                      | 111 |
|        | 6.4.5 Interval timer operation (16-bit)                                 | 114 |
| 6.5    | Notes on 8-Bit Timer/Event Counters 50 to 53                            | 115 |
|        |                                                                         |     |
|        | R 7 BASIC TIMER                                                         |     |
| 7.1    | Function of Basic Timer                                                 |     |
| 7.2    | Configuration of Basic Timer                                            |     |
| 7.3    | Operation of Basic Timer                                                | 118 |
| CHAPTE | R 8 WATCHDOG TIMER                                                      | 119 |
| 8.1    | Functions of Watchdog Timer                                             |     |
| 8.2    | Configuration of Watchdog Timer                                         |     |
| 8.3    | Registers Controlling Watchdog Timer                                    |     |
| 8.4    | Operations of Watchdog Timer                                            |     |
| ••••   | 8.4.1 Watchdog timer operation                                          |     |
|        | 8.4.2 Interval timer operation                                          |     |
|        |                                                                         | 120 |
| CHAPTE | R 9 BUZZER OUTPUT CONTROLLER                                            | 127 |
| 9.1    | Functions of Buzzer Output Controllers                                  | 127 |
| 9.2    | Configuration of Buzzer Output Controllers                              | 128 |
| 9.3    | Registers Controlling Buzzer Output Controllers                         | 128 |
|        | 9.3.1 BEEP0                                                             | 128 |
|        | 9.3.2 BUZ                                                               | 129 |
| 9.4    | Operation of Buzzer Output Controllers                                  | 129 |
|        |                                                                         |     |
|        | R 10 A/D CONVERTER                                                      |     |
|        | Functions of A/D Converter                                              |     |
|        | Configuration of A/D Converter                                          |     |
|        | Registers Controlling A/D Converter                                     |     |
| 10.4   | Operations of A/D Converter                                             | 136 |
|        | 10.4.1 Basic operations of A/D converter                                |     |
|        | 10.4.2 Input voltage and conversion results                             |     |
|        | 10.4.3 A/D converter operating mode                                     |     |
| 10.5   | Notes on A/D Converter                                                  | 145 |
| CHAPTE | R 11 SERIAL INTERFACES SIO30 TO SIO32                                   | 147 |
|        | Functions of Serial Interfaces SIO30 to SIO32                           |     |
|        | Configuration of Serial Interfaces SIO30 to SIO32                       |     |
|        | Registers Controlling Serial Interfaces SIO30 to SIO32                  |     |
|        | Operations of Serial Interfaces SIO30 to SIO32                          |     |
|        | 11.4.1 Operation stop mode                                              |     |
|        | 11.4.2 3-wire serial I/O mode                                           |     |
|        |                                                                         |     |

| CHAPTE | R 12 INTERRUPT FUNCTIONS                                                        | 156         |  |  |
|--------|---------------------------------------------------------------------------------|-------------|--|--|
| 12.1   | Interrupt Function Types                                                        | 156         |  |  |
| 12.2   | Interrupt Sources and Configuration 15                                          |             |  |  |
| 12.3   | Registers Controlling Interrupt Functions 1                                     |             |  |  |
| 12.4   | Interrupt Servicing Operations                                                  | 166         |  |  |
|        | 12.4.1 Non-maskable interrupt request acknowledgement operation                 | 166         |  |  |
|        | 12.4.2 Maskable interrupt request acknowledgement operation                     | 169         |  |  |
|        | 12.4.3 Software interrupt request acknowledgement operation                     | 172         |  |  |
|        | 12.4.4 Multiple interrupt servicing                                             | 173         |  |  |
|        | 12.4.5 Pending interrupt requests                                               | 176         |  |  |
| СНАРТЕ | R 13 PLL FREQUENCY SYNTHESIZER                                                  | 177         |  |  |
|        | Function of PLL Frequency Synthesizer                                           | 177         |  |  |
|        | Configuration of PLL Frequency Synthesizer                                      | 179         |  |  |
|        | Registers Controlling PLL Frequency Synthesizer                                 | 181         |  |  |
|        | Operation of PLL Frequency Synthesizer                                          | 185         |  |  |
| 13.4   | 13.4.1 Operation of each block of PLL frequency synthesizer                     | 185         |  |  |
|        |                                                                                 | 189         |  |  |
| 10 E   | 13.4.2 Operation to set N value of PLL frequency synthesizer PLL Disable Status | <b>194</b>  |  |  |
|        | Notes on PLL Frequency Synthesizer                                              | 194<br>194  |  |  |
| 13.0   | Notes on FLL Frequency Synthesizer                                              | 194         |  |  |
| CHAPTE | R 14 FREQUENCY COUNTER                                                          | 195         |  |  |
| 14.1   | Function of Frequency Counter                                                   | 195         |  |  |
| 14.2   | Configuration of Frequency Counter                                              | 195         |  |  |
| 14.3   | Registers Controlling Frequency Counter                                         | 197         |  |  |
| 14.4   | Operation of Frequency Counter                                                  | 199         |  |  |
| 14.5   | Notes on Frequency Counter                                                      | 201         |  |  |
| СНАРТЕ | R 15 STANDBY FUNCTION                                                           | 203         |  |  |
|        | Standby Function and Configuration                                              | 203         |  |  |
| 13.1   | 15.1.1 Standby function                                                         | 203         |  |  |
|        | 15.1.2 Register controlling standby function                                    | 203         |  |  |
| 15.2   | Operations of Standby Function                                                  | <b>20</b> 4 |  |  |
| 13.2   | 15.2.1 HALT mode                                                                | 205         |  |  |
|        | 15.2.2 STOP mode                                                                | 205         |  |  |
|        |                                                                                 | 200         |  |  |
| CHAPTE | R 16 RESET FUNCTION                                                             | 211         |  |  |
|        | Reset Function                                                                  | 211         |  |  |
| 16.2   | Power Failure Detection Function                                                | 218         |  |  |
| 16.3   | 4.5 V Voltage Detection Function                                                | 219         |  |  |
| CHAPTE | R 17 μPD178F054                                                                 | 220         |  |  |
|        | Memory Size Switching Register (IMS)                                            | 221         |  |  |
|        | Internal Expansion RAM Size Switching Register (IXS)                            | 222         |  |  |
|        | Flash Memory Programming                                                        | 223         |  |  |
|        | 17.3.1 Selecting communication mode                                             | 223         |  |  |
|        | 17.3.2 Flash memory programming function                                        | 224         |  |  |
|        | 17.3.3 Connecting Flashpro III                                                  | 224         |  |  |
|        | 17.3.4 Setting example for Flashpro III (PG-FP3)                                | 225         |  |  |
|        |                                                                                 |             |  |  |

| СН   | APTE        | R 18 INSTRUCTION SET                               | 226 |
|------|-------------|----------------------------------------------------|-----|
|      | 18.1        | Conventions                                        | 227 |
|      |             | 18.1.1 Operand symbols and description             | 227 |
|      |             | 18.1.2 Description of "operation" column           | 228 |
|      |             | 18.1.3 Description of "flag operation" column      | 228 |
|      | 18.2        | Operation List                                     | 229 |
|      | 18.3        | Instructions Listed by Addressing Type             | 237 |
| * CH | ΑΡΤΕ        | R 19 ELECTRICAL SPECIFICATIONS                     | 240 |
| * CH | ΑΡΤΕ        | R 20 PACKAGE DRAWING                               | 250 |
| * CH | ΑΡΤΕ        | R 21 RECOMMENDED SOLDERING CONDITIONS              | 251 |
| AP   | PEND        | X A DEVELOPMENT TOOLS                              | 252 |
|      | <b>A.1</b>  | Software Package                                   | 255 |
| *    | A.2         | Language Processing Software                       | 255 |
| *    | A.3         |                                                    | 256 |
|      | <b>A.</b> 4 |                                                    | 256 |
|      | A.5         | Debugging Tools (Hardware)                         | 257 |
|      | A.6         | Debugging Tools (Software)                         | 259 |
|      | <b>A.</b> 7 | Embedded Software                                  | 260 |
|      | A.8         | System Upgrade from Former In-circuit Emulator for |     |
|      |             | 78K/0 Series to IE-78001-R-A                       | 261 |
| ΑΡ   | PEND        | X B REGISTER INDEX                                 | 264 |
|      | <b>B.1</b>  | Register Index                                     | 264 |
|      | B.2         | Register Index (Symbol)                            | 267 |
| * AP | PEND        | X C REVISION HISTORY                               | 270 |

# LIST OF FIGURES (1/4)

| Figure No. | Title                                              | Page |
|------------|----------------------------------------------------|------|
| 2-1        | Pin I/O Circuits                                   |      |
| 3-1        | Memory Map of $\mu$ PD178053                       |      |
| 3-2        | Memory Map of µPD178054                            |      |
| 3-3        | Memory Map of μPD178F054                           |      |
| 3-4        | Data Memory Addressing of µPD178053                |      |
| 3-5        | Data Memory Addressing of µPD178054                |      |
| 3-6        | Data Memory Addressing of µPD178F054               |      |
| 3-7        | Configuration of Program Counter                   |      |
| 3-8        | Configuration of Program Status Word               |      |
| 3-9        | Configuration of Stack Pointer                     |      |
| 3-10       | Data to Be Saved to Stack Memory                   |      |
| 3-11       | Data to Be Restored from Stack Memory              |      |
| 3-12       | Configuration of General-Purpose Register          |      |
| 4-1        | Port Types                                         |      |
| 4-2        | Block Diagram of P00 to P04                        |      |
| 4-3        | Block Diagram of P05 and P06                       |      |
| 4-4        | Block Diagram of P10 to P15                        |      |
| 4-5        | Block Diagram of P30 to P32 and P35                |      |
| 4-6        | Block Diagram of P33 and P34                       |      |
| 4-7        | Block Diagram of P36 and P37                       |      |
| 4-8        | Block Diagram of P40 to P47                        |      |
| 4-9        | Block Diagram of Key Input Detector                |      |
| 4-10       | Block Diagram of P50 to P57                        |      |
| 4-11       | Block Diagram of P60 to P67                        |      |
| 4-12       | Block Diagram of P70, P74, and P77                 |      |
| 4-13       | Block Diagram of P71 and P75                       |      |
| 4-14       | Block Diagram of P72 and P76                       |      |
| 4-15       | Block Diagram of P73                               |      |
| 4-16       | Block Diagram of P120 and P123                     |      |
| 4-17       | Block Diagram of P121 and P124                     |      |
| 4-18       | Block Diagram of P122 and P125                     |      |
| 4-19       | Block Diagram of P130 to P132                      |      |
| 4-20       | Format of Port Mode Registers                      |      |
| 4-21       | Format of Pull-up Resistor Option Register 4 (PU4) |      |
| 5-1        | Format of DTS System Clock Select Register (DTSCK) |      |
| 5-2        | Block Diagram of Clock Generator                   |      |
| 5-3        | Format of Processor Clock Control Register (PCC)   |      |
| 5-4        | External Circuit of System Clock Oscillator        |      |
| 5-5        | Examples of Incorrect Resonator Connection         |      |

# LIST OF FIGURES (2/4)

| Figure No. | Title                                                                     | Page |
|------------|---------------------------------------------------------------------------|------|
| 6-1        | Block Diagram of 8-Bit Timer/Event Counter 50                             | 97   |
| 6-2        | Block Diagram of 8-Bit Timer/Event Counter 51                             |      |
| 6-3        | Block Diagram of 8-Bit Timer/Event Counter 52                             | 98   |
| 6-4        | Block Diagram of 8-Bit Timer 53                                           | 98   |
| 6-5        | Format of Timer Clock Select Registers 50 to 52 (TCL50 to TCL52)          | 101  |
| 6-6        | Format of Timer Clock Select Register 53 (TCL53)                          | 102  |
| 6-7        | Format of 8-Bit Timer Mode Control Registers 50 to 52 (TMC50 to TMC52)    | 103  |
| 6-8        | Format of 8-Bit Timer Mode Control Register 53 (TMC53)                    | 104  |
| 6-9        | Timing of Interval Timer Operation                                        | 106  |
| 6-10       | Operation Timing of External Event Counter (with Rising Edge Specified)   | 109  |
| 6-11       | Timing of Square Output Operation                                         | 110  |
| 6-12       | Operation Timing of PWM Output                                            | 112  |
| 6-13       | Timing of Operation When CR5n Is Changed                                  | 113  |
| 6-14       | Operation Timing of 16-Bit Resolution Cascade Mode (Timers 50 and 51)     | 115  |
| 6-15       | Start Timing of 8-Bit Timer Counter                                       | 115  |
| 6-16       | Timing After Changing Compare Register Value During Timer Count Operation | 116  |
| 7-1        | Block Diagram of Basic Timer                                              | 117  |
| 7-2        | Operation Timing of Basic Timer                                           | 118  |
| 7-3        | Operating Timing to Poll BTMIF0 Flag                                      | 118  |
| 8-1        | Block Diagram of Watchdog Timer                                           | 119  |
| 8-2        | Format of Watchdog Timer Clock Select Register (WDCS)                     | 122  |
| 8-3        | Format of Watchdog Timer Mode Register (WDTM)                             | 123  |
| 8-4        | Format of Oscillation Stabilization Time Select Register (OSTS)           | 124  |
| 9-1        | Block Diagram of BEEP0                                                    | 127  |
| 9-2        | Block Diagram of BUZ                                                      | 127  |
| 9-3        | Format of BEEP Clock Select Register 0 (BEEPCL0)                          | 128  |
| 9-4        | Format of Clock Output Select Register (CKS)                              | 129  |
| 10-1       | Block Diagram of A/D Converter                                            | 131  |
| 10-2       | Format of A/D Converter Mode Register 3 (ADM3)                            | 133  |
| 10-3       | Format of Analog Input Channel Specification Register 3 (ADS3)            | 134  |
| 10-4       | Format of Power-Fail Comparison Mode Register 3 (PFM3)                    | 135  |
| 10-5       | A/D Converter Basic Operation                                             | 137  |
| 10-6       | Relationship Between Analog Input Voltage and A/D Conversion Result       | 138  |
| 10-7       | A/D Conversion Operation                                                  | 140  |
| 10-8       | Power-Fail Comparison Threshold Value Register 3 (PFT3)                   | 141  |
| 10-9       | A/D Conversion Operation in Power-Fail Comparison Mode                    | 142  |
| 10-10      | Example of Reducing Current Consumption in Standby Mode                   | 145  |
| 10-11      | A/D Conversion End Interrupt Request Generation Timing                    | 146  |

# LIST OF FIGURES (3/4)

| Figure No. | Title                                                                           | Page |
|------------|---------------------------------------------------------------------------------|------|
| 11-1       | Block Diagram of Serial Interface SIO30                                         | 147  |
| 11-2       | Block Diagram of Serial Interface SIO31                                         |      |
| 11-3       | Block Diagram of Serial Interface SIO32                                         | 148  |
| 11-4       | Format of Serial Operating Mode Registers 30 to 32 (CSIM30 to CSIM32)           | 150  |
| 11-5       | Format of Serial Port Select Register 32 (SIO32SEL)                             |      |
| 11-6       | Timing in 3-Wire Serial I/O Mode                                                |      |
| 12-1       | Basic Configuration of Interrupt Function                                       | 158  |
| 12-2       | Format of Interrupt Request Flag Registers (IF0L, IF0H)                         | 161  |
| 12-3       | Format of Interrupt Mask Flag Registers (MK0L, MK0H)                            | 162  |
| 12-4       | Format of Priority Specification Flag Registers (PR0L, PR0H)                    | 163  |
| 12-5       | Format of External Interrupt Rising Edge Enable Register (EGP) and              |      |
|            | External Interrupt Falling Edge Enable Register (EGN)                           | 164  |
| 12-6       | Configuration of Program Status Word (PSW)                                      | 165  |
| 12-7       | Flowchart from Generation of Non-Maskable Interrupt Request to Acknowledgement  | 167  |
| 12-8       | Non-Maskable Interrupt Request Acknowledgement Timing                           | 167  |
| 12-9       | Non-Maskable Interrupt Request Acknowledgement Operation                        | 168  |
| 12-10      | Interrupt Request Acknowledgement Processing Algorithm                          | 170  |
| 12-11      | Interrupt Request Acknowledgement Timing (Minimum Time)                         | 171  |
| 12-12      | Interrupt Request Acknowledgement Timing (Maximum Time)                         |      |
| 12-13      | Multiple Interrupt Servicing Example                                            |      |
| 12-14      | Pending Interrupt Request                                                       | 176  |
| 13-1       | Block Diagram of PLL Frequency Synthesizer                                      | 179  |
| 13-2       | Format of PLL Mode Select Register (PLLMD)                                      | 181  |
| 13-3       | Format of PLL Reference Mode Register (PLLRF)                                   | 182  |
| 13-4       | Format of PLL Unlock F/F Judge Register (PLLUL)                                 | 183  |
| 13-5       | Format of PLL Data Transfer Register (PLLNS)                                    | 184  |
| 13-6       | Configuration of Input Select Block and Programmable Divider                    | 185  |
| 13-7       | Configuration of Reference Frequency Generator                                  | 186  |
| 13-8       | Configuration of Phase Comparator, Charge Pump, and Unlock F/F                  | 186  |
| 13-9       | Relationship Between fr, f <sub>N</sub> , $\overline{UP}$ , and $\overline{DW}$ |      |
| 13-10      | Configuration of Error Out Output                                               | 188  |
| 14-1       | Block Diagram of Frequency Counter                                              | 196  |
| 14-2       | Format of IF Counter Mode Select Register (IFCMD)                               | 197  |
| 14-3       | Format of IF Counter Control Register (IFCCR)                                   | 198  |
| 14-4       | Format of IF Counter Gate Judge Register (IFCJG)                                | 198  |
| 14-5       | Block Diagram of Input Pin and Mode Selection                                   | 199  |
| 14-6       | Gate Timing of Frequency Counter                                                | 200  |
| 14-7       | Frequency Counter Input Pin Circuit                                             | 201  |
| 14-8       | Gate Status When HALT Instruction Is Executed                                   | 201  |

# LIST OF FIGURES (4/4)

| Figure No. | Title                                                                | Page |
|------------|----------------------------------------------------------------------|------|
| 15-1       | Format of Oscillation Stabilization Time Select Register (OSTS)      | 204  |
| 15-2       | HALT Mode Release upon Interrupt Generation                          |      |
| 15-3       | HALT Mode Release by RESET Input                                     | 207  |
| 15-4       | STOP Mode Release by Interrupt Request Generation                    | 209  |
| 15-5       | Release by STOP Mode RESET Input                                     | 210  |
| 16-1       | Reset Function Block Diagram                                         | 212  |
| 16-2       | Timing of Reset by RESET Input                                       | 213  |
| 16-3       | Timing of Reset due to Watchdog Timer Overflow                       | 214  |
| 16-4       | Timing of Reset by Power-on Clear                                    | 215  |
| 16-5       | Format of POC Status Register (POCS)                                 | 218  |
| 16-6       | Format of POC Status Register (POCS)                                 | 219  |
| 17-1       | Format of Memory Size Switching Register (IMS)                       | 221  |
| 17-2       | Format of Internal Expansion RAM Size Switching Register (IXS)       | 222  |
| 17-3       | Format of Communication Mode Selection                               | 223  |
| 17-4       | Connection of Flashpro III in 3-Wire Serial I/O Mode                 | 224  |
| A-1        | Configuration of Development Tools                                   | 253  |
| A-2        | EV-9200GC-80 Package Drawing (for Reference Only)                    | 262  |
| A-3        | EV-9200GC-80 Recommended Board Mounting Pattern (for Reference Only) | 263  |

# LIST OF TABLES (1/2)

| Table No. | Title                                                                                 | Page |
|-----------|---------------------------------------------------------------------------------------|------|
| 2-1       | Pin I/O Circuit Type and Recommended Connections of Unused Pins                       | 35   |
| 3-1       | Internal Memory Capacities                                                            | 42   |
| 3-2       | Vector Table                                                                          |      |
| 3-3       | Absolute Address of General-Purpose Registers                                         |      |
| 3-4       | Special Function Registers                                                            |      |
| 4-1       | Port Functions                                                                        | 69   |
| 4-2       | Port Configuration                                                                    | 70   |
| 4-3       | Port Mode Register and Output Latch Settings When Using Alternate Functions           | 84   |
| 5-1       | Configuration of Clock Generator                                                      | 89   |
| 5-2       | Maximum Time Required for CPU Clock Switching                                         | 95   |
| 6-1       | Configuration of 8-Bit Timer/Event Counters 50 to 53                                  | 99   |
| 8-1       | Watchdog Timer Inadvertent Program Loop Detection Times                               | 120  |
| 8-2       | Interval Time                                                                         | 120  |
| 8-3       | Configuration of Watchdog Timer                                                       | 121  |
| 8-4       | Watchdog Timer Inadvertent Program Loop Detection Time                                | 125  |
| 8-5       | Interval Timer Interval Time                                                          | 126  |
| 9-1       | Configuration of Buzzer Output Controllers                                            | 128  |
| 10-1      | Configuration of A/D Converter                                                        | 130  |
| 11-1      | Configuration of Serial Interfaces SIO30 to SIO32                                     | 149  |
| 12-1      | Interrupt Sources                                                                     | 157  |
| 12-2      | Various Flags Corresponding to Interrupt Request Sources                              | 160  |
| 12-3      | Times from Maskable Interrupt Request Generation to Interrupt Servicing               | 169  |
| 12-4      | Interrupt Request Enabled for Multiple Interrupt Servicing During Interrupt Servicing | 173  |
| 13-1      | Division Mode, Input Pin, and Division Value                                          | 178  |
| 13-2      | Configuration of PLL Frequency Synthesizer                                            | 179  |
| 13-3      | Error Out Output Signal                                                               | 188  |
| 13-4      | Operation of Each Block and Register Status in PLL Disabled Status                    | 194  |
| 14-1      | Configuration of Frequency Counter                                                    | 195  |
| 15-1      | HALT Mode Operating Status                                                            | 205  |
| 15-2      | Operation After HALT Mode Release                                                     | 207  |
| 15-3      | STOP Mode Operating Status                                                            | 208  |
| 15-4      | Operation After STOP Mode Release                                                     | 210  |

# LIST OF TABLES (2/2)

| Table No. | Title                                                       | Page  |
|-----------|-------------------------------------------------------------|-------|
| 16-1      | Hardware Status After Reset                                 | 216   |
| 17-1      | Differences Between $\mu$ PD178F054 and Mask ROM Versions   | 220   |
| 17-2      | Set Value of Memory Size Switching Register                 | . 221 |
| 17-3      | Set Value of Internal Expansion RAM Size Switching Register | 222   |
| 17-4      | Communication Modes                                         | . 223 |
| 17-5      | Major Functions of Flash Memory Programming                 | . 224 |
| 17-6      | Setting Example for Flashpro III (PG-FP3)                   | 225   |
| 18-1      | Operand Symbols and Descriptions                            | 227   |
| 21-1      | Surface Mounting Type Soldering Conditions                  | 251   |
| A-1       | System Upgrade Method from Former In-circuit Emulator for   |       |
|           | 78K/0 Series to IE-78001-R-A                                | . 261 |

#### 1.1 Features

• Internal ROM and RAM

| Item        | Program Memory |       | Data Memory             |
|-------------|----------------|-------|-------------------------|
| Part Number |                |       | Internal High-Speed RAM |
| μPD178053   | ROM            | 24 KB | 1024 bytes              |
| μPD178054   |                | 32 KB |                         |
| μPD178F054  | Flash memory   | 32 KB |                         |

- Instruction set suitable for system control
  - Bit processing across entire address space
  - Multiplication/division instructions
- General-purpose I/O ports: 62 pins
- Hardware for PLL frequency synthesizer
  - Dual modulus prescaler (160 MHz MAX.)
  - Programmable divider
  - · Phase comparator
  - Charge pump
- Frequency counter
- 8-bit resolution A/D converter: 6 channels
- Serial interface: 3 channels
  - 3-wire serial I/O mode: 2 channels
  - 3-wire serial I/O mode (on-chip time-division transfer function): 1 channel
- Timer: 6 channels
  - Basic timer (timer carry FF): 1 channel
  - 8-bit timer/event counter: 4 channels
  - Watchdog timer: 1 channel
- Buzzer output
- Vectored interrupt

| Item                       | Non-Maskable              | Maskable Interrupt <sup>Note</sup> |            | Software Interrupt |
|----------------------------|---------------------------|------------------------------------|------------|--------------------|
| Part Number                | Interrupt <sup>Note</sup> | External                           | Internal   |                    |
| μPD178053, 178054, 178F054 | 1 source                  | 5 sources                          | 11 sources | 1 source           |

**Note** Either a non-maskable interrupt or maskable interrupt (internal) can be selected as the interrupt source of the watchdog timer (INTWDT).

- Test input: 1 pin
- Instruction cycle: 0.45/0.89/1.78/3.56/7.11  $\mu$ s (with 4.5 MHz crystal resonator)
- Supply voltage: VDD = 4.5 to 5.5 V (with CPU, PLL operating)
  - $V_{DD}$  = 3.5 to 5.5 V (with CPU operating)
- Power-on clear circuit

# 1.2 Applications

Car stereos

# 1.3 Ordering Information

| Part Number           | Package                            |  |  |
|-----------------------|------------------------------------|--|--|
| μPD178053GC-×××-8BT   | 80-pin plastic QFP (14 $	imes$ 14) |  |  |
| μPD178054GC-×××-8BT   | 80-pin plastic QFP (14 $	imes$ 14) |  |  |
| $\mu$ PD178F054GC-8BT | 80-pin plastic QFP (14 $	imes$ 14) |  |  |

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

#### 1.4 Pin Configuration (Top View)

#### • 80-pin plastic QFP ( $14 \times 14$ )

μPD178053GC-×××-8BT, 178054GC-×××-8BT, 178F054GC-8BT



Cautions 1. Directly connect the IC (Internally Connected) pin and VPP pin to GND.

- 2. Keep the VDDPORT and VDDPLL pins as same potential as that at the VDD pin.
- 3. Keep the GNDPORT and GNDPLL pins as same potential as that at GND.
- 4. Connect each of the REGOSC and REGCPU pins to GND via a 0.1  $\mu\text{F}$  capacitor.

**Remark** ():  $\mu$ PD178F054 only

#### Pin Name

| AMIFC:          | AM intermediate frequency counter input | P130 to P132:      | Port 13                          |
|-----------------|-----------------------------------------|--------------------|----------------------------------|
| ANI0 to ANI5:   | A/D converter input                     | REGCPU:            | Regulator for CPU power supply   |
| BEEP0, BUZ:     | Buzzer output                           | REGOSC:            | Regulator for oscillator         |
| EO0, EO1:       | Error out output                        | RESET:             | Reset input                      |
| FMIFC:          | FM intermediate frequency counter input | SCK30, SCK31,:     | Serial (SIO3) clock input/output |
| GND:            | Ground                                  | SCK32, SCK321      |                                  |
| GNDPLL:         | PLL ground                              | SI30, SI31, SI32,: | Serial (SIO3) data input         |
| GNDPORT:        | Port ground                             | SI321              |                                  |
| IC:             | Internally connected                    | SO30, SO31,:       | Serial (SIO3) data output        |
| INTP0 to INTP4: | Interrupt input                         | SO32, SO321        |                                  |
| P00 to P06:     | Port 0                                  | TI50 to TI52:      | 8-bit timer clock input          |
| P10 to P15:     | Port 1                                  | TO50 to TO52:      | 8-bit timer output               |
| P30 to P37:     | Port 3                                  | VCOL, VCOH:        | Local oscillation input          |
| P40 to P47:     | Port 4                                  | Vdd:               | Power supply                     |
| P50 to P57:     | Port 5                                  | VddPLL:            | PLL power supply                 |
| P60 to P67:     | Port 6                                  | VDDPORT:           | Port power supply                |
| P70 to P77:     | Port 7                                  | VPP Note:          | Programming power supply         |
| P120 to P125:   | Port 12                                 | X1, X2:            | Crystal resonator                |

**Note** μPD178F054 only

#### \* 1.5 Development of 8-Bit DTS Series



Limits functions of µPD178018A Subseries

#### 1.6 Block Diagram



**Remarks 1.** The internal ROM capacity differs depending on the product. **2.** ( ):  $\mu$ PD178F054

# 1.7 Functional Outline

|                                 | Item                   | μPD178053                                                                                                                                                                                                                                                                                                                                                      | μPD178054                                                   | μPD178F054              |  |  |
|---------------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------------|--|--|
| Internal                        | ROM                    | 24 KB<br>(Mask ROM)                                                                                                                                                                                                                                                                                                                                            | 32 KB<br>(Mask ROM)                                         | 32 KB<br>(Flash memory) |  |  |
|                                 | High-speed RAM         | 1024 bytes                                                                                                                                                                                                                                                                                                                                                     |                                                             | 1                       |  |  |
| General-purp                    | bose registers         | 8 bits $\times$ 32 registers (8 bits                                                                                                                                                                                                                                                                                                                           | imes 8 registers $	imes$ 4 banks)                           |                         |  |  |
| Minimum inst                    | ruction execution time | 0.45 μs/0.89 μs/1.78 μs/3.5                                                                                                                                                                                                                                                                                                                                    | 6 $\mu$ s/7.11 $\mu$ s (with crystal reson                  | ator of fx = 4.5 MHz)   |  |  |
| Instruction set                 |                        | <ul> <li>16-bit operation</li> <li>Multiplication/division (8 bits × 8 bits, 16 bits ÷ 8 bits)</li> <li>Bit manipulation (set, reset, test, Boolean operation)</li> <li>BCD adjustment, etc.</li> </ul>                                                                                                                                                        |                                                             |                         |  |  |
| I/O ports                       |                        | Total: 6                                                                                                                                                                                                                                                                                                                                                       | 52 pins                                                     |                         |  |  |
|                                 |                        | CMOS I/O: 53 pins     CMOS input: 6 pins     N-ch open-drain output: 3 pins                                                                                                                                                                                                                                                                                    |                                                             |                         |  |  |
| A/D converte                    | er                     | 8-bit resolution × 6 channels                                                                                                                                                                                                                                                                                                                                  | S                                                           |                         |  |  |
| Serial interfa                  | ice                    | <ul> <li>3-wire serial I/O mode: 2 channels</li> <li>3-wire serial I/O mode (on-chip time-division transfer): 1 channel</li> </ul>                                                                                                                                                                                                                             |                                                             |                         |  |  |
| Timer                           |                        | <ul> <li>Basic timer (timer carry FF</li> <li>8-bit timer/event counter:</li> <li>Watchdog timer:</li> </ul>                                                                                                                                                                                                                                                   | <sup>-</sup> (10 Hz)): 1 channel<br>4 channels<br>1 channel |                         |  |  |
| Buzzer outpu                    | ut                     | BEEP pin: 1 kHz, 1.5 kHz, 3 kHz, 4 kHz<br>BUZ pin: 549 Hz, 1.10 kHz, 2.20 kHz, 4.39 kHz                                                                                                                                                                                                                                                                        |                                                             |                         |  |  |
| Vectored interrupt              | Maskable               | Internal : 11<br>External: 5                                                                                                                                                                                                                                                                                                                                   |                                                             |                         |  |  |
| sources                         | Non-maskable           | Internal: 1                                                                                                                                                                                                                                                                                                                                                    |                                                             |                         |  |  |
|                                 | Software               | 1                                                                                                                                                                                                                                                                                                                                                              |                                                             |                         |  |  |
| PLL<br>frequency<br>synthesizer | Division mode          | 2 types<br>• Direct division mode (VCC<br>• Pulse swallow mode (VCC                                                                                                                                                                                                                                                                                            | 1 /                                                         |                         |  |  |
|                                 | Reference frequency    | Seven types selectable in se                                                                                                                                                                                                                                                                                                                                   | oftware (1, 3, 9, 10, 12.5, 25, 5                           | 0 kHz)                  |  |  |
|                                 | Charge pump            | Error out output: 2 pins                                                                                                                                                                                                                                                                                                                                       |                                                             |                         |  |  |
|                                 | Phase comparator       | Unlock detectable with prog                                                                                                                                                                                                                                                                                                                                    | ram                                                         |                         |  |  |
| Frequency counter               |                        | Frequency measurement<br>• AMIFC pin: For 450 kHz counting<br>• FMIFC pin: For 450 kHz/10.7 MHz counting                                                                                                                                                                                                                                                       |                                                             |                         |  |  |
| Reset                           |                        | <ul> <li>Reset by RESET pin</li> <li>Internal reset by watchdog timer</li> <li>Reset by power-on clear circuit</li> <li>Detection of less than 4.5 V<sup>Note</sup> (reset does not occur, however)</li> <li>Detection of less than 3.5 V<sup>Note</sup> (during CPU operation)</li> <li>Detection of less than 2.2 V<sup>Note</sup> (in STOP mode)</li> </ul> |                                                             |                         |  |  |
| Supply voltage                  |                        | <ul> <li>V<sub>DD</sub> = 4.5 to 5.5 V (during CPU, PLL operation)</li> <li>V<sub>DD</sub> = 3.5 to 5.5 V (during CPU operation)</li> </ul>                                                                                                                                                                                                                    |                                                             |                         |  |  |
| Package                         |                        | 80-pin plastic QFP (14 $	imes$ 14)                                                                                                                                                                                                                                                                                                                             |                                                             |                         |  |  |

Note For details, refer to CHAPTER 16 RESET FUNCTION.

### **CHAPTER 2 PIN FUNCTION**

# 2.1 Pin Function List

## (1) Port pins

| Pin Name     | I/O    | Function                                                                                                                                                                                | After Reset | Alternate Function |
|--------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|
| P00 to P04   | I/O    | Port 0                                                                                                                                                                                  | Input       | INTP0 to INTP4     |
| P05, P06     | -      | 7-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                         |             |                    |
| P10 to P15   | Input  | Port 1                                                                                                                                                                                  | Input       | ANI0 to ANI5       |
| 1 10 10 1 10 | input  | 6-bit input port                                                                                                                                                                        | input       |                    |
| P30 to P32   | I/O    | Port 3                                                                                                                                                                                  | Input       | _                  |
| P33          | -      | 8-bit I/O port.                                                                                                                                                                         |             | TI50               |
| P34          |        | Input/output can be specified in 1-bit units.                                                                                                                                           |             | TI51               |
| P35          |        |                                                                                                                                                                                         |             | —                  |
| P36          |        |                                                                                                                                                                                         |             | BEEP0              |
| P37          |        |                                                                                                                                                                                         |             | BUZ                |
| P40 to 47    | I/O    | Port 4<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>An on-chip pull-up resistor can be specified by software.<br>Interrupt function by key input is provided. | Input       | _                  |
| P50 to P57   | I/O    | Port 5<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                               | Input       | _                  |
| P60 to P67   | I/O    | Port 6.<br>8-bit I/O port.<br>Input/output can be specified in 1-bit units.                                                                                                             | Input       | _                  |
| P70          | I/O    | Port 7                                                                                                                                                                                  | Input       | SI30               |
| P71          |        | 8-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                                         |             | SO30               |
| P72          |        |                                                                                                                                                                                         |             | SCK30              |
| P73          |        |                                                                                                                                                                                         |             | _                  |
| P74          |        |                                                                                                                                                                                         |             | SI31               |
| P75          |        |                                                                                                                                                                                         |             | SO31               |
| P76          |        |                                                                                                                                                                                         |             | SCK31              |
| P77          |        |                                                                                                                                                                                         |             | TI52               |
| P120         | I/O    | Port 12                                                                                                                                                                                 | Input       | SI32               |
| P121         |        | 6-bit I/O port                                                                                                                                                                          |             | SO32               |
| P122         | 1      | Input/output can be specified in 1-bit units.                                                                                                                                           |             | SCK32              |
| P123         | 1      |                                                                                                                                                                                         |             | SI321              |
| P124         |        |                                                                                                                                                                                         |             | SO321              |
| P125         |        |                                                                                                                                                                                         |             | SCK321             |
| P130         | Output | Port 13                                                                                                                                                                                 | Low-level   | TO50               |
| P131         |        | 3-bit output port                                                                                                                                                                       | output      | TO51               |
| P132         | 1      | N-ch open-drain output port (12 V tolerance)                                                                                                                                            |             | TO52               |

| Pin Name                 | I/O    | Function                                                                                                                          | After Reset         | Alternate Function |  |
|--------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------|--|
| INTP0 to INTP4           | Input  | External maskable interrupt input whose valid edge (rising edge, falling edge, or both rising and falling edges) can be specified | Input               | P00 to P04         |  |
| SI30                     | Input  | Serial data input to serial interface.                                                                                            | Input               | P70                |  |
| S131                     | -      |                                                                                                                                   |                     | P74                |  |
| S132                     |        |                                                                                                                                   |                     | P120               |  |
| SI321                    |        |                                                                                                                                   |                     | P123               |  |
| SO30                     | Output | Serial data output from serial interface.                                                                                         | Input               | P71                |  |
| SO31                     |        |                                                                                                                                   |                     | P75                |  |
| SO32                     |        |                                                                                                                                   |                     | P121               |  |
| SO321                    |        |                                                                                                                                   |                     | P124               |  |
| SCK30                    | I/O    | Serial clock input/output to/from serial interface.                                                                               | Input               | P72                |  |
| SCK31                    |        |                                                                                                                                   |                     | P76                |  |
| SCK32                    |        |                                                                                                                                   |                     | P122               |  |
| SCK321                   |        |                                                                                                                                   |                     | P125               |  |
| TI50                     | Input  | External count clock input to 8-bit timer 50                                                                                      | Input               | P33                |  |
| TI51                     |        | External count clock input to 8-bit timer 51                                                                                      | ]                   | P34                |  |
| TI52                     |        | External count clock input to 8-bit timer 52                                                                                      |                     | P77                |  |
| TO50                     | Output | 8-bit timer 50 output                                                                                                             | Low-level<br>output | P130               |  |
| TO51                     |        | 8-bit timer 51 output                                                                                                             |                     | P131               |  |
| TO52                     |        | 8-bit timer 52 output                                                                                                             |                     | P132               |  |
| BEEP0                    | Output | Buzzer output                                                                                                                     | Input               | P36                |  |
| BUZ                      |        |                                                                                                                                   |                     | P37                |  |
| ANI0 to ANI5             | Input  | Analog input to A/D converter Input P10 to                                                                                        |                     | P10 to P15         |  |
| EO0, EO1                 | Output | Error out output from charge pump of PLL frequency synthesizer                                                                    | -                   | _                  |  |
| VCOL                     | Input  | Inputs local oscillation frequency of PLL (in HF and MF modes)                                                                    |                     | -                  |  |
| VCOH                     |        | Inputs local oscillation frequency of PLL (in VHF mode)                                                                           |                     |                    |  |
| AMIFC                    | Input  | Input to AM intermediate frequency counter                                                                                        | Input               | _                  |  |
| FMIFC                    |        | Input to FM or AM intermediate frequency counter                                                                                  |                     |                    |  |
| RESET                    | Input  | System reset input                                                                                                                | -                   | _                  |  |
| X1                       | Input  | Connection of crystal resonator for system clock oscillation.                                                                     | -                   | _                  |  |
| X2                       | _      |                                                                                                                                   | -                   | _                  |  |
| REGOSC                   | -      | Regulator for oscillator. Connect this pin to GND via 0.1 $\mu$ F capacitor.                                                      | -                   | -                  |  |
| REGCPU                   | -      | Regulator for CPU power supply. Connect this pin to GND via 0.1 $\mu$ F capacitor.                                                | -                   | -                  |  |
| Vdd                      | -      | Positive power supply                                                                                                             | -                   | -                  |  |
| GND                      | -      | Ground                                                                                                                            | -                   | _                  |  |
|                          | -      | Port power supply                                                                                                                 | -                   | -                  |  |
| GNDPORT                  | -      | Port ground                                                                                                                       | -                   | -                  |  |
| VDDPLLNote 1             | _      | PLL positive power supply                                                                                                         | -                   | -                  |  |
| GNDPLL <sup>Note 1</sup> | -      | PLL ground                                                                                                                        | -                   | -                  |  |
| IC                       | -      | Internally connected. Directly connect this pin to GND. – –                                                                       |                     |                    |  |
| VPPNote 2                | -      | Pin to apply high voltage at program writing/verifying.<br>Directly connect this pin to GND in normal operating mode.             | -                   | -                  |  |

## (2) Pins other than port pins

Notes 1. Connect a capacitor of about 1000 pF between the VDDPLL and GNDPLL pins.

**2.** μPD178F054 only.

#### 2.2 Description of Pin Functions

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

P00 to P06 constitute a 7-bit I/O port. In addition to I/O port pins, P00 to P06 also function as external interrupt inputs. The following operating modes can be specified in 1-bit units.

#### (1) Port mode

These pins function as a 7-bit I/O port for which input or output can be specified in 1-bit units using port mode register 0 (PM0).

#### (2) Control mode

These pins function as external interrupt input pins (INTP0 to INTP4).

These external interrupt input pins can specify valid edges (rising edge, falling edge, and both rising and falling edges).

#### 2.2.2 P10 to P15 (Port 1)

P10 to P15 constitute a 6-bit input port. In addition to input port pins, P10 to P15 function as A/D converter analog inputs.

The following operating modes can be specified in 1 bit units.

#### (1) Port mode

These pins function as a 6-bit input port.

#### (2) Control mode

These pins function as A/D converter analog input pins (ANI0 to ANI5).

#### 2.2.3 P30 to P37 (Port 3)

P30 to P37 constitute an 8-bit I/O port . In addition to I/O port pins, P30 to P37 function as timer inputs and buzzer outputs.

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

#### (1) Port mode

These pins function as an 8-bit I/O port for which input or output can be specified in 1-bit units using port mode register 3 (PM3).

#### (2) Control mode

These pins function as timer inputs (TI50, T51) and buzzer outputs (BEEP0, BUZ).

#### (a) TI50, TI51

Pins for external clock input to the 8-bit timer/event counter.

#### (b) BEEP0, BUZ

Buzzer output pins.

#### 2.2.4 P40 to P47 (Port 4)

P40 to P47 constitute an 8-bit I/O port.

These pins can be specified as input or output in 1-bit units using port mode register 4 (PM4).

On-chip pull-up resistors can be specified by pull-up resistor option register 4 (PU4). An interrupt function via key input is also provided.

#### 2.2.5 P50 to P57 (Port 5)

P50 to P57 constitute an 8-bit I/O port.

These pins can be specified as input or output in 1-bit units using port mode register 5 (PM5).

#### 2.2.6 P60 to P67 (Port 6)

P60 to P67 constitute an 8-bit port.

These pins can be specified as input or output in 1-bit units using port mode register 6 (PM6).

#### 2.2.7 P70 to P77 (Port 7)

P70 to P77 pins constitute an 8-bit I/O port. In addition to port pins, P70 to P77 also function as serial interface data I/O, clock I/O, and a timer input.

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

#### (1) Port mode

These pins function as an 8-bit I/O port for which input or output can be specified in 1-bit units using port mode register 7 (PM7).

#### (2) Control mode

These pins function as serial interface data I/O, clock I/O, and timer input pins.

#### (a) SI30, SO30, SI31, SO31

Serial data I/O pins of the serial interface.

#### (b) SCK30, SCK31

Serial clock I/O pins of the serial interface.

(c) TI52

External clock input pin to 8-bit timer/event counter.

#### 2.2.8 P120 to P125 (Port 12)

P120 to P125 constitute a 6-bit I/O port. In addition to I/O port pins, P120 to P125 also function as serial interface data I/O and clock I/O.

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

#### (1) Port mode

These pins function as an 8-bit I/O port for which input or output can be specified in 1-bit units using port mode register 7 (PM7).

#### (2) Control mode

These pins function as serial interface data I/O and clock I/O pins.

#### (a) SI32, SO32, SI321, SO321

Serial data I/O pins of the serial interface.

#### (b) SCK32, SCK321

Serial clock I/O pins of the serial interface.

#### 2.2.9 P130 to P132 (Port 13)

P130 to P132 constitute a 3-bit N-ch open-drain output port with a 12 V tolerance. In addition to output port pins,

P130 to P132 also function as timer outputs.

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

#### (1) Port mode

These pins function as a 3-bit output port.

#### (2) Control mode

These pins function as output pins for the 8-bit timer/event counter.

#### TO50, TO51, TO52

These pins are output pins for the 8-bit timer/event counter.

#### 2.2.10 EO0, EO1

These are the output pins of the charge pump of the PLL frequency synthesizer.

They output the result of phase comparison between the frequency divided by the programmable divider of the local oscillation input (VCOL and VCOH pins) and the reference frequency.

#### 2.2.11 VCOL, VCOH

These pins input the local oscillation frequency (VCO) of the PLL.

Because signals are input to these pins via an AC amplifier, cut the DC component of the input signals using a capacitor.

- VCOL
  - HF, MF input
  - This pin becomes active when the HF or MF mode is selected by software; otherwise, the pin is in the status set by bit 2 (VCOLDMD) of the PLL mode select register (PLLMD). If VCOLDMD is reset to 0 (to connect a pull-down resistor), however, the VCOL pin does not become active even if the HF or MF mode is selected. In this case, set VCOLDMD to 1 (high-impedance state).

#### • VCOH

- VHF input
- This pin becomes active when the FM mode is selected by software; otherwise the pin is in the status set by bit 3 (VCOHDMD) of the PLL mode select register (PLLMD). If VCOHDMD is reset to 0 (to connect a pull-down resistor), however, the VCOL pin does not become active even if the FM mode is selected. In this case, set VCOHDMD to 1 (high-impedance state).

#### 2.2.12 AMIFC

Input pin of the AM intermediate frequency counter.

#### 2.2.13 FMIFC

Input pin of the FM intermediate frequency counter or AM intermediate frequency counter.

#### 2.2.14 RESET

Low-level active system reset input pin.

#### 2.2.15 X1, X2

Crystal resonator connection pins for system clock oscillation.

#### 2.2.16 REGOSC

Regulator pin for oscillator. Connect to GND via a 0.1  $\mu$ F capacitor.

#### 2.2.17 REGCPU

Regulator pin for CPU power supply. Connect to GND via a 0.1  $\mu$ F capacitor.

#### 2.2.18 VDD

Positive power supply pin.

#### 2.2.19 GND

Ground potential pin.

#### 2.2.20 VDDPORT

Positive power supply pin for port.

#### 2.2.21 GNDPORT

Ground potential pin for port.

#### 2.2.22 VDDPLL

Positive power supply pin for PLL.

#### 2.2.23 GNDPLL

Ground potential pin for PLL.

#### 2.2.24 VPP (μPD178F054 only)

This pin applies a high voltage when the flash memory programming mode is set or when a program is written or verified.

In the normal operation mode, directly connect this pin to GND.

#### 2.2.25 IC (Mask ROM version only)

The IC (Internally Connected) pin is provided to set the test mode to check the  $\mu$ PD178054 Subseries at delivery. Connect it directly to the GND pin with the shortest possible wire in the normal operating mode.

When a potential difference is produced between the IC pin and GND pin because the wiring between those two pins is too long or an external noise is input to the IC pin, the user's program may not run normally.

#### $\bigcirc$ Connect IC pin to GND pin directly.



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

Table 2-1 shows the types of the I/O circuits of the respective pins and the recommended connections of the pins when they are not used. For the configuration of the I/O circuit of each pin, refer to Figure 2-1.

| Pin Name               | I/O Circuit Type | I/O    | Recommended Connection of Unused Pin                                                                                                    |  |
|------------------------|------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| P00/INTP0 to P04/INTP4 | 8                | I/O    | Input: Connect to VDD, VDDPORT, GND, or GNDPORT via a resistor.                                                                         |  |
| P05, P06               |                  |        | Output: Leave open.                                                                                                                     |  |
| P10/ANI0 to P15/ANI5   | 25               | Input  | Connect to VDD, VDDPORT, GND, or GNDPORT.                                                                                               |  |
| P30 to P32             | 5                | I/O    | Input: Connect to VDD, VDDPORT, GND, or GNDPORT via a resistor.                                                                         |  |
| P33/TI50               | 5-K              |        | Output: Leave open.                                                                                                                     |  |
| P34/TI51               |                  |        |                                                                                                                                         |  |
| P35                    | 5                |        |                                                                                                                                         |  |
| P36/BEEP0              |                  |        |                                                                                                                                         |  |
| P37/BUZ                |                  |        |                                                                                                                                         |  |
| P40 to P47             | 5-A              |        |                                                                                                                                         |  |
| P50 to P57             | 5                |        |                                                                                                                                         |  |
| P60 to P67             |                  |        |                                                                                                                                         |  |
| P70/SI30               | 5-K              |        |                                                                                                                                         |  |
| P71/SO30               | 5                |        |                                                                                                                                         |  |
| P72/SCK30              | 5-K              |        |                                                                                                                                         |  |
| P73                    | 5                |        |                                                                                                                                         |  |
| P74/SI31               | 5-K              |        |                                                                                                                                         |  |
| P75/SO31               | 5                |        |                                                                                                                                         |  |
| P76/SCK31              | 5-K              | -      |                                                                                                                                         |  |
| P77/TI52               |                  |        |                                                                                                                                         |  |
| P120/SI32              |                  |        |                                                                                                                                         |  |
| P121/SO32              | 5                |        |                                                                                                                                         |  |
| P122/SCK32             | 5-K              | -      |                                                                                                                                         |  |
| P123/SI321             |                  |        |                                                                                                                                         |  |
| P124/SO321             | 5                |        |                                                                                                                                         |  |
| P125/SCK321            | 5-K              |        |                                                                                                                                         |  |
| P130/TO50              | 19               | Output | Leave open.                                                                                                                             |  |
| P131/TO51              |                  |        |                                                                                                                                         |  |
| P132/TO52              |                  |        |                                                                                                                                         |  |
| EO0, EO1               | DTS-EO1          |        |                                                                                                                                         |  |
| VCOL, VCOH             | DTS-AMP          | Input  | Disable PLL in software and select pull-down.                                                                                           |  |
| AMIFC, FMIFC           |                  |        | Set these pins in general-purpose input port mode by software and connect each of them to VDD, VDDPORT, GND, or GNDPORT via a resistor. |  |
| REGOSC, REGCPU         | -                | _      | Connect these pins to GND via 0.1 $\mu$ F capacitor.                                                                                    |  |
| RESET                  | 2                | Input  | _                                                                                                                                       |  |
| VDDPLL                 | -                | _      | Connect to VDD.                                                                                                                         |  |
| GNDPLL                 |                  |        | Directly connect to GND or GNDPORT.                                                                                                     |  |
| IC (Mask ROM version)  |                  |        |                                                                                                                                         |  |
| VPP (µPD178F054)       | 1                |        |                                                                                                                                         |  |

#### Table 2-1. Pin I/O Circuit Type and Recommended Connections of Unused Pins



Figure 2-1. Pin I/O Circuits (1/2)

**Remark** VDD and GND are the positive power supply and ground pins for all port pins. Read VDD and GND as VDDPORT and GNDPORT.



Figure 2-1. Pin I/O Circuits (2/2)

Note This switch is selectable by software only for the VCOL and VCOH pins.

**Remark** VDD and GND are the positive power supply and ground pins for all port pins. Read VDD and GND as VDDPORT and GNDPORT.

# CHAPTER 3 CPU ARCHITECTURE

# 3.1 Memory Space

The initial value of the memory size switching register (IMS) is CFH. The following values must be set to the registers of each model.

| Part Number | IMS                                  |
|-------------|--------------------------------------|
| μPD178053   | С6Н                                  |
| μPD178054   | С8Н                                  |
| μPD178F054  | Value equivalent to mask ROM version |

# **(1)** μ**PD178053**

Set the value of the memory size switching register (IMS) to C6H. The initial value is CFH.



Figure 3-1. Memory Map of  $\mu$ PD178053

# **(2)** μ**PD178054**

Set the value of the memory size switching register (IMS) to C8H. The initial value is CFH.





# (3) µPD178F054

Set the value of the memory size switching register (IMS) to the value corresponding to that of the mask ROM versions. The initial value is CFH.





#### 3.1.1 Internal program memory space

Programs and table data are stored in internal program memory space, and are usually addressed by the program counter (PC).

The  $\mu$ PD178054 Subseries has internal ROM (or flash memory) as shown in the following table.

| Part Number | Structure    | Capacity                               |
|-------------|--------------|----------------------------------------|
| μPD178053   | Mask ROM     | 24576 $\times$ 8 bits (0000F to 5FFFH) |
| μPD178054   |              | 32768 $\times$ 8 bits (0000H to 7FFFH) |
| μPD178F054  | Flash memory |                                        |

#### Table 3-1. Internal Memory Capacities

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

#### (1) Vector table area

The 64-byte area 0000H to 003FH is reserved as a vector table area. The reset input and program start addresses for branch upon generation of each interrupt request are stored in the vector table area. Of the 16-bit address, the lower 8 bits are stored at even addresses and the higher 8 bits are stored at odd addresses.

| Vector Table Address | Interrupt Request |
|----------------------|-------------------|
| 0004H                | INTWDT            |
| 0006H                | INTP0             |
| 0008H                | INTP1             |
| 000AH                | INTP2             |
| 000CH                | INTP3             |
| 000EH                | INTP4             |
| 0010H                | INTKY             |
| 0012H                | INTCSI31          |
| 0014H                | INTBTM0           |
| 0016H                | INTAD3            |
| 0018H                | INTCSI32          |
| 001AH                | INTCSI30          |
| 001CH                | INTTM50           |
| 001EH                | INTTM51           |
| 0020H                | INTTM52           |
| 0022H                | INTTM53           |
| 003EH                | BRK               |

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

#### (2) CALLT instruction table area

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

#### (3) CALLF instruction entry area

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

#### 3.1.2 Internal data memory space

The  $\mu$ PD178054 Subseries products incorporate the following RAMs.

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

The  $\mu$ PD178053, 178054, and 178F054 have a RAM structure of 1024 × 8 bits. In this area, four banks of general-purpose registers, each bank consisting of eight 8-bit registers, are allocated in the 32-byte area FEE0H to FEFFH.

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

# 3.1.3 Special Function Register (SFR) area

An on-chip peripheral hardware special function register (SFR) is allocated in the area FF00H to FFFFH. Refer to **Table 3-4 Special Function Registers**.

Caution Do not access addresses where the SFR is not assigned.

#### 3.1.4 Data memory addressing

Addressing refers to the method of specifying the address of the instruction to be executed next or the address of the register or memory relevant to the execution of instructions.

The address of an instruction to be executed next is addressed by the program counter (PC) (for details, refer to 3.3 Instruction Address Addressing).

Several addressing modes are provided for addressing the memory relevant to the execution of instructions for the µPD178054 Subseries, based on operability and other considerations. For areas containing data memory in particular, special addressing methods designed for the functions of special function registers (SFR) and generalpurpose registers are available for use. Data memory addressing is illustrated in Figures 3-4 to 3-6. For the details of each addressing mode, refer to 3.4 Operand Address Addressing.



Figure 3-4. Data Memory Addressing of µPD178053



Figure 3-5. Data Memory Addressing of  $\mu$ PD178054



Figure 3-6. Data Memory Addressing of  $\mu$ PD178F054

# 3.2 Processor Registers

The  $\mu$ PD178054 Subseries units incorporate the following processor registers.

#### 3.2.1 Control registers

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

# (1) Program counter (PC)

The program counter is a 16-bit register 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 and register contents are set. Reset input sets the reset vector table values at addresses 0000H and 0001H to the program counter.

#### Figure 3-7. Configuration of Program Counter

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

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

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

#### Figure 3-8. Configuration of Program Status Word



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

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

When IE = 0, all the interrupts are disabled (DI) except the non-maskable interrupt.

When IE = 1, the interrupts are enabled (EI). At this time, the acknowledging of interrupts is controlled by the in-service priority flag (ISP), the interrupt mask flag corresponding to each interrupt, and the interrupt priority specification flag.

The IE is reset to 0 upon DI instruction execution or interrupt acknowledgement 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) Register bank select flags (RBS0 and RBS1)

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

# (d) Auxiliary carry flag (AC)

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

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

This flag manages the priority of acknowledgeable maskable vectored interrupts.

When ISP = 0, acknowledging the vectored interrupt requests to which a low priority is assigned by the priority specification flag registers (PR0L, PR0H) (refer to **12.3 (3) Priority specification flag registers (PR0L, PR0H)** is disabled. Whether an interrupt request is actually accepted depends on the status of the interrupt enable flag (IE).

# (f) Carry flag (CY)

This flag stores overflow and underflow upon add/subtract instruction execution. It stores the shift-out value upon rotate instruction execution and functions as a bit accumulator during bit manipulation 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 (FB00H to FEFFH for  $\mu$ PD178053, 178054, and 178F054) can be set as the stack area.



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

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

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

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





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



#### 3.2.2 General-purpose registers

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

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

They can be written with function names (X, A, C, B, E, D, L, H, AX, BC, DE, and HL) and absolute names (R0 to R7 and RP0 to RP3).

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

| Bank  | Reg           | Register      |   |         | sol |   |                             | Bank  | Reg | ister |      | At  | osol | ute |   |
|-------|---------------|---------------|---|---------|-----|---|-----------------------------|-------|-----|-------|------|-----|------|-----|---|
|       | Function Name | Absolute Name |   | Address |     |   | Function Name Absolute Name |       |     | A     | ddre | ess |      |     |   |
| BANK0 | Н             | R7            | F | Е       | F   | F | Н                           | BANK2 | н   | R7    | F    | Е   | Е    | F   | Н |
|       | L             | R6            | F | Е       | F   | Е | Н                           |       | L   | R6    | F    | Е   | Е    | Е   | Н |
|       | D             | R5            | F | Е       | F   | D | Н                           |       | D   | R5    | F    | Е   | Е    | D   | Н |
|       | E             | R4            | F | Е       | F   | С | Н                           |       | E   | R4    | F    | Е   | Е    | С   | Н |
|       | В             | R3            | F | Е       | F   | В | Н                           |       | В   | R3    | F    | Е   | Е    | В   | Н |
|       | С             | R2            | F | Е       | F   | А | Н                           |       | С   | R2    | F    | Е   | Е    | А   | Н |
|       | A             | R1            | F | Е       | F   | 9 | Н                           |       | A   | R1    | F    | Е   | Е    | 9   | Н |
|       | X             | R0            | F | Е       | F   | 8 | Н                           |       | Х   | R0    | F    | Е   | Е    | 8   | Н |
| BANK1 | н             | R7            | F | Е       | F   | 7 | Н                           | BANK3 | н   | R7    | F    | Е   | Е    | 7   | Н |
|       | L             | R6            | F | Е       | F   | 6 | Н                           |       | L   | R6    | F    | Е   | Е    | 6   | Н |
|       | D             | R5            | F | Е       | F   | 5 | Н                           |       | D   | R5    | F    | Е   | Е    | 5   | Н |
|       | E             | R4            | F | Е       | F   | 4 | Н                           |       | E   | R4    | F    | Е   | Е    | 4   | Н |
|       | В             | R3            | F | Е       | F   | 3 | Н                           |       | В   | R3    | F    | Е   | Е    | 3   | Н |
|       | С             | R2            | F | Е       | F   | 2 | Н                           |       | С   | R2    | F    | Е   | Е    | 2   | Н |
|       | A             | R1            | F | Е       | F   | 1 | Н                           |       | А   | R1    | F    | Е   | Е    | 1   | Н |
|       | Х             | R0            | F | Е       | F   | 0 | Н                           |       | Х   | R0    | F    | Е   | Е    | 0   | Н |

Table 3-3. Absolute Address of General-Purpose Registers



# Figure 3-12. Configuration of General-Purpose Register

# (a) Absolute Name

# (b) Function Name



# 3.2.3 Special Function Registers (SFR)

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

SFRs are can be manipulated like general-purpose registers, using operation, transfer and bit manipulation instructions. The manipulatable bit units: 1, 8, and 16, depends on the special function register type.

The manipulatable bit units can be specified as follows.

# • 1-bit manipulation

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

# • 8-bit manipulation

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

# • 16-bit manipulation

Use the symbol reserved in the assembler for the 16-bit manipulation instruction operand (sfrp). When addressing an address, use an even address.

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

# Symbol

This is a symbol to indicate an address of the special function register.

These symbols are reserved for the DF178054 and RA78K0, and defined by header file sfrbit.h for the CC78K0.

They can be written as instruction operands when the RA78K0, ID78K0, or ID78K0-NS is used.

# • R/W

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

R/W: Read/write enable

R: Read only

R&Reset: Read only (reset to 0 when read)

W: Write only

# • Bit units for manipulation

○ indicates the manipulatable bit units: 1, 8, and 16. – indicates the bit units that cannot be manipulated.

# • After reset

Indicates each register status upon reset. The values of special function registers whose addresses are not shown in the table are undefined at reset.

| Address | Special Function Register (SFR) Name               | Symbol   | R/W     | Bit Units | s for Man | ipulation | After Reset                |
|---------|----------------------------------------------------|----------|---------|-----------|-----------|-----------|----------------------------|
|         |                                                    |          |         | 1 Bit     | 8 Bits    | 16 Bits   |                            |
| FF00H   | Port 0                                             | P0       | R/W     | 0         | 0         | —         | 00H                        |
| FF01H   | Port 1                                             | P1       | R       | 0         | 0         | _         |                            |
| FF03H   | Port 3                                             | P3       | R/W     | 0         | 0         | _         |                            |
| FF04H   | Port 4                                             | P4       |         | 0         | 0         | _         |                            |
| FF05H   | Port 5                                             | P5       |         | 0         | 0         | -         |                            |
| FF06H   | Port 6                                             | P6       |         | 0         | 0         | _         |                            |
| FF07H   | Port 7                                             | P7       |         | 0         | 0         | —         |                            |
| FF0CH   | Port 12                                            | P12      |         | 0         | 0         | -         |                            |
| FF0DH   | Port 13                                            | P13      |         | 0         | 0         | _         |                            |
| FF10H   | A/D conversion result register 3 <sup>Note 1</sup> | ADCR3    | _       | _         | _         | _         | _                          |
| FF11H   |                                                    |          | R       | _         | 0         | -         | Undefined                  |
| FF12H   | A/D converter mode register 3                      | ADM3     | R/W     | 0         | 0         | _         | 00H                        |
| FF13H   | Analog input channel specification register 3      | ADS3     |         | _         | 0         | _         |                            |
| FF15H   | Power-fail comparison threshold value register 3   | PFT3     |         | _         | 0         | _         |                            |
| FF16H   | Power-fail comparison mode register 3              | PFM3     |         | 0         | 0         | _         |                            |
| FF1BH   | POC status register                                | POCS     | R&Reset | _         | 0         | _         | Retained <sup>Note 2</sup> |
| FF20H   | Port mode register 0                               | PM0      | R/W     | 0         | 0         | _         | FFH                        |
| FF23H   | Port mode register 3                               | PM3      |         | 0         | 0         | _         |                            |
| FF24H   | Port mode register 4                               | PM4      |         | 0         | 0         | —         |                            |
| FF25H   | Port mode register 5                               | PM5      |         | 0         | 0         | -         |                            |
| FF26H   | Port mode register 6                               | PM6      |         | 0         | 0         | _         |                            |
| FF27H   | Port mode register 7                               | PM7      |         | 0         | 0         | _         |                            |
| FF2CH   | Port mode register 12                              | PM12     |         | 0         | 0         | _         |                            |
| FF34H   | Pull-up resistor option register 4                 | PU4      |         | 0         | 0         | _         | 00H                        |
| FF40H   | Clock output select register                       | CKS      |         | 0         | 0         | _         |                            |
| FF41H   | BEEP clock select register 0                       | BEEPCL0  |         | 0         | 0         | _         |                            |
| FF42H   | Watchdog timer clock select register               | WDCS     |         | 0         | 0         | _         |                            |
| FF48H   | External interrupt rising edge enable register     | EGP      |         | 0         | 0         | —         |                            |
| FF49H   | External interrupt falling edge enable register    | EGN      |         | 0         | 0         | —         |                            |
| FF69H   | Serial port select register 32                     | SIO32SEL |         | 0         | 0         | _         |                            |
| FF6AH   | Serial I/O shift register 32                       | SIO32    |         | _         | 0         | _         | Undefined                  |
| FF6BH   | Serial operating mode register 32                  | CSIM32   |         | 0         | 0         | —         | 00H                        |
| FF6CH   | Serial I/O shift register 31                       | SIO31    |         | _         | 0         | -         | Undefined                  |
| FF6DH   | Serial operating mode register 31                  | CSIM31   |         | 0         | 0         | _         | 00H                        |

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

Notes 1. This register can be accessed only in 8-bit units. When ADCR3 is read, the value of FF11H is read.

2. The value of this register is 03H only at reset by power-on clear. This register is not reset by the RESET pin or watchdog timer.

Caution Do not access addresses to which no SFR is assigned.

| Address | Special Function             | Register (SFR) Name | Syr   | nbol  | R/W     | Bit Units | s for Man | ipulation | After Reset                |
|---------|------------------------------|---------------------|-------|-------|---------|-----------|-----------|-----------|----------------------------|
|         |                              |                     |       |       |         | 1 Bit     | 8 Bits    | 16 Bits   |                            |
| FF6EH   | Serial I/O shift register 30 | )                   | SIO30 |       | R/W     | _         | 0         | _         | Undefined                  |
| FF6FH   | Serial operating mode re     | gister 30           | CSIM3 | 0     |         | 0         | 0         | _         | 00H                        |
| FF70H   | 8-bit compare register 52    | CR52                |       | W     | _       | 0         | _         | Undefined |                            |
| FF71H   | 8-bit compare register 53    |                     | CR53  |       |         | _         | 0         | _         |                            |
| FF72H   | 8-bit timer counter 52       |                     | TM523 | TM52  | R       | _         | 0         | 0         | 00H                        |
| FF73H   | 8-bit timer counter 53       |                     |       | TM53  |         | _         | 0         |           |                            |
| FF74H   | Timer clock select registe   | er 52               | TCL52 |       | R/W     | _         | 0         | _         |                            |
| FF75H   | 8-bit timer mode control r   | egister 52          | TMC52 | 2     |         | 0         | 0         | _         |                            |
| FF77H   | Timer clock select registe   | er 53               | TLC53 |       |         | _         | 0         | _         |                            |
| FF78H   | 8-bit timer mode control r   | egister 53          | TMC53 | }     |         | 0         | 0         | _         |                            |
| FF80H   | 8-bit compare register 50    |                     | CR50  |       |         | _         | 0         | _         | Undefined                  |
| FF81H   | 8-bit compare register 51    |                     | CR51  |       |         | _         | 0         | _         |                            |
| FF82H   | 8-bit timer counter 50       |                     | TM501 | TM50  | R       | _         | 0         | 0         | 00H                        |
| FF83H   | 8-bit timer counter 51       |                     |       | TM51  |         | _         | 0         | -         |                            |
| FF84H   | Timer clock select registe   | er 50               | TCL50 |       | R/W     | _         | 0         | —         |                            |
| FF85H   | 8-bit timer mode control r   | egister 50          | TMC50 | )     |         | 0         | 0         | _         |                            |
| FF87H   | Timer clock select registe   | er 51               | TCL51 |       |         | _         | 0         | _         |                            |
| FF88H   | 8-bit timer mode control r   | egister 51          | TMC51 |       |         | 0         | 0         | _         |                            |
| FFA0H   | PLL mode select register     |                     | PLLMC | )     |         | 0         | 0         | _         |                            |
| FFA1H   | PLL reference mode regi      | ster                | PLLRF |       |         | 0         | 0         | _         | 0FH                        |
| FFA2H   | PLL unlock F/F judge reg     | ister               | PLLUL |       | R&Reset | 0         | 0         | —         | Retained <sup>Note 1</sup> |
| FFA3H   | PLL data transfer registe    | r                   | PLLNS |       | W       | 0         | 0         | _         | 00H                        |
| FFA6H   | PLL data registers           | PLL data register L | PLLR  | PLLRL | R/W     | 0         | 0         | 0         | Undefined                  |
| FFA7H   |                              | PLL data register H |       | PLLRH |         | 0         | 0         | -         |                            |
| FFA8H   | PLL data register 0          |                     | PLLR0 |       |         | 0         | 0         | _         |                            |
| FFA9H   | IF counter mode select re    | egister             | IFCMD |       |         | 0         | 0         | _         | 00H                        |
| FFAAH   | DTS system clock select      | DTSCK               | <     |       | 0       | 0         | _         | 00HNote 2 |                            |
| FFABH   | IF counter gate judge reg    | IFCJG               |       | R     | 0       | 0         | _         | 00H       |                            |
| FFACH   | IF counter control registe   | IFCCR               |       | W     | 0       | 0         | _         |           |                            |
| FFAEH   | IF counter register          | IFCR                | IFCRL | R     |         |           | 0         |           |                            |
| FFAFH   |                              |                     |       | IFCRH |         | _         | _         |           |                            |

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

Notes 1. Undefined by power-on clear reset only.

2. Though the initial value of the DTS system clock select register (DTSCK) is 00H, be sure to set this register to 01H before using it.

# Caution Do not access addresses to which no SFR is assigned.

| Address             | Special Function Register (SFR) Name              | Sy   | mbol | R/W | Bit Units | for Man | ipulation | After Reset |
|---------------------|---------------------------------------------------|------|------|-----|-----------|---------|-----------|-------------|
|                     |                                                   |      |      |     | 1 Bit     | 8 Bits  | 16 Bits   |             |
| FFD0H<br> <br>FFDFH | External access area <sup>Note 1</sup>            |      |      | R/W | 0         | 0       | _         | Undefined   |
| FFE0H               | Interrupt request flag register 0L                | IF0  | IF0L |     | 0         | 0       | 0         | 00H         |
| FFE1H               | Interrupt request flag register 0H                |      | IF0H |     | 0         | 0       |           |             |
| FFE4H               | Interrupt mask flag register 0L                   | MK0  | MK0L |     | 0         | 0       | 0         | FFH         |
| FFE5H               | Interrupt mask flag register 0H                   |      | мкон |     | 0         | 0       |           |             |
| FFE8H               | Priority specification flag register 0L           | PR0  | PR0L |     | 0         | 0       | 0         |             |
| FFE9H               | Priority specification flag register 0H           |      | PR0H |     | 0         | 0       |           |             |
| FFF0H               | Memory size switching register                    | IMS  |      |     | _         | 0       | —         | CFHNote 2   |
| FFF4H               | Internal expansion RAM size switching register    | IXS  |      |     | _         | 0       | —         | 0CHNote 3   |
| FFF9H               | Watchdog timer mode register                      | WDTN | 1    |     | 0         | 0       | _         | 00H         |
| FFFAH               | Oscillation stabilization time switching register | OSTS |      |     | _         | 0       | —         | 04H         |
| FFFBH               | Processor clock control register                  | PCC  |      |     | 0         | 0       | —         |             |

| Table 3-4. | Special | Function  | Registers | (3/3) |
|------------|---------|-----------|-----------|-------|
|            | opeciai | i unction | Registers | (3/3) |

 $\star$ 

**Notes 1.** The external access area cannot be accessed by means of SFR addressing. Use direct addressing to access this area.

**2.** The initial value of the memory size switching register (IMS) is CFH. Set the values of these registers of each model as follows:

| Part Number | IMS                                  |
|-------------|--------------------------------------|
| μPD178053   | С6Н                                  |
| μPD178054   | С8Н                                  |
| μPD178F054  | Value equivalent to mask ROM version |

**3.** Do not assign a value other than the initial value to the internal expansion RAM size switching register (IXS).

Caution Do not access addresses to which no SFR is assigned.

# 3.3 Instruction Address Addressing

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

# 3.3.1 Relative addressing

# [Function]

The value obtained by adding 8-bit immediate data (displacement value: jdisp8) of an instruction code to the start address of the following instruction is transferred to the program counter (PC) and branched. The displacement value is treated as signed two's complement data (-128 to +127) and bit 7 becomes a sign bit. That is, using relative addressing, the program branches in the range -128 to +127 relative to the first address of the next instruction. This function is carried out when the BR \$addr16 instruction or a conditional branch instruction is executed.

#### [Illustration]



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

#### 3.3.2 Immediate addressing

#### [Function]

Immediate data in the instruction word is transferred to the program counter (PC) and branched.

This function is carried out when the CALL !addr16 or BR !addr16 or CALLF !addr11 instruction is executed. The CALL !addr16 and BR !add16 instructions can be used to branch to any location in the memory. The CALLF !addr11 instruction is used to branch to the area between 0800H through 0FFFH.

# [Illustration]

In the case of CALL !addr16 and BR !addr16 instructions



In the case of CALLF !addr11 instruction



#### 3.3.3 Table indirect addressing

# [Function]

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

This addressing is used when the CALLT [addr5] instruction is executed. This instruction references an address stored in the memory table between 40H through 7FH, and can be used to branch to any location in the memory.

# [Illustration]



# 3.3.4 Register addressing

# [Function]

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

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

# [Illustration]



# 3.4 Operand Address Addressing

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

#### 3.4.1 Implied addressing

# [Function]

The registers that functions as an accumulator (A and AX) among the general-purpose registers are automatically addressed (implied). Of the  $\mu$ PD178054 Subseries instruction words, the following instructions employ implied addressing.

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

# [Operand format]

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

#### [Example]

In the case of MULU X

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

#### 3.4.2 Register addressing

#### [Function]

This addressing mode is used to access a general-purpose register as an operand. The register to be accessed is specified by the register bank select flags (RBS0 and RBS1) and the register specification codes (Rn and RPn) in the operation code.

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

#### [Operand format]

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

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

# [Example]

MOV A, C; when selecting C register as r



INCW DE; when selecting DE register pair as rp



# 3.4.3 Direct addressing

# [Function]

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

# [Operand format]

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

# [Example]

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



# [Illustration]



#### 3.4.4 Short direct addressing

# [Function]

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

The SFR area (FF00H to FF1FH) where short direct addressing is applied is one part of all the SFR areas. In this area, ports which are frequently accessed in a program and a compare register and a capture register of the timer/event counter are mapped and these SFRs can be manipulated with a small number of bytes and clocks. When 8-bit immediate data is at 20H to FFH, bit 8 of an effective address is set to 0. When it is at 00H to 1FH, bit 8 is set to 1. Refer to [Illustration] below.

# [Operand format]

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

# [Example]

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



# [Illustration]



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

# 3.4.5 Special Function Register (SFR) addressing

# [Function]

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

This addressing is applied to the 240-byte spaces FF00H to FFCFH and FFE0H to FFFFH. However, the SFR mapped at FF00H to FF1FH can be accessed with short direct addressing.

# [Operand format]

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

# [Example]

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

Operation code



# [Illustration]



#### 3.4.6 Register indirect addressing

#### [Function]

This addressing is used to address the memory to be manipulated by using the contents of the register pair specified by the register pair code in an instruction word as the operand address. The register pair specified is in the register bank specified by the register bank select flags (RBS0 and RBS1). This addressing can be used for the entire memory space.

# [Operand format]

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

# [Example]

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

Operation code

```
1 0 0 0 0 1 0 1
```

# [Illustration]



#### 3.4.7 Based addressing

# [Function]

This addressing mode is used to address a memory location specified by the result of adding the 8-bit immediate data to the contents of the HL register pair which is used as a base register. The HL register pair accessed is the register in the register bank specified by the register bank select flags (RBS0 and RBS1). 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]

| Symbol | Description |  |
|--------|-------------|--|
| —      | [HL + byte] |  |

# [Example]

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



#### 3.4.8 Based indexed addressing

#### [Function]

This addressing mode is used to address a memory location specified by the result of adding the contents of the B or C register specified in the instruction word to the contents of the HL register pair which is used as a base register. The HL, B, and C registers accessed are the registers in the register bank specified by the register bank select flags (RBS0 and RBS1).

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]

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

#### [Example]

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

Operation code

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

#### 3.4.9 Stack addressing

# [Function]

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

This addressing method is automatically employed when the PUSH, POP, subroutine call and RETURN instructions are executed or the register is saved/restored upon generation of an interrupt request. Stack addressing enables to address the internal high-speed RAM area only.

#### [Example]

In the case of PUSH DE

Operation code

10110101

# **CHAPTER 4 PORT FUNCTIONS**

# 4.1 Port Functions

The  $\mu$ PD178054 Subseries units incorporate input, output, and I/O ports consisting of 6, 3, and 53 pins, respectively. Figure 4-1 shows the port configuration. Every port is capable of 1-bit and 8-bit manipulations and can carry out considerably varied control operations. Besides port functions, the ports can also serve as on-chip hardware input/output pins.





# Table 4-1. Port Functions

| Pin Name   | I/O    | Function                                                                                                                                                                               | Alternate Function |
|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| P00 to P04 | I/O    | Port 0                                                                                                                                                                                 | INTP0 to INTP4     |
| P05, P06   | -      | 7-bit I/O port                                                                                                                                                                         |                    |
|            |        | Input/output can be specified in 1-bit units.                                                                                                                                          |                    |
| P10 to P15 | Input  | Port 1<br>6-bit input port                                                                                                                                                             | ANI0 to ANI5       |
| P30 to P32 | I/O    | Port 3                                                                                                                                                                                 |                    |
| P33        | -      | 8-bit I/O port                                                                                                                                                                         | TI50               |
| P34        | -      | Input/output can be specified in 1-bit units.                                                                                                                                          | TI51               |
| P35        | -      |                                                                                                                                                                                        |                    |
| P36        | -      |                                                                                                                                                                                        | BEEP0              |
| P37        | -      |                                                                                                                                                                                        | BUZ                |
| P40 to 47  | I/O    | Port 4<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.<br>An on-chip pull-up resistor can be specified by software.<br>Interrupt function by key input is provided. | _                  |
| P50 to P57 | I/O    | Port 5<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                              | _                  |
| P60 to P67 | I/O    | Port 6<br>8-bit I/O port<br>Input/output can be specified in 1-bit units.                                                                                                              | _                  |
| P70        | I/O    | Port 7                                                                                                                                                                                 | SI30               |
| P71        |        | 8-bit I/O port                                                                                                                                                                         | SO30               |
| P72        | -      | Input/output can be specified in 1-bit units.                                                                                                                                          | SCK30              |
| P73        |        |                                                                                                                                                                                        | —                  |
| P74        |        |                                                                                                                                                                                        | SI31               |
| P75        | -      |                                                                                                                                                                                        | SO31               |
| P76        |        |                                                                                                                                                                                        | SCK31              |
| P77        |        |                                                                                                                                                                                        | TI52               |
| P120       | I/O    | Port 12                                                                                                                                                                                | SI32               |
| P121       | 1      | 6-bit I/O port                                                                                                                                                                         | SO32               |
| P122       | 1      | Input/output can be specified in 1-bit units.                                                                                                                                          | SCK32              |
| P123       | 1      |                                                                                                                                                                                        | SI321              |
| P124       | 1      |                                                                                                                                                                                        | SO321              |
| P125       | 1      |                                                                                                                                                                                        | SCK321             |
| P130       | Output | Port 13                                                                                                                                                                                | TO50               |
| P131       | 1      | 3-bit output port                                                                                                                                                                      | TO51               |
| P132       | 1      | N-ch open-drain output port (12 V tolerance)                                                                                                                                           | TO52               |

# 4.2 Port Configuration

The ports consist of the following hardware.

| Table | 4-2. | Port | Configuration |
|-------|------|------|---------------|
|-------|------|------|---------------|

| Item             | Configuration                                      |
|------------------|----------------------------------------------------|
| Control register | Port mode register (PMm: m = 0, 3 to 7, 12)        |
| Port             | Total: 62 port pins (6 inputs, 3 outputs, 53 I/Os) |

# 4.2.1 Port 0

Port 0 is a 7-bit I/O port with an output latch. Input or output mode can be specified for port 0 in 1-bit units using port mode register 0 (PM0).

Alternate functions include external interrupt request input.

Reset input sets port 0 to the input mode.

Figures 4-2 and 4-3 show the block diagrams of port 0.

Caution Because port 0 also serves as an external interrupt request input, when the port function output mode is specified and the output level is changed, the interrupt request flag is set. Thus, when the output mode is used, set the interrupt mask flag to 1.





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





WR: Port 0 write signal

# 4.2.2 Port 1

Port 1 is a 6-bit input port.

Alternate functions include A/D converter analog input.

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





RD: Port 1 read signal

# 4.2.3 Port 3

Port 3 is an 8-bit I/O port with an output latch. Input or output mode can be specified for port 3 in 1-bit units using port mode register 3 (PM3).

Alternate functions include timer input and buzzer output.

Reset input sets port 3 to the input mode.

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





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









#### 4.2.4 Port 4

Port 4 is an 8-bit I/O port with an output latch. Input or output mode can be specified for port 4 in 1-bit units using port mode register 4 (PM4). Connection of pull-up resistors can be specified in 1-bit units using pull-up resistor option register 4 (PU4).

The interrupt request flag (KYIF) can be set to 1 by detecting key inputs. When using this function, be sure to set the MEM register to 01H.

Reset input sets port 4 to input mode.

Figures 4-8 and 4-9 show a block diagram of port 4 and block diagram of the key input detector, respectively.



Figure 4-8. Block Diagram of P40 to P47

PU: Pull-up resistor option register

PM: Port mode register

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

#### Figure 4-9. Block Diagram of Key Input Detector



Cautions 1. This register is valid only when the MEM register is set to 01H.

2. Key return can be detected only when all the pins of P40 to P47 are high level. When any one is low level, even if falling edge is generated at the other pins, the key return signal cannot be detected.

#### 4.2.5 Port 5

\*

Port 5 is an 8-bit I/O port with an output latch. Input or output mode can be specified for port 5 in 1-bit units using port mode register 5 (PM5).

Reset input sets port 5 to the input mode.

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





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

#### 4.2.6 Port 6

Port 6 is an 8-bit I/O port with an output latch. Input or output mode can be specified for port 6 in 1-bit units using port mode register 6 (PM6).

Reset input sets port 6 to the input mode.

Figure 4-11 shows the block diagram of port 6.





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

#### 4.2.7 Port 7

Port 7 is an 8-bit I/O port with an output latch. Input or output mode can be specified for port 7 in 1-bit units using port mode register 7 (PM7).

Alternate functions include serial interface data I/O, clock I/O, and timer input.

Reset input sets port 7 to the input mode.

Figures 4-12 to 4-15 show the block diagrams of port 7.





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

Figure 4-13. Block Diagram of P71 and P75



- PM: Port mode register
- RD: Port 7 read signal

WR: Port 7 write signal

Figure 4-14. Block Diagram of P72 and P76



Figure 4-15. Block Diagram of P73



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

#### 4.2.8 Port 12

Port 12 is a 6-bit I/O port with an output latch. Input or output mode can be specified for port 12 in 1-bit units using port mode register 12 (PM12).

Alternate functions include serial interface data I/O and clock I/O.

Reset input sets port 12 to the input mode.

Figures 4-16 to 4-18 show the block diagrams of port 12.





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

Figure 4-17. Block Diagram of P121 and P124





#### 4.2.9 Port 13

Port 13 is a 3-bit N-ch open-drain output port with an output latch.

The pins of this port are also used as timer output pins.

Reset input sets port 13 in the general-purpose output port mode.

The port 13 block diagram is shown in Figure 4-19.





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

#### 4.3 Registers Controlling Port Functions

The following two types of registers control the ports.

- Port mode registers (PM0, PM3 to PM7, PM12)
- Pull-up resistor option register (PU4)

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

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

PM0, PM3 to PM7, and PM12 are independently set with a 1-bit or 8-bit memory manipulation instruction. Reset input sets these registers to FFH.

When using a port pin as an alternate-function pin, set the values of the port mode registers and the output latches as shown in Table 4-3.

#### Cautions 1. P10 to P17 are input-only pins, and P130 to P132 are output-only pins.

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

| Pin Name     | Alternate F    | unctions | PM×× | P×× |
|--------------|----------------|----------|------|-----|
|              | Name           | I/O      |      |     |
| P00 to P04   | INTP0 to INTP4 | Input    | 1    | ×   |
| P33          | TI50           | Input    | 1    | ×   |
| P34          | TI51           | Input    | 1    | ×   |
| P36          | BEEP0          | Output   | 0    | 0   |
| P37          | BUZ            | Output   | 0    | 0   |
| P70          | SI30           | Input    | 1    | ×   |
| P71          | SO30           | Output   | 0    | 0   |
| P72          | SCK30          | Input    | 1    | ×   |
|              |                | Output   | 0    | 0   |
| P74          | SI31           | Input    | 1    | ×   |
| P75          | SO31           | Output   | 0    | 0   |
| P76          | SCK31          | Input    | 1    | ×   |
|              |                | Output   | 0    | 0   |
| P77          | TI52           | Input    | 1    | ×   |
| P120         | SI32           | Input    | 1    | ×   |
| P121         | SO32           | Output   | 0    | 0   |
| P122         | SCK32          | Input    | 1    | ×   |
|              |                | Output   | 0    | 0   |
| P123         | SI321          | Input    | 1    | ×   |
| P124         | SO321          | Output   | 0    | 0   |
| P125         | SCK321         | Input    | 1    | ×   |
|              |                | Output   | 0    | 0   |
| P130 to P132 | TO50 to TO52   | Output   | —    | 0   |

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

Caution When using the above alternate function pins as an output port, be sure to set the output latch ( $P \times x$ ) to 0.

Remark ×: Don't care

PM xx: Port mode register

Pxx: Output latch of port

\*

| R/W<br>R/W |
|------------|
| R/W        |
| R/W        |
|            |
|            |
| R/W        |
|            |
|            |
|            |

# Figure 4-20. Format of Port Mode Registers

| PMmn | Pmn pin input/output mode selection $(m = 0, 3 \text{ to } 7, 12 : n = 0 \text{ to } 7)$ |
|------|------------------------------------------------------------------------------------------|
| 0    | Output mode (output buffer on)                                                           |
| 1    | Input mode (output buffer off)                                                           |

#### (2) Pull-up resistor option register 4 (PU4)

This register is used to specify the use of the internal pull-up resistors of port 4. A pull-up resistor can only be used internally for the bit specified by PU4.

PU4 can be set with a 1-bit or 8-bit memory manipulation instruction.

Reset input sets PU4 to 00H.

#### Figure 4-21. Format of Pull-up Resistor Option Register 4 (PU4)

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Address | After reset | R/W |
|--------|------|------|------|------|------|------|------|------|---------|-------------|-----|
| PU4    | PU47 | PU46 | PU45 | PU44 | PU43 | PU42 | PU41 | PU40 | FF34H   | 00H         | R/W |

| PU4n | Selection of internal pull-up resistor for P4n (n = 0 to 7) |
|------|-------------------------------------------------------------|
| 0    | Internal pull-up resistor not used                          |
| 1    | Internal pull-up resistor used                              |

#### 4.4 Port Function Operations

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

#### 4.4.1 Writing to I/O ports

#### (1) Output mode

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

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

#### (2) Input mode

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

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

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

#### 4.4.2 Reading from I/O ports

#### (1) Output mode

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

#### (2) Input mode

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

#### 4.4.3 Operations on I/O ports

#### (1) Output mode

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

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

#### (2) Input mode

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

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

# CHAPTER 5 CLOCK GENERATOR

#### 5.1 Functions of Clock Generator

The clock generator generates the clock to be supplied to the CPU and peripheral hardware. This system clock oscillator is connected to 4.5 MHz crystal resonator. At this time, set bit 0 (DTSCK0) of the DTS system clock select register (DTSCK) to 1. Set the DTSCK0 flag after power application and reset by the RESET pin, and before using the basic timer, buzzer output control circuit, PLL frequency synthesizer, and frequency counter.

Oscillation can be stopped by executing the STOP instruction.

|        | Fig    | gure 5 | 5-1. F  | ormat  | of DT    | 'S Sys  | tem ( | Clock S | Select Regist | er (DTSCK)  |     |
|--------|--------|--------|---------|--------|----------|---------|-------|---------|---------------|-------------|-----|
| Symbol | 7      | 6      | 5       | 4      | 3        | 2       | 1     | <0>     | Address       | After reset | R/W |
| DTSCK  | 0      | 0      | 0       | 0      | 0        | 0       | 0     | DTSCK0  | FFAAH         | 00H         | R/W |
|        |        |        |         | -      |          | -       | _     |         |               |             |     |
|        | DTSCK0 |        |         | Select | s svstei | n clock | 1     |         |               |             |     |
|        | 1      | 4.5 M  | lHz     |        |          |         |       |         |               |             |     |
|        | 0      | Settir | ng proh | ibited |          |         |       |         |               |             |     |

# 5.2 Configuration of Clock Generator

The clock generator consists of the following hardware.

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

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





# 5.3 Register Controlling Clock Generator

The clock generator is controlled by the processor clock control register (PCC).

PCC sets the CPU clock.

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

Reset input sets PCC to 04H.

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

| Symbol | 7    | 6         | 5     | 4         | 3                            | 2    | 1    | 0    | Address | After reset | R/W                 |  |
|--------|------|-----------|-------|-----------|------------------------------|------|------|------|---------|-------------|---------------------|--|
| PCC    | 0    | 0         | 0     | 0         | 0                            | PCC2 | PCC1 | PCC0 | FFFBH   | 04H         | R/W <sup>Note</sup> |  |
|        |      |           |       |           |                              |      |      |      |         |             |                     |  |
| R/W    | PCC2 | PCC1      | PCC0  |           | CPU clock (fcpu) selection   |      |      |      |         |             |                     |  |
|        | 0    | 0         | 0     | fx        | < (0.45 μs)                  |      |      |      |         |             |                     |  |
|        | 0    | 0         | 1     | fx/2      | fx/2 (0.89 μs)               |      |      |      |         |             |                     |  |
|        | 0    | 1         | 0     | $fx/2^2$  | (1.78 μs                     | s)   |      |      |         |             |                     |  |
|        | 0    | 1         | 1     | $f_x/2^3$ | $f_{x}/2^{3}$ (3.56 $\mu$ s) |      |      |      |         |             |                     |  |
|        | 1    | 0         | 0     | fx/24     | f∞/2 <sup>4</sup> (7.11 μs)  |      |      |      |         |             |                     |  |
|        | Othe | er than a | above | Settin    | ietting prohibited           |      |      |      |         |             |                     |  |

Note Bits 3 to 7 are read only.

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

2. (): Minimum instruction execution time:  $2/f_{CPU}$  at fx = 4.5 MHz operation

#### 5.4 System Clock Oscillator

#### 5.4.1 System clock oscillator

The system clock oscillator oscillates with a crystal resonator (4.5 MHz TYP.) connected to the X1 and X2 pins. Figure 5-4 shows an external circuit of the system clock oscillator.

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

#### **Crystal oscillation**



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

Figure 5-5 shows examples of incorrectly connected resonators.



- (a) Wiring of connection circuits is too long
- (b) Signal lines cross each other



- (c) High fluctuating current is near a signal lines
- (d) Current flows through the ground line of the oscillator (potential at points A, B, and C fluctuate)

X1

B

High current IC

С



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

(e) Signals are fetched



#### 5.4.2 Divider

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

#### 5.5 Clock Generator Operations

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

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

The following clock generator functions and operations are determined by the processor clock control register (PCC).

- (a) Upon generation of the  $\overrightarrow{\text{RESET}}$  signal, the lowest speed mode of the system clock (7.11  $\mu$ s when operated at 4.5 MHz) is selected (PCC = 04H). System clock oscillation stops while a low level is applied to the  $\overrightarrow{\text{RESET}}$  pin.
- (b) One of the five CPU clock types (0.45, 0.89, 1.78, 3.56, 7.11  $\mu$ s at 4.5 MHz) can be selected by setting PCC.
- (c) Two standby modes, STOP and HALT, are available.
- (d) The system clock is divided and supplied to the peripheral hardware. The peripheral hardware also stops if the system clock is stopped.

#### 5.6 Changing System Clock and CPU Clock Settings

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

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

The actual switching operation is not performed directly after writing to PCC, but operation continues on the preswitched clock for several instructions (refer to **Table 5-2**).

|      | alues E<br>witchin |      |                | Set Values After Switching |                |                                 |                |      |               |                 |      |                |                 |      |                |                |      |
|------|--------------------|------|----------------|----------------------------|----------------|---------------------------------|----------------|------|---------------|-----------------|------|----------------|-----------------|------|----------------|----------------|------|
| PCC2 |                    | DCCO | PCC2           | PCC1                       | PCC0           | PCC2                            | PCC1           | PCC0 | PCC2          | PCC1            | PCC0 | PCC2           | PCC1            | PCC0 | PCC2           | PCC1           | PCC0 |
| PUU2 | PUUT               | PCCU | 0              | 0                          | 0              | 0                               | 0              | 1    | 0             | 1               | 0    | 0              | 1               | 1    | 1              | 0              | 0    |
| 0    | 0                  | 0    |                |                            |                | 16 instructions 16 instructions |                |      |               | 16 instructions |      |                | 16 instructions |      |                |                |      |
| 0    | 0                  | 1    | 8 in           | structi                    | ons            |                                 |                |      | 8 in          | 8 instructions  |      | 8 instructions |                 | ons  | 8 instructions |                |      |
| 0    | 1                  | 0    | 4 in           | structi                    | ons            | s 4 instructions                |                | ons  |               |                 |      | 4 instructions |                 |      | 4 ir           | 4 instructions |      |
| 0    | 1                  | 1    | 2 instructions |                            | 2 instructions |                                 | 2 instructions |      |               |                 |      | 2 instructions |                 |      |                |                |      |
| 1    | 0                  | 0    | 1 ir           | nstruct                    | ion            | 1 instruction                   |                |      | 1 instruction |                 |      | 1 ii           | nstruct         | ion  |                |                |      |

# Table 5-2. Maximum Time Required for CPU Clock Switching

Remark One instruction is the minimum instruction execution time with the preswitched CPU clock.

### CHAPTER 6 8-BIT TIMER/EVENT COUNTERS 50 TO 53

#### 6.1 Functions of 8-Bit Timer/Event Counters 50 to 53

8-bit timer/event counters 50 to 53 have the following two modes.

- Mode in which an 8-bit timer/event counter is used alone (single mode)
- Mode in which the two timer/event counters are cascaded (cascade mode with a resolution of 16 bits)

These two modes are explained below.

- (1) Mode in which an 8-bit timer/event counter is used alone (single mode) The timer/event counter operates as an 8-bit timer/event counter. In this mode, the following functions can be used.
  - Interval timer
  - External event counter
  - Square wave output
  - PWM output

Caution Timer 53 can be used only as an interval timer since it does not include timer input and output pins.

- (2) Mode in which the two timer/event counters are cascaded (cascade mode with a resolution of 16 bits) By connecting timer 50 or timer 52 as a lower timer and timer 51 or timer 53 as a higher timer in cascade, they operate as a 16-bit timer/event counter. In this mode, the following functions can be used:
  - Interval timer with 16-bit resolution
  - External event counter with 16-bit resolution
  - Square wave output with 16-bit resolution

Figures 6-1 to 6-4 show the block diagrams of 8-bit timer/event counters 50 to 53.





Figure 6-2. Block Diagram of 8-Bit Timer/Event Counter 51





Figure 6-3. Block Diagram of 8-Bit Timer/Event Counter 52

Figure 6-4. Block Diagram of 8-Bit Timer 53



#### 6.2 Configuration of 8-Bit Timer/Event Counters 50 to 53

8-bit timer/event counters 50 to 53 consist of the following hardware.

| Item              | Configuration                                                                                                                                                        |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer registers   | 8-bit timer counters 50, 51, 52, and 53 (TM50 to TM53)                                                                                                               |
| Registers         | 8-bit compare registers 50, 51, 52, and 53 (CR50 to CR53)                                                                                                            |
| Timer outputs     | 3 lines (TO50 to TO52)                                                                                                                                               |
| Control registers | <ul> <li>Timer clock select registers 50, 51, 52, and 53 (TCL50 to TCL53)</li> <li>8-bit timer mode control registers 50, 51, 52, and 53 (TMC50 to TMC53)</li> </ul> |

#### Table 6-1. Configuration of 8-Bit Timer/Event Counters 50 to 53

#### (1) 8-bit timer counters 50, 51, 52, and 53 (TM50 to TM53)

TM5n is an 8-bit read-only register that counts the count pulses.

The counter is incremented at the rising edge of the count clock.

TM50 and TM51 or TM52 and TM53 can be cascaded and used as a 16-bit timer.

When TM50 and TM51 are cascaded and used as a 16-bit timer, its value can be read using a 16-bit memory manipulation instruction. However, because TM50 and TM51 are connected with the internal 8-bit bus, they are read one at a time. Therefore, read the value of TM50 and TM51 when used as a 16-bit timer two times for comparison, taking changes in the values during counting into consideration.

When TM52 and TM53 are cascaded and used as a 16-bit timer, its value can be read using a 16-bit memory manipulation instruction. However, because TM52 and TM53 are connected with the internal 8-bit bus, they are read one at a time. Therefore, read the value of TM52 and TM53 when used as a 16-bit timer two times for comparison, taking changes in the values during counting into consideration.

If the count value is read while the timer is operating, stop input of the count clock, and read the count value at that point. The count value is cleared to 00H in the following cases.

- <1> RESET input
- <2> Clearing TCE5n
- <3> Match between TM5n and CR5n in mode in which the timer is cleared and started on match between TM5n and CR5n
  - Caution When TM50 and TM51 or TM52 and TM53 are cascaded, the value of the timer is cleared to 00H even if the least significant bit (TCE50 or TCE52) of timer mode control register 50 (TMC50) or 52 (TMC52) is cleared.

Remark n = 0 to 3

#### (2) 8-bit compare registers 50, 51, 52, and 53 (CR50 to CR53)

The value set to CR5n is always compared with the value of 8-bit timer counter 5n (TM5n). When the value of a compare register matches the count value of the corresponding counter, an interrupt request (INTTM5n) is generated (in a mode other than PWM mode).

If TM50 and TM51 are cascaded and used as a 16-bit timer, CR50 and CR51 operate together as a 16-bit compare register. The 16-bit counter value and 16-bit compare register value are compared, and when the two values match, an interrupt request (INTTM50) is generated. At this time, the interrupt request INTTM51 is also generated. Therefore, mask INTTM51 when using TM50 and TM51 in the cascade mode.

If TM52 and TM53 are cascaded and used as a 16-bit timer, CR52 and CR53 operate together as a 16-bit compare register. The 16-bit counter value and 16-bit compare register value are compared, and when the two values match, an interrupt request (INTTM52) is generated. At this time, the interrupt request INTTM53 is also generated. Therefore, mask INTTM53 when using TM52 and TM53 in the cascade mode.

# Caution When TM50 and TM51 or TM52 and TM53 are cascaded, be sure to change the CR5n setting value after stopping the timer operation of cascaded TM5n.

Remark n = 0 to 3

#### 6.3 Registers Controlling 8-Bit Timer/Event Counters 50 to 53

The following two types of registers control the 8-bit timer/event counters 50 to 53.

- Timer clock select registers 50 to 53 (TCL50 to TCL53)
- 8-bit timer mode control registers 50 to 53 (TMC50 to TMC53)

#### (1) Timer clock select registers 50 to 52 (TCL50 to TCL52)

These registers select the count clock of 8-bit timer counter 5n (TM5n) and the valid edge of the TI5n input. TCL5n is set with an 8-bit memory manipulation instruction. Reset input clears TCL50 to TCL52 to 00H.

**Remark** n = 0 to 2

| Symbol | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0      | Address | After reset | R/W |
|--------|---|---|---|---|---|--------|--------|--------|---------|-------------|-----|
| TCL50  | 0 | 0 | 0 | 0 | 0 | TCL502 | TCL501 | TCL500 | FF84H   | 00H         | R/W |
|        | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| TCL51  | 0 | 0 | 0 | 0 | 0 | TCL512 | TCL511 | TCL510 | FF87H   | 00H         | R/W |
|        | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| TCL52  | 0 | 0 | 0 | 0 | 0 | TCL522 | TCL521 | TCL520 | FF74H   | 00H         | R/W |

#### Figure 6-5. Format of Timer Clock Select Registers 50 to 52 (TCL50 to TCL52)

| TCL5n2 | TCL5n1 | TCL5n0 | Count clock selection         |  |  |  |  |  |
|--------|--------|--------|-------------------------------|--|--|--|--|--|
| 0      | 0      | 0      | Falling edge of TI5n          |  |  |  |  |  |
| 0      | 0      | 1      | Rising edge of TI5n           |  |  |  |  |  |
| 0      | 1      | 0      | fx/2 (2.25 MHz)               |  |  |  |  |  |
| 0      | 1      | 1      | fx/2 <sup>3</sup> (563 kHz)   |  |  |  |  |  |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (141 kHz)   |  |  |  |  |  |
| 1      | 0      | 1      | fx/2 <sup>7</sup> (35.2 kHz)  |  |  |  |  |  |
| 1      | 1      | 0      | fx/2 <sup>9</sup> (8.79 kHz)  |  |  |  |  |  |
| 1      | 1      | 1      | fx/2 <sup>11</sup> (2.20 kHz) |  |  |  |  |  |

# Cautions 1. Before changing the data of TCL5n, be sure to stop the timer operation.

- 2. Be sure to set bits 3 to 7 to 0.
- **Remarks 1.** In the cascade mode, the setting of bits TCL50 or TCL52 of the lower timer (TM50 or TM52) is valid, and the setting of bits TCL51 or TCL53 of the higher timer (TM51 or TM53) is invalid.
  - **2.** n = 0 to 2
  - 3. fx: System clock oscillation frequency
  - **4.** (): fx = 4.5 MHz

#### (2) Timer clock select register 53 (TCL53)

This register selects the count clock of 8-bit timer counter 53 (TM53). TCL53 is set with an 8-bit memory manipulation instruction. Reset input clears TCL53 to 00H.

| Symbol | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0      | Address | After reset | R/W |
|--------|---|---|---|---|---|--------|--------|--------|---------|-------------|-----|
| TCL53  | 0 | 0 | 0 | 0 | 0 | TCL532 | TCL531 | TCL530 | FF77H   | 00H         | R/W |

Figure 6-6. Format of Timer Clock Select Register 53 (TCL53)

| TCL532 | TCL531 | TCL530 | Count clock selection         |  |  |  |  |
|--------|--------|--------|-------------------------------|--|--|--|--|
| 0      | 0      | 0      | Setting prohibited            |  |  |  |  |
| 0      | 0      | 1      | Setting prohibited            |  |  |  |  |
| 0      | 1      | 0      | fx/2 (2.25 MHz)               |  |  |  |  |
| 0      | 1      | 1      | fx/2 <sup>3</sup> (563 kHz)   |  |  |  |  |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (141 kHz)   |  |  |  |  |
| 1      | 0      | 1      | fx/2 <sup>7</sup> (35.2 kHz)  |  |  |  |  |
| 1      | 1      | 0      | fx/2 <sup>9</sup> (8.79 kHz)  |  |  |  |  |
| 1      | 1      | 1      | fx/2 <sup>11</sup> (2.20 kHz) |  |  |  |  |

# Cautions 1. Before changing the data of TCL53, be sure to stop the timer operation.2. Be sure to reset bits 3 to 7 to 0.

- 2. fx: System clock oscillation frequency
- **3.** ( ): fx = 4.5 MHz

# (3) 8-bit timer mode control registers 50 to 52 (TMC50 to TMC52)

The TMC5n register is used for the following.

- <1> Controlling count operation of 8-bit timer counter 5n (TM5n)
- <2> Selecting operation mode of 8-bit timer counter 5n (TM5n)
- <3> Selecting single mode or cascade mode
- <4> Setting status of timer output F/F (flip-flop)
- <5> Controlling timer F/F or selecting active level in PWM (free-running) mode
- <6> Controlling timer output

TMC5n can be set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears TMC5n to 00H.

**Remark** n = 0 to 2

Remarks 1. In the cascade mode, the setting of bit TCL53 of the higher timer (TM53) is invalid.

#### Figure 6-7. Format of 8-Bit Timer Mode Control Registers 50 to 52 (TMC50 to TMC52)

| Symbol | <7>   | 6      | 5 | 4      | <3>   | <2>   | 1      | <0>   | Address | After reset | R/W |
|--------|-------|--------|---|--------|-------|-------|--------|-------|---------|-------------|-----|
| TMC50  | TCE50 | TMC506 | 0 | TMC504 | LVS50 | LVR50 | TMC501 | TOE50 | FF85H   | 00H         | R/W |
|        | -7    |        | - |        |       | 0     |        |       |         |             |     |
|        | <7>   | 6      | 5 | 4      | <3>   | <2>   | 1      | <0>   |         |             |     |
| TMC51  | TCE51 | TMC516 | 0 | TMC514 | LVS51 | LVR51 | TMC511 | TOE51 | FF88H   | 00H         | R/W |
|        |       |        |   |        |       |       |        |       |         |             |     |
|        | <7>   | 6      | 5 | 4      | <3>   | <2>   | 1      | <0>   |         |             |     |
| TMC52  | TCE52 | TMC526 | 0 | TMC524 | LVS52 | LVR52 | TMC521 | TOE52 | FF75H   | 00H         | R/W |

| TCE | 5n | Control of count operation of TM5n                                    |  |  |  |  |
|-----|----|-----------------------------------------------------------------------|--|--|--|--|
| 0   |    | Clears counter to 0 and disables count operation (disables prescaler) |  |  |  |  |
| 1   |    | Starts count operation                                                |  |  |  |  |

| TMC5n6 | Selection of operating mode of TM5n                               |
|--------|-------------------------------------------------------------------|
| 0      | Mode of clearing and starting TM5n on match between TM5n and CR5n |
| 1      | PWM (free-running) mode                                           |

| TMC5n4 | Selection of single mode or cascade mode |  |  |  |  |
|--------|------------------------------------------|--|--|--|--|
| 0      | Single mode                              |  |  |  |  |
| 1 Note | Cascade mode (connected to lower timer)  |  |  |  |  |

| LVS5n | LVR5n | Setting status of timer output F/F |
|-------|-------|------------------------------------|
| 0     | 0     | Not affected                       |
| 0     | 1     | Resets timer output F/F to 0       |
| 1     | 0     | Sets timer output F/F to 1         |
| 1     | 1     | Setting prohibited                 |

| TMC5n1 | Other than PWM mode (TMC5n6 = 0) | PWM mode (TMC5n6 = 1)     |
|--------|----------------------------------|---------------------------|
|        | Control of timer F/F             | Selection of active level |
| 0      | Disables inversion operation     | High active               |
| 1      | Enables inversion operation      | Low active                |

| TOE5n | Control of timer output     |  |  |  |
|-------|-----------------------------|--|--|--|
| 0     | Disables output (port mode) |  |  |  |
| 1     | Enables output              |  |  |  |

**Note** Since the higher timer settings become valid, the lower timer TMC504/TMC524 settings become invalid.

#### Caution Be sure to reset bit 4 (TMC5n4) to 0.

**Remarks 1.** The PWM output becomes inactive when TCE5n = 0 in the PWM mode.

- 2. LVS5n and LVR5n are 0 when read after data has been set.
- **3.** n = 0 to 2

#### (4) 8-bit timer mode control register 53 (TMC53)

The TMC53 register is used for the following.

- <1> Controlling count operation of 8-bit timer counter 53 (TM53)
- <2> Selecting single mode or cascade mode

TMC53 can be set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears TMC53 to 00H.

#### Figure 6-8. Format of 8-Bit Timer Mode Control Register 53 (TMC53)

| Symbol |       |   |   |        |   |   | 1 | 0 | Address | After reset | R/W |
|--------|-------|---|---|--------|---|---|---|---|---------|-------------|-----|
| TMC53  | TCE53 | 0 | 0 | TMC534 | 0 | 0 | 0 | 0 | FF78H   | 00H         | R/W |

| TCE53 | Control of count operation of TM53                                    |  |  |  |  |  |
|-------|-----------------------------------------------------------------------|--|--|--|--|--|
| 0     | Clears counter to 0 and disables count operation (disables prescaler) |  |  |  |  |  |
| 1     | Starts count operation                                                |  |  |  |  |  |

| Т | MC534 | Selection of single mode or cascade mode       |  |  |  |  |
|---|-------|------------------------------------------------|--|--|--|--|
|   | 0     | Single mode                                    |  |  |  |  |
|   | 1     | Cascade mode (connected to lower timer (TM52)) |  |  |  |  |

#### 6.4 Operations of 8-Bit Timer/Event Counters 50 to 53

#### 6.4.1 Operation as interval timer (8-bit)

The 8-bit timer/event counter operates as an interval timer that repeatedly generates an interrupt request at the interval specified by the count value set in advance in 8-bit compare register 5n (CRn).

When the count value of 8-bit timer counter 5n (TM5n) matches the value set in CR5n, the value of TM5n is cleared to 0. TM5n continues counting and an interrupt request signal (INTTM5n) is generated.

The count clock of TM5n can be selected by using bits 0 to 2 (TCL5n0 to TCL5n2) of timer clock select register 5n (TCL5n).

For the operation if the value of the compare register is changed while the timer count operation, refer to (2) in 6.5 Notes on 8-Bit Timer/Event Counters 50 to 53.

#### [Setting]

<1> Set each register.

- TCL5n: Select a count clock.
- CR5n: Compare value
- TMC5n: Select a mode in which TM5n is cleared and started on match between TM5n and CR5n (TMC5n = 0000×××0B: × = Don't care).
- <2> The count operation is started when TEC5n is set to 1.
- <3> INTTM5n is generated if the values of TM5n and CR5n match (TM5n is cleared to 00H).
- <4> After that, INTTM5n is repeatedly generated at fixed intervals. To stop the count operation, clear TCE5n to 0.

**Remark** n = 0 to 3

Figure 6-9. Timing of Interval Timer Operation (1/3)



#### (a) Basic operation



#### Figure 6-9. Timing of Interval Timer Operation (2/3)

# (b) When CR5n = 00H



#### (c) When CR5n = FFH



n = 0 to 3

Figure 6-9. Timing of Interval Timer Operation (3/3)

### (d) Operation when CR5n is changed (M < N)



#### (e) Operation when CR5n is changed (M > N)



n = 0 to 3

#### 6.4.2 Operation as external event counter (timers 50 to 52)

The external event counter counts the number of clock pulses input from an external source to the TI5n pin using 8-bit timer counter 5n (TM5n).

Each time the valid edge specified by timer clock select register 5n (TCL5n) has been input to TI5n, the value of TM5n is incremented. As the valid edge, either the rising or falling edge can be selected.

When the count value of TM5n matches the value of 8-bit compare register 5n (CR5n), TM5n is cleared to 0, and an interrupt request signal (INTTM5n) is generated.

After that, each time the value of TM5n matches the value of CR5n, INTTM5n is generated.

## [Setting]

<1> Set each register.

- TCL5n: Select the valid edge of TI5n input.
- CR5n: Compare value
- TMC5n: Select a mode in which TM5n is cleared and started on match between TM5n and CR5n.
- <2> The count operation is started when TEC5n is set to 1.
- <3> INTTM5n is generated if the values of TM5n and CR5n match (TM5n is cleared to 00H).
- <4> After that, INTTM5n is generated each time the value of TM5n matches the value of CR5n. To stop the count operation, clear TCE5n to 0.

Remark n = 0 to 2

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

| TI5n             |                                       |                                       |
|------------------|---------------------------------------|---------------------------------------|
| TM5n count value | X 00 X 01 X 02 X 03 X 04 X 05 X       | XN-1X N X 00 X 01 X 02 X 03 X         |
| CR5n             | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · · |
| INTTM5n          | (                                     |                                       |
|                  |                                       |                                       |

n = 0 to 2

## 6.4.3 Square wave output operation (8-bit resolution) (timers 50 to 52)

8-bit timer/event counter TM5n can be used to output a square wave with any frequency at time interval specified by the value set in advance in 8-bit compare register 5n (CR5n).

When bit 0 (TOE5n) of 8-bit timer mode control register 5n (TMC5n) is set to 1, the output status of TO5n is inverted at the interval specified by the count value set in advance to CR5n. In this way, a square wave (duty factor = 50%) of any frequency can be output.

## [Setting]

<1> Set each register.

- Reset the port latch and port mode register to "0".
- TCL5n: Select a count clock.
- CR5n: Compare value
- TMC5n: Mode in which TM5n is cleared and started on match between TM5n and CR5n

| LVS5n | LVR5n | Sets Status of Timer Output F/F |
|-------|-------|---------------------------------|
| 1     | 0     | High-level output               |
| 0     | 1     | Low-level output                |

Enable inverting the timer F/F.

Enable the timer output  $\rightarrow$  TOE5n = 1.

- <2> When TCE5n is set to 1, the count operation is started.
- <3> When the value of TM5n matches the value of CR5n, the timer output F/F is inverted. In addition, INTTM5n is generated, and TM5n is cleared to 00H.
- <4> After that, the timer output F/F is inverted at fixed intervals, and a square wave is output from TO5n.

## Remark n = 0 to 2





**Note** The initial value of the TO5n output can be set using bits 2 and 3 (LVR5n and LVS5n) of 8-bit timer mode control register 5n (TMC5n).

Remark n = 0 to 2

#### 6.4.4 8-bit PWM output operation (timers 50 to 52)

The 8-bit timer/event counter can be used for PWM output when bit 6 (TMC5n6) of 8-bit timer mode control register 5n (TMC5n) is set to 1.

A pulse with a duty factor determined by the value set in 8-bit compare register 5n (CR5n) is output from TO5n. Set the active level width of the PWM pulse to CR5n. The active level is selected by bit 1 (TMC5n) of TMC5n. The count clock can be selected by bits 0 to 2 (TCL5n0 to TCL5n2) of timer clock select register n (TCL5n). PWM output can be enabled or disabled by bit 0 (TOE5n) of TMC5n.

#### Caution The value of CR5n can be rewritten only once in one cycle in the PWM mode.

Remark n = 0 to 2

#### (1) Basic operation of PWM output

#### [Setting]

- <1> Set port latches (P130 and P131) to 0.
- <2> Select the active level width using the 8-bit compare register (CR5n).
- <3> Select the count clock by using timer clock select register 5n (TCL5n).
- <4> Select the active level using bit 1 (TMC5n1) of TMC5n.
- <5> When bit 7 (TCE5n) of TMC5n is set to 1, the count operation is started. To stop the count operation, reset TCE5n to 0.

#### [Operation of PWM output]

- <1> When the count operation is started, the PWM output (output from TO5n) remains inactive until an overflow occurs.
- <2> When an overflow occurs, the active level set in step <1> above is output. This active level is output until the value of CR5n matches the count value of 8-bit timer counter 5n (TM5n).
- <3> The PWM output remains inactive after CR5n and the count value of TM5n match, until an overflow occurs again.
- <4> After that, <2> and <3> are repeated until the count operation is stopped.
- <5> When the count operation is stopped because TCE5n is cleared to 0, PWM output becomes inactive.

Remark n = 0 to 2

Figure 6-12. Operation Timing of PWM Output

## (a) Basic operation (when active level = H)



## (b) When CR5n = 0



(c) When CR5n = FFH





## (2) Operation when CR5n is changed

## Figure 6-13. Timing of Operation When CR5n Is Changed

## (a) If value of CR5n is changed from N to M before overflow of TM5n



## (b) If value of CR5n is changed from N to M after overflow of TM5n



## (c) If value of CR5n is changed from N to M for duration of 2 clocks immediately after overflow of TM5n



n = 0 to 2

Caution The value of CR5n can be changed only once in one cycle in the PWM mode.

#### 6.4.5 Interval timer operation (16-bit)

When using the 8-bit timer/counters as a 16-bit timer, be sure to use a combination of timers 50 and 51 or timers 52 and 53. The following section describes the case when using timers 50 and 51. When using timers 52 and 53, read "50" as "52" and "51" as "53".

The 8-bit timer/event counters are used together in 16-bit timer/counter mode when bit 4 (TMC514) of 8-bit timer mode control register 51 (TM51) is set to 1.

In this mode, the 8-bit timer/event counters are used as a 16-bit interval timer that repeatedly generates an interrupt request at intervals specified by the count value set in advance in the 8-bit compare registers (CR50 and CR51). At this time, CR50 serves as the lower 8 bits of the 16-bit compare register, and CR51 serves as the higher 8 bits.

#### [Setting]

<1> Set each register. • TCL50:

Select the count clock for TM50.

- The count clock for TM51, which is cascaded, does not have to be set.
- CR50 and CR51: Compare values. (Each compare value can be set in a range of 00H to FFH.)
- TMC50 and TMC51: Select a mode in which the interval timer is cleared and started on match between

TM50 and CR50 (or between TM51 and CR51).

- $\langle$  TM50  $\rightarrow$  TMC50 = 0000×××0B ×: Don't care  $\rangle$
- $\langle$  TM51  $\rightarrow$  TMC51 = 0001×××0B ×: Don't care
- <2> The count operation is started by setting TCE51 of TMC51 to 1 first, and then TCE50 of TMC50 to 1.
- <3> If the value of cascaded timer TM50 matches the value of CR50, INTTM50 of TM50 is generated (TM50 and TM51 are cleared to 00H).
- <4> After that, INTTM50 is repeatedly generated at fixed intervals.

## Cautions 1. Be sure to set the compare registers (CR50 and CR51) after stopping the timer operation.

- 2. Even if the 8-bit timers/counters are cascaded, INTTM51 of TM51 is generated when the count value of TM51 matches CR51. Be sure to mask TM51 to disable this interrupt.
- 3. Set TCE50 and TCE51 in the order of TM51 and TM50.
- 4. Counting can be restarted or stopped by setting or resetting TCE50 of TM50 to 1 or 0.

Figure 6-14 shows a timing example in the 16-bit resolution cascade mode.



Figure 6-14. Operation Timing of 16-Bit Resolution Cascade Mode (Timers 50 and 51)

## 6.5 Notes on 8-Bit Timer/Event Counters 50 to 53

## (1) Error on starting timer

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





n = 0 to 3

## (2) Operation after changing compare register during timer count operation

If a new value of 8-bit compare register 5n (CR5n) is less than the value of 8-bit timer counter 5n (TM5n), counting continues, and TM5n overflows and starts counting from 0. If the new value of CR5n (M) is less than the old value (N), therefore, it is necessary to restart the timer after changing CR5n.







**Remarks 1.** N > X > M **2.** n = 0 to 3

## (3) Reading TM5n (n = 0 to 3) during timer operation

When TM5n is read during operation, the count clock is temporarily stopped. Therefore, select a count clock with a high/low level longer than two cycles of the CPU clock. For example, when the CPU clock ( $f_{CPU}$ ) is fx, the count clock to be selected should be fx/4 or less in order that TM5n can be read.

Remark n = 0 to 3

## CHAPTER 7 BASIC TIMER

The basic timer is used for time management during program execution.

## 7.1 Function of Basic Timer

The basic timer generates an interrupt request signal (INTBTM0) at time intervals of 100 ms.

## 7.2 Configuration of Basic Timer





Caution Use the basic timer after setting bit 0 (DTSCK0) of the DTS system clock select register (DETSCK) to 1 after power application, and after reset by the RESET pin (refer to 5.1 Functions of Clock Generator).

The first interrupt request signal (INTBTM0) after the DTSCK0 flag has been set is generated within 100 to 140 ms. The second signal and those that follow are generated at intervals of 100 ms.

## 7.3 Operation of Basic Timer

An example of the operation of the basic timer is shown below.

In this example, the basic timer operates as an interval timer that repeatedly generates an interrupt at time intervals of 100 ms. Interrupt request signal (INTBTM0) is generated every 100 ms.

The timer clock frequency is 10 Hz.



Figure 7-2. Operation Timing of Basic Timer

By polling the interrupt request flag (BTMIF0) of this basic timer by software, time management can be carried out. Note that BTMIF0 is not a Read & Reset flag.

Figure 7-3. Operating Timing to Poll BTMIF0 Flag



For the registers controlling the basic timer, refer to CHAPTER 12 INTERRUPT FUNCTIONS.

## **CHAPTER 8 WATCHDOG TIMER**

## 8.1 Functions of Watchdog Timer

The watchdog timer has the following functions.

- · Watchdog timer
- Interval timer
- · Selecting oscillation stabilization time

# Caution Select the watchdog timer mode or the interval timer mode using the watchdog timer mode register (WDTM). (The watchdog timer and interval timer cannot be used simultaneously.)

Figure 8-1 shows a block diagram.





## (1) Watchdog timer mode

An inadvertent program loop is detected. Upon detection of the inadvertent program loop, a non-maskable interrupt request or reset can be generated.

| Inadvertent Program Loop Detection Time   |
|-------------------------------------------|
| 2 <sup>12</sup> /fx (910 μs)              |
| 2 <sup>13</sup> /fx (1.82 ms)             |
| 2 <sup>14</sup> /fx (3.64 ms)             |
| 2 <sup>15</sup> /fx (7.28 ms)             |
| 2 <sup>16</sup> /f <sub>x</sub> (14.6 ms) |
| 2 <sup>17</sup> /fx (29.1 ms)             |
| 2 <sup>18</sup> /fx (58.3 ms)             |
| 2 <sup>20</sup> /f <sub>X</sub> (233 ms)  |

## Table 8-1. Watchdog Timer Inadvertent Program Loop Detection Times

Remarks 1. fx: System clock oscillation frequency
2. ( ): fx = 4.5 MHz

## (2) Interval timer mode

Interrupt requests are generated at the preset time intervals.

## Table 8-2. Interval Time

| Interval Time                 |
|-------------------------------|
| 2 <sup>12</sup> /fx (910 μs)  |
| 2 <sup>13</sup> /fx (1.82 ms) |
| 2 <sup>14</sup> /fx (3.64 ms) |
| 2 <sup>15</sup> /fx (7.28 ms) |
| 2 <sup>16</sup> /fx (14.6 ms) |
| 2 <sup>17</sup> /fx (29.1 ms) |
| 2 <sup>18</sup> /fx (58.3 ms) |
| 2 <sup>20</sup> /fx (233 ms)  |

| Remarks | 1. | fx: | System clock oscillation frequency |
|---------|----|-----|------------------------------------|
|         | 2. | (): | fx = 4.5 MHz                       |

## 8.2 Configuration of Watchdog Timer

The watchdog timer consists of the following hardware.

## Table 8-3. Configuration of Watchdog Timer

| Item              | Configuration                                                                                                                               |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Control registers | Watchdog timer clock select register (WDCS)<br>Watchdog timer mode register (WDTM)<br>Oscillation stabilization time select register (OSTS) |

## 8.3 Registers Controlling Watchdog Timer

The following three types of registers are used to control the watchdog timer.

- Watchdog timer clock select register (WDCS)
- Watchdog timer mode register (WDTM)
- Oscillation stabilization time select register (OSTS)

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

This register sets the watchdog timer and overflow time of the interval timer. WDCS is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears WDCS to 00H.

## Figure 8-2. Format of Watchdog Timer Clock Select Register (WDCS)

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

| WDCS2 | WDCS1 | WDCS0 | Watchdog timer/interval timer overflow time |
|-------|-------|-------|---------------------------------------------|
| 0     | 0     | 0     | 2 <sup>12</sup> /fx (910µs)                 |
| 0     | 0     | 1     | 2 <sup>13</sup> /f <sub>x</sub> (1.82 ms)   |
| 0     | 1     | 0     | 2 <sup>14</sup> /f <sub>x</sub> (3.64 ms)   |
| 0     | 1     | 1     | 2 <sup>15</sup> /fx (7.28 ms)               |
| 1     | 0     | 0     | 2 <sup>16</sup> /fx (14.6 ms)               |
| 1     | 0     | 1     | 2 <sup>17</sup> /f <sub>x</sub> (29.1 ms)   |
| 1     | 1     | 0     | 2 <sup>18</sup> /fx (58.3 ms)               |
| 1     | 1     | 1     | 2 <sup>20</sup> /fx (233 ms)                |

Remarks 1. fx: System clock oscillation frequency

**2.** (): fx = 4.5 MHz

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

This register sets the watchdog timer operating mode and enables/disables counting. WDTM is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears WDTM to 00H.

#### Symbol 6 5 4 3 Address After reset R/W <7> 2 1 0 WDTM 0 0 WDTM4 WDTM3 0 0 RUN 0 FFF9H 00H R/W RUN Watchdog timer operating mode selectionNote 1 0 Count stop 1 Counter is cleared and counting starts.

| Figure 8-3. | Format of Watchdog Timer Mode Register (WDTM) |
|-------------|-----------------------------------------------|
|             |                                               |

| WDTM4 | WDTM3 | Watchdog timer operating mode selection <sup>Note 2</sup>                                            |
|-------|-------|------------------------------------------------------------------------------------------------------|
| 0     | ×     | Interval timer mode <sup>Note 3</sup><br>(Maskable interrupt occurs upon generation of an overflow.) |
| 1     | 0     | Watchdog timer mode 1<br>(Non-maskable interrupt occurs upon generation of an overflow.)             |
| 1     | 1     | Watchdog timer mode 2<br>(Reset operation is activated upon generation of an overflow.)              |

- Notes 1. Once set to 1, RUN cannot be cleared to 0 by software. Therefore, use RESET input to clear RUN to 0.
  - 2. Once set to 1, WDTM3 and WDTM4 cannot be cleared to 0 by software.
  - 3. WDTM starts interval timer operation at a time RUN is set to 1.
- Caution When RUN is set to 1 so that the watchdog timer is cleared, the actual overflow time is up to 0.5% shorter than the time set by the timer clock select register (WDCS).

**Remark** ×: Don't care

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

This register is used to select the time required for oscillation to stabilize after the  $\overline{\text{RESET}}$  signal has been input or the STOP mode has been released.

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

Reset input sets OSTS to 04H. Therefore, it takes 2<sup>17</sup>/fx to release the STOP mode by RESET input.

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

| Symbol | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     | Address | After reset | R/W |
|--------|---|---|---|---|---|-------|-------|-------|---------|-------------|-----|
| OSTS   | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 | FFFAH   | 04H         | R/W |

| OSTS2            | OSTS1 | OSTS0 | Selection of oscillation stabilization time |
|------------------|-------|-------|---------------------------------------------|
| 0                | 0     | 0     | 2 <sup>12</sup> /fx (910 μs)                |
| 0                | 0     | 1     | 2 <sup>14</sup> /fx (3.64 ms)               |
| 0                | 1     | 0     | 2 <sup>15</sup> /f <sub>x</sub> (7.28 ms)   |
| 0                | 1     | 1     | 2 <sup>16</sup> /f <sub>x</sub> (14.6 ms)   |
| 1                | 0     | 0     | 2 <sup>17</sup> /fx (29.1 ms)               |
| Other than above |       |       | Setting prohibited                          |

Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

\*

## 8.4 Operations of Watchdog Timer

#### 8.4.1 Watchdog timer operation

When bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 1, the watchdog timer operates to detect any inadvertent program loop.

The watchdog timer count clock (inadvertent program loop detection time interval) can be selected with bits 0 to 2 (WDCS0 to WDCS2) of timer clock select register 2 (WDCS). A watchdog timer count operation is started by setting bit 7 (RUN) of WDTM to 1. After the watchdog timer count operation starts, set RUN to 1 within the set inadvertent program loop time interval.

The watchdog timer can be cleared and counting started by setting RUN to 1. If RUN is not set to 1 and the inadvertent program loop detection time has elapsed, a system reset or a non-maskable interrupt request is generated according to the value of WDTM bit 3 (WDTM3).

The watchdog timer continues operating in the HALT mode but stops in the STOP mode. Thus, set RUN to 1 before the STOP mode is set, clear the watchdog timer and then execute the STOP instruction.

## Caution The actual inadvertent program loop detection time may be shorter than the set time by a maximum of 0.5%.

| Inadvertent Program Loop Detection Time  |
|------------------------------------------|
| 2 <sup>12</sup> /f <sub>X</sub> (910 μs) |
| 2 <sup>13</sup> /fx (1.82 ms)            |
| 2 <sup>14</sup> /fx (3.64 ms)            |
| 2 <sup>15</sup> /fx (7.28 ms)            |
| 2 <sup>16</sup> /fx (14.6 ms)            |
| 2 <sup>17</sup> /fx (29.1 ms)            |
| 2 <sup>18</sup> /fx (58.3 ms)            |
| 2 <sup>20</sup> /fx (233 ms)             |

#### Table 8-4. Watchdog Timer Inadvertent Program Loop Detection Time

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

**2.** (): fx = 4.5 MHz

#### 8.4.2 Interval timer operation

The watchdog timer operates as an interval timer that generates interrupt requests repeatedly at an interval of the preset count value when bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 0.

The count clock (interval time) can be selected by using bits 0 to 2 (WDCS0 to WDCS2) of the watchdog timer clock select register (WDCS). By setting bit 7 (RUN) of WDTM to 1, the watchdog timer starts operating as an interval timer.

When the watchdog timer operates as an interval timer, the interrupt mask flag (WDTMK) and priority specification flag (WDTPR) are validated and the maskable request interrupt (INTWDT) can be generated. Among maskable interrupt requests, the INTWDT default has the highest priority.

The interval timer continues operating in the HALT mode but stops in STOP mode. Thus, set RUN to 1 before the STOP mode is set, clear the interval timer and then execute the STOP instruction.

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

2. The interval time just after setting by WDTM may be shorter than the set time by a maximum of 0.5%.

| Interval Time                            |  |
|------------------------------------------|--|
| 2 <sup>12</sup> /f <sub>x</sub> (910 μs) |  |
| 2 <sup>13</sup> /fx (1.82 ms)            |  |
| 2 <sup>14</sup> /fx (3.64 ms)            |  |
| 2 <sup>15</sup> /fx (7.28 ms)            |  |
| 2 <sup>16</sup> /fx (14.6 ms)            |  |
| 2 <sup>17</sup> /fx (29.1 ms)            |  |
| 2 <sup>18</sup> /fx (58.3 ms)            |  |
| 2 <sup>20</sup> /fx (233 ms)             |  |
|                                          |  |

Table 8-5. Interval Timer Interval Time

Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

## CHAPTER 9 BUZZER OUTPUT CONTROLLER

## 9.1 Functions of Buzzer Output Controllers

The  $\mu$ PD178054 Subseries has the following two types of buzzer output controllers.

- BEEP0
- BUZ

BEEP0 outputs a square wave of the buzzer frequency selected by BEEP clock select register 0 (BEEPCL0) from the BEEP0/P36 pin.

BUZ outputs a square wave of the buzzer frequency selected by the clock output select register (CKS) from the BUZ/P37 pin.

Figures 9-1 and 9-2 show the block diagrams of BEEP0 and BUZ.



Figure 9-1. Block Diagram of BEEP0

Figure 9-2. Block Diagram of BUZ



Remark fx: System clock frequency

## 9.2 Configuration of Buzzer Output Controllers

The buzzer output controllers consist of the following hardware.

#### Table 9-1. Configuration of Buzzer Output Controllers

## (1) BEEP0

| Item Configuration |                                        |  |  |  |  |
|--------------------|----------------------------------------|--|--|--|--|
| Control register   | BEEP clock select register 0 (BEEPCL0) |  |  |  |  |

## (2) BUZ

| Item             | Configuration                      |
|------------------|------------------------------------|
| Control register | Clock output select register (CKS) |

## 9.3 Registers Controlling Buzzer Output Controllers

## 9.3.1 BEEP0

BEEP0 is controlled by the following register.

• BEEP clock select register 0 (BEEPCL0)

## (1) BEEP clock select register 0 (BEEPCL0)

This register selects the frequency of the buzzer output. BEEPCL0 is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears this register to 00H.

## Figure 9-3. Format of BEEP Clock Select Register 0 (BEEPCL0)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    | Address | After reset | R/W |
|--------|---|---|---|---|---|------|------|------|---------|-------------|-----|
| BEEP   |   | 0 | 0 | 0 | 0 | BEEP | BEEP | BEEP | FF41H   | 00H         | R/W |
| CL0    | Ŭ | 0 |   |   |   | CL02 | CL01 | CL00 |         |             |     |

| BEEP | BEEP | BEEP | Selection of frequency of BEEP0 output |
|------|------|------|----------------------------------------|
| CL02 | CL01 | CL00 |                                        |
| 0    | ×    | ×    | Disables buzzer output (port function) |
| 1    | 0    | 0    | 1 kHz                                  |
| 0    | 0    | 1    | 3 kHz                                  |
| 1    | 1    | 0    | 4 kHz                                  |
| 1    | 1    | 1    | 1.5 kHz                                |

Caution The selected clock may not be correctly output during the period of 1 cycle immediately after the output clock has been changed.

## 9.3.2 BUZ

BUZ is controlled by the following register.

Clock output select register (CKS)

## (1) Clock output select register (CKS)

This register enables/disables buzzer output and sets the clock of the buzzer output. CKS is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears this register to 00H.

#### Figure 9-4. Format of Clock Output Select Register (CKS)

| Symbol | <7>  | 6    | 5    | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W |
|--------|------|------|------|---|---|---|---|---|---------|-------------|-----|
| CKS    | BZOE | BCS1 | BCS0 | 0 | 0 | 0 | 0 | 0 | FF40H   | 00H         | R/W |

| BZOE | Enables/disables output of BUZ |  |  |  |  |  |
|------|--------------------------------|--|--|--|--|--|
| 0    | Low-level output               |  |  |  |  |  |
| 1    | Enables buzzer output          |  |  |  |  |  |

| BCS1 | BCS0 | Selects output clock of BUZ   |
|------|------|-------------------------------|
| 0    | 0    | fx/2 <sup>10</sup> (4.39 kHz) |
| 0    | 1    | fx/2 <sup>11</sup> (2.20 kHz) |
| 1    | 0    | fx/2 <sup>12</sup> (1.10 kHz) |
| 1    | 1    | fx/2 <sup>13</sup> (549 Hz)   |

Remarks 1. fx: System clock frequency

**2.** (): fx = 4.5 MHz

## 9.4 Operation of Buzzer Output Controllers

The buzzer frequency is output by the following procedure.

## (1) **BEEP0**

- <1> Select a buzzer output frequency using bits 0 to 2 (BEEPCL00 to BEEPCL02) of BEEP clock select register 0 (BEEPCL0).
- <2> Set the output latch of P36 to 0.
- <3> Set bit 6 (PM36) of the port mode register 3 to 0 (set the output mode).

#### (2) BUZ

- <1> Select a buzzer output frequency by using bits 5 and 6 (BCS0 and BCS1) of the clock output select register (CKS) (disable buzzer output).
- <2> Set bit 7 (BZOE) of CKS to 1 and enable buzzer output.
- <3> Set the output latch of P37 to 0.
- <4> Set bit 7 (PM37) of the port mode register 3 to 0 (set output mode).

## CHAPTER 10 A/D CONVERTER

## **10.1 Functions of A/D Converter**

The A/D converter converts analog inputs into digital values and consists of 6 channels (ANI0 to ANI5) with an 8-bit resolution.

The conversion method is based on successive approximation and the conversion result is held in 8-bit A/D conversion result register 3 (ADCR3).

Conversion is started by setting A/D converter mode register 3.

Select one analog input channel from ANI0 to ANI5 and carry out A/D conversion.

When A/D conversion is complete, the next A/D conversion is started immediately. Each time an A/D conversion operation ends, an interrupt request (INTAD3) is generated.

## **10.2** Configuration of A/D Converter

The A/D converter consists of the following hardware.

| Item              | Configuration                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Analog inputs     | 6 channels (ANI0 to ANI5)                                                                                                                      |
| Control registers | A/D converter mode register 3 (ADM3)<br>Analog input channel specification register 3 (ADS3)<br>Power-fail comparison mode register 3 (PFM3)   |
| Registers         | Successive approximation register (SAR)<br>A/D conversion result register 3 (ADCR3)<br>Power-fail comparison threshold value register 3 (PFT3) |

## Table 10-1. Configuration of A/D Converter



## Figure 10-1. Block Diagram of A/D Converter

#### (1) Successive approximation register (SAR)

This register compares the analog input voltage value to the voltage tap (compare voltage) value applied from the series resistor string and holds the result from the most significant bit (MSB). When up to the least significant bit (LSB) is set (termination of A/D conversion), the SAR contents are

transferred to the A/D conversion result register.

#### (2) A/D conversion result register 3 (ADCR3)

This register is an 8-bit register to store the A/D conversion result. Each time A/D conversion terminates, the conversion result is loaded from the successive approximation register (SAR). ADCR is read with an 8-bit memory manipulation instruction.

Reset input makes ADCR undefined.

Caution When data is written to A/D converter mode register 3 (ADM3) and analog input channel specification register 3 (ADS3), the contents of ADCR3 may be undefined. Read the result of conversion after conversion has been completed and before writing data to ADM3 and ADS3; otherwise the correct conversion result may not be read.

## (3) Power-fail comparison threshold value register 3 (PFT3)

This register sets a threshold value to be compared with the value of A/D conversion result register 3 (ADCR3). PFT3 is read or written with an 8-bit memory manipulation instruction.

#### (4) Sample & hold circuit

The sample & hold circuit samples each analog input signal sequentially applied from the input circuit and sends it to the voltage comparator. This circuit holds the sampled analog input voltage value during A/D conversion.

#### (5) Voltage comparator

The voltage comparator compares the analog input to the series resistor string output voltage.

#### (6) Resistor string

The resistor string is connected between  $V_{DD}$  and GND, and generates a voltage to be compared to the analog input.

#### (7) ANI0 to ANI5 pins

These are the 6-channel analog input pins through which analog signals to undergo A/D conversion are input to the A/D converter.

- Cautions 1. Use the ANI0 to ANI5 input voltages within the specified range. If a voltage higher than VDD or lower than GND is applied (even if within the absolute maximum ratings), the converted value of the corresponding channel becomes undefined and may adversely affect the converted values of other channels.
  - 2. The analog input pins (ANI0 to ANI5) are also used as input port pins (P10 to P15). When one of ANI0 to ANI5 is selected for A/D conversion, do not execute an input instruction to port 1; otherwise the conversion resolution may drop.

If a digital pulse is applied to the pin adjacent to the pin executing A/D conversion, the A/D conversion value may not be obtained as expected due to coupling noise. Do not apply a pulse to the pin adjacent to the pin executing A/D conversion.

## 10.3 Registers Controlling A/D Converter

The following three registers control the A/D converter.

- A/D converter mode register 3 (ADM3)
- Analog input channel specification register 3 (ADS3)
- Power-fail comparison mode register 3 (PFM3)

## (1) A/D converter mode register 3 (ADM3)

This register selects the conversion time of the analog input to be converted and starts or stops the conversion operation.

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

Reset input clears this register to 00H.

## Figure 10-2. Format of A/D Converter Mode Register 3 (ADM3)

| Symbol | <7>   | 6 | 5    | 4    | 3    | 2 | 1 | 0 | Address | After reset | R/W |
|--------|-------|---|------|------|------|---|---|---|---------|-------------|-----|
| ADM3   | ADCS3 | 0 | FR32 | FR31 | FR30 | 0 | 0 | 0 | FF12H   | 00H         | R/W |

| ADCS3 | Control of A/D conversion operation |  |  |  |  |  |  |  |
|-------|-------------------------------------|--|--|--|--|--|--|--|
| 0     | Stops conversion operation          |  |  |  |  |  |  |  |
| 1     | Enables conversion operation        |  |  |  |  |  |  |  |

| FR32  | FR31             | FR30 | Selection of conversion time |
|-------|------------------|------|------------------------------|
| 0     | 0                | 0    | 288/fx (64.0 μs)             |
| 0     | 0                | 1    | 240/fx (53.3 μs)             |
| 0     | 1                | 0    | 192/fx (42.7 μs)             |
| 1     | 0                | 0    | 144/fx (32.0 μs)             |
| 1     | 0                | 1    | 120/fx (26.7 μs)             |
| 1     | 1                | 0    | 96/fx (21.3 μs)              |
| Other | Other than above |      | Setting prohibited           |

| Cautions 1. The conversion result is undefined immediately after bit 7 (ADCS3) has been set to 1. |
|---------------------------------------------------------------------------------------------------|
| 2. To change the data of bits 3 to 5 (FR30 to FR32), stop the A/D conversion operation.           |

Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

## (2) Analog input channel specification register 3 (ADS3)

This register specifies the input channel of the analog voltage to be converted.

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

Reset input clears this register to 00H.

## Figure 10-3. Format of Analog Input Channel Specification Register 3 (ADS3)

| Symbol | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     | Address | After reset | R/W |
|--------|---|---|---|---|-------|-------|-------|-------|---------|-------------|-----|
| ADS3   | 0 | 0 | 0 | 0 | ADS33 | ADS32 | ADS31 | ADS30 | FF13H   | 00H         | R/W |

| ADS33   | ADS32            | ADS31 | ADS30 | Specification of analog input channel |
|---------|------------------|-------|-------|---------------------------------------|
| 0       | 0                | 0     | 0     | ANIO                                  |
| 0       | 0                | 0     | 1     | ANI1                                  |
| 0       | 0                | 1     | 0     | ANI2                                  |
| 0       | 0                | 1     | 1     | ANI3                                  |
| 0       | 1                | 0     | 0     | ANI4                                  |
| 0       | 1                | 0     | 1     | ANI5                                  |
| Other t | Other than above |       |       | Setting prohibited                    |

## (3) Power-fail comparison mode register 3 (PFM3)

PFM3 is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears this register to 00H.

| Symbol | <7>   | <6>      | <5>         | 4         | 3       | 2       | 1        | 0  | Address | After reset | R/W |
|--------|-------|----------|-------------|-----------|---------|---------|----------|----|---------|-------------|-----|
| PFM3   | PFEN3 | PFCM3    | PFHRM3      | 0         | 0       | 0       | 0        | 0  | FF16H   | 00H         | R/W |
|        |       |          |             |           |         |         |          |    |         |             |     |
|        | PFEN3 |          | Enable/     | disable o |         |         |          |    |         |             |     |
|        | 0     | Disables | power-fai   | l compari |         |         |          |    |         |             |     |
|        | 1     | Enables  | power-fail  | compari   |         |         |          |    |         |             |     |
|        |       |          |             |           |         |         |          |    |         |             |     |
|        | PFCM3 |          | Selectio    | n of pow  |         |         |          |    |         |             |     |
|        | 0     | Generate | es interrup | t request | FT      |         |          |    |         |             |     |
|        | 1     | Generate | es interrup | t request | (INTAD) | when AD | )CR3 < P | FT |         |             |     |

| Figure 10-4. | Format of Power-Fai | I Comparison M | lode Register 3 (PFM3) |
|--------------|---------------------|----------------|------------------------|
|              |                     |                |                        |

| <b>Note</b><br>PFHRM3 | Selection of power-fail HALT repeat mode |
|-----------------------|------------------------------------------|
| 0                     | Disables power-fail HALT repeat mode     |
| 1                     | Enables power-fail HALT repeat mode      |

**Note** When bit 5 (PFHRM3) is set to 1, power-fail comparison manipulation is enabled in the HALT mode in which A/D conversion is repeated until an interrupt request (INTAD3) is generated (this bit is reset to 0 when INTAD3 is generated).

## 10.4 Operations of A/D Converter

#### 10.4.1 Basic operations of A/D converter

- (1) Select one channel for A/D conversion with A/D converter analog input channel specification register 3 (ADS3).
- (2) Sample the voltage input to the selected analog input channel with the sample & hold circuit.
- (3) Sampling for the specified period of time sets the sample & hold circuit to the hold state so that the circuit holds the input analog voltage until termination of A/D conversion.
- (4) Bit 7 of the successive approximation register (SAR) is set and the tap selector sets the series resistor string voltage tap to (1/2) VDD.
- (5) The voltage difference between the series resistor string voltage tap and analog input is compared with a voltage comparator. If the analog input is greater than (1/2) VDD, the MSB of SAR remains set. If the input is smaller than (1/2) VDD, the MSB is reset.
- (6) Next, bit 6 of SAR is automatically set and the operation proceeds to the next comparison. In this case, the series resistor string voltage tap is selected according to the preset value of bit 7 as described below.
  - Bit 7 = 1: (3/4) VDD
  - Bit 7 = 0: (1/4) VDD

The voltage tap and analog input voltage are compared and bit 6 of SAR is manipulated with the result as follows.

- Analog input voltage ≥ Voltage tap: Bit 6 = 1
- Analog input voltage < Voltage tap: Bit 6 = 0
- (7) Comparison of this sort continues up to bit 0 of SAR.
- (8) Upon completion of the comparison of 8 bits, any valid digital resultant value remains in SAR and the resultant value is transferred to and latched in A/D conversion result register 3 (ADCR3).

At the same time, the A/D conversion termination interrupt request (INTAD3) can also be generated.

## Caution The value immediately after A/D conversion has been started may not satisfy the ratings.

#### Figure 10-5. A/D Converter Basic Operation



A/D conversion operations are performed continuously until bit 7 (ADCS3) of the ADM is reset (0) by software. If a write to ADM3 or ADS3 is performed during an A/D conversion operation, the conversion operation is initialized, and if the ADCS3 bit is set (1), conversion starts again from the beginning.

After reset input, the value of ADCR3 is undefined.

## 10.4.2 Input voltage and conversion results

The relationship between the analog input voltage input to the analog input pins (ANI0 to ANI5) and the A/D conversion result (the value stored in A/D conversion result register 3 (ADCR3) is shown by the following expression.

ADCR3 = INT (
$$\frac{V_{IN}}{V_{DD}} \times 256 + 0.5$$
)

or

$$(\mathsf{ADCR3} - 0.5) \times \frac{\mathsf{V}_{\mathsf{DD}}}{256} \leq \mathsf{V}_{\mathsf{IN}} < (\mathsf{ADCR3} + 0.5) \times \frac{\mathsf{V}_{\mathsf{DD}}}{256}$$

Remark INT(): Function which returns integer parts of value in parentheses.

VIN: Analog input voltage

VDD: VDD pin voltage

ADCR3: A/D conversion result register 3 (ADCR3) value

Figure 10-6 shows the relationship between the analog input voltage and the A/D conversion result.





#### **10.4.3** A/D converter operating mode

The A/D converter has the following two modes:

| • A/D conversion operation mode: | In this mode, the voltage applied to the analog input pin selected from ANIO |
|----------------------------------|------------------------------------------------------------------------------|
|                                  | to ANI5 is converted into a digital signal. The result of the A/D conversion |
|                                  | is stored in A/D conversion result register 3 (ADCR3), and at the same time, |
|                                  | an interrupt request signal (INTAD3) is generated.                           |

Power-fail comparison mode: The digital value resulting from A/D conversion is compared with the value assigned to power-fail comparison threshold value register 3 (PFT3) is compared. If the result of the comparison matches the condition set by bit 6 (PFCM3) of power-fail comparison mode register 3 (PFM3), an interrupt request signal (INTAD3) is generated.

## (1) A/D conversion operation mode

When bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) is set to 1, the A/D conversion starts on the voltage applied to the analog input pins specified with bits 0 to 3 (ADS30 to ADS33) of ADS3.

Upon termination of the A/D conversion, the conversion result is stored in A/D conversion result register 3 (ADCR3) and the interrupt request signal (INTAD3) is generated. After one A/D conversion operation is started and terminated, the next A/D conversion operation starts immediately. The A/D conversion operation continues repeatedly until new data is written to ADM3.

If data is written to ADCS3 again during A/D conversion, the converter suspends its A/D conversion operation and starts A/D conversion on the newly written data.

If data with ADCS3 set to 0 is written to ADM3 during A/D conversion, the A/D conversion operation stops immediately.



#### Figure 10-7. A/D Conversion Operation

**Remarks 1.** n = 0, 1, ..., 5 **2.** m = 0, 1, ..., 5

**Note** The conversion result is illegal immediately after bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) has been set to 1 (to enable conversion).

Caution Reset bit 5 (PFHRM3) of power-fail comparison mode register 3 (PFM3) to 0.

### (2) Power-fail comparison mode

In the power-fail comparison mode, the digital value converted from analog input is compared in units of 8 bits.

If the result of the comparison matches the condition set by bit 6 (PFCM3) of power-fail comparison mode register 3 (PFM3), an interrupt request (INTAD3) is generated.

Moreover, the power-fail comparison mode can be used in the HALT mode. At this time, the HALT mode can be released by generating the interrupt request signal (INTAD3) as a result of comparison (however, the A/ D operation must be executed before the HALT instruction is executed).

To set the power-fail comparison mode, set bit 7 (PEEN3) of PFM3 to 1, set bit 6 (PFCM3) to the generation condition of INTAD, and assign the threshold value to be compared with the value of A/D conversion result register 3 (ADCR3) to power-fail comparison threshold value register 3 (PFT3).

By setting bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) to 1, the voltage applied to the analog input pin specified by ADS3 is converted into a digital signal. When the A/D conversion has been completed, the result of the conversion is stored in ADCR3. This conversion result is compared with the value set in PFT3 and if the result of the comparison matches the condition set by bit 6 (PFCM3) of PFM3, an interrupt request signal (INTAD3) is generated.

| Symbol | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     | Address | After reset | R/W |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|---------|-------------|-----|
| PFT3   | PFT37 | PFT36 | PFT35 | PFT34 | PFT33 | PFT32 | PFT31 | PFT30 | FF15H   | 00H         | R/W |

Remark Bit 7 (PFT37) is the MSB, and bit 0 (PFT30) is the LSB.
For the setting value, refer to 10.4.2 Input voltage and conversion results.

- Cautions 1. In the power-fail comparison mode, the first result (A/D conversion result and interrupt request (INTAD)) of the A/D conversion (started by setting bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) to 1) is not correct.
  - 2. When executing A/D conversion in the HALT mode using the power-fail HALT repeat mode, clear the interrupt request flag (ADIF) after the first conversion has been completed immediately after bit 7 (ADCS3) of ADM3 has been set to 1, and bit 5 (PFHRM3) of power-fail comparison mode register 3 (PFM3) has been set to 1, before executing the HALT instruction.
  - 3. To set the power-fail comparison mode in the HALT mode, be sure to set bit 5 (PFHRM3) of PFM3 to 1 before executing the HALT instruction; otherwise comparison cannot be performed correctly because the conversion result in the HALT mode is not stored in A/ D conversion result register 3 (ADCR3). If bit 5 (PFHRM3) of PFM3 is set in the normal operating mode (other than HALT mode), the A/D conversion is not performed correctly. Therefore, be sure to clear this bit to 0 in the normal mode.





### (1) In normal mode (other than HALT mode)

- **Notes 1.** The conversion data is undefined immediately after bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) is set to 1 (to start conversion).
  - The first result of the A/D conversion (A/D conversion result and interrupt request) is not correct. Do not use this result because there is a possibility that it will be determined that the comparison condition has matched even if it has not.
- Caution Set power-fail comparison threshold value register 3 (PFT3) and power-fail comparison mode register 3 (PFM3) before starting conversion. Be sure to reset bit 5 (PFHRM3) of PFM3 to 0 (to disable HALT repeat mode setting).
- **Remark** n = 0, 1, ... 5m = 0, 1, ... 5



Figure 10-9. A/D Conversion Operation in Power-Fail Comparison Mode (2/3)

(2) In HALT repeat mode (when generation of interrupt (INTAD3) is used to release HALT mode)

- **Notes 1.** The conversion data is undefined immediately after bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) is set to 1 (to start conversion).
  - 2. When executing A/D conversion in the HALT mode by using the power-fail comparison mode, clear the interrupt request flag (ADIF) after the first conversion has been completed immediately after bit 7 (ADCS3) of ADM3 has been set to 1, and bit 5 (PFHRM3) of power-fail comparison mode register 3 (PFM3) has been set to 1, before executing the HALT instruction.
  - **3.** The first result of the A/D conversion (A/D conversion result and interrupt request) is not correct. Do not use this result because there is a possibility that it will be determined that the comparison condition has matched even if it has not.

## Caution Be sure to set bit 5 (PFHRM3) of PFM3 to 1 (to enable the HALT repeat mode setting).

**Remark** n = 0, 1, ... 5

## Figure 10-9. A/D Conversion Operation in Power-Fail Comparison Mode (3/3)

## (3) In HALT repeat mode (when generation of interrupt (INTAD3) is not used to release HALT mode)



- **Notes 1.** The conversion data is undefined immediately after bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) is set to 1 (to start conversion).
  - 2. When executing A/D conversion in the HALT mode by using the power-fail HALT repeat mode, clear the interrupt request flag (ADIF) after the first conversion has been completed immediately after bit 7 (ADCS3) of ADM3 has been set to 1, and bit 5 (PFHRM3) of power-fail comparison mode register 3 (PFM3) has been set to 1, before executing the HALT instruction.
  - **3.** The first result of the A/D conversion (A/D conversion result and interrupt request) is not correct. Do not use this result because there is a possibility that it will be determined that the comparison condition has matched even if it has not.

Caution Be sure to set bit 5 (PFHRM3) of PFM3 to 1 (to enable the HALT repeat mode setting).

**Remark** n = 0, 1, ... 5

#### 10.5 Notes on A/D Converter

#### (1) Current consumption in standby mode

The A/D converter is stopped in the standby mode. At this time, the current consumption can be reduced by stopping the conversion operation (by resetting bit 7 (ADCS3) of A/D converter mode register 3 (ADM3) to 0).

Figure 10-10 shows how to reduce the current consumption in the standby mode.

Figure 10-10. Example of Reducing Current Consumption in Standby Mode



#### (2) Input range of ANI0 to ANI5

The input voltages of ANI0 to ANI5 should be within the specified range. In particular, if a voltage above VDD or below GND is input (even if within the absolute maximum rating range), the conversion value for that channel will be undefined. The conversion values of the other channels may also be affected.

#### (3) Conflicting operations

- <1> Conflict between writing A/D conversion result register 3 (ADCR3) on completion of conversion and reading ADCR3 by an instruction Reading ADCR3 takes precedence. After ADCR3 has been read, a new conversion result is written to ADCR3.
- <2> Conflict between writing ADCR3 on completion of conversion and writing A/D converter mode register 3 (ADM3) or writing analog input channel specification register 3 (ADS3) Writing ADM3 or ADS3 takes precedence. ADCR3 is not written. Nor is the conversion completion interrupt request signal (INTAD3) generated.

#### (4) ANI0 to ANI5

The analog input pins ANI0 to ANI5 also function as input port (P10 to P15) pins.

When A/D conversion is performed with any of pins ANI0 to ANI5 selected, be sure not to execute a PORT1 input instruction while conversion is in progress, as this may reduce the conversion resolution.

Also, if digital pulses are applied to a pin adjacent to the pin in the process of A/D conversion, the expected A/D conversion value may not be obtainable due to coupling noise. Therefore, avoid applying pulses to pins adjacent to the pin undergoing A/D conversion.

#### (5) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even if analog input channel specification register 3 (ADS3) is changed.

Caution is therefore required since, if an analog input pin is changed during A/D conversion, the A/D conversion result and conversion end interrupt request flag for the pre-change analog input may be set just before the ADS3 rewrite, and when ADIF is read immediately after the ADM rewrite, ADIF may be set despite the fact that the A/D conversion for the post-change analog input has not ended.

When the A/D conversion is stopped and then resumed, clear ADIF before it is resumed.



Figure 10-11. A/D Conversion End Interrupt Request Generation Timing

**Remarks 1.** n = 0, 1, ..., 5 **2.** m = 0, 1, ..., 5

#### (6) Conversion result immediately after starting A/D conversion

The first A/D conversion result value is undefined immediately after the A/D conversion operation has been started. Poll the A/D conversion completion interrupt request (INTAD3) and discard the first conversion result.

#### (7) Reading A/D conversion result register 3 (ADCR3)

If data is written to A/D converter mode register 3 (ADM3) and analog input channel specification register 3 (ADS3), the contents of ADCR3 can be undefined. Read the conversion value before writing ADM3 and ADS3 after the conversion operation has been completed; otherwise the correct conversion result may not be read.

# CHAPTER 11 SERIAL INTERFACES SIO30 TO SIO32

# 11.1 Functions of Serial Interfaces SIO30 to SIO32

The serial interface SIO3n has the following two modes.

# (1) Operation stop mode

This mode is used when serial transfer is not performed. For details, refer to **11.4.1 Operation stop mode**.

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

In this mode, 8-bit data is transferred by using three lines: serial clock (SCK3n), serial output (SO3n), and serial input (SI3n) lines.

Because transmission and reception can be executed simultaneously in this mode, the processing time of data transfer can be shortened.

The first bit of the 8-bit data to be transferred is the MSB.

The 3-wire serial I/O mode is useful for connecting a peripheral I/O or display controller with a clocked serial interface. For details, refer to **11.4.2 3-wire serial I/O mode**.

Figures 11-1 to 11-3 show the block diagrams of the serial interface SIO3n.

**Remark** n = 0 to 2



## Figure 11-1. Block Diagram of Serial Interface SIO30



Figure 11-2. Block Diagram of Serial Interface SIO31

Figure 11-3. Block Diagram of Serial Interface SIO32



# 11.2 Configuration of Serial Interfaces SIO30 to SIO32

The serial interface SIO3n consists of the following hardware.

| Table 11-1. | Configuration | of Serial | Interfaces | SIO30 to | SIO32 |
|-------------|---------------|-----------|------------|----------|-------|
|-------------|---------------|-----------|------------|----------|-------|

| ltem              | Configuration                                                                                            |  |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| Register          | ter Serial I/O shift registers 30 to 32 (SIO30 to SIO32)                                                 |  |  |  |
| Control registers | Serial operating mode registers 30 to 32 (CSIM30 to CSIM32)<br>Serial port select register 32 (SIO32SEL) |  |  |  |

# (1) Serial I/O shift registers 30 to 32 (SIO30 to SIO32)

These 8-bit registers convert parallel data into serial data and transmit or receive the serial data (shift operation) in synchronization with a serial clock.

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

Serial operation is started by writing or reading data to or from SIO3n when bit 7 (CSIE3n) of serial operating mode register 3n (CSIM3n) is 1.

Data written to SIO3n is output to a serial output line (SO3n) for transmission.

Data is read to SIO3n from a serial input line (SI3n) for reception.

Reset input makes the values of these registers undefined.

Caution Do not execute access other than that for the transfer start trigger to SIO3n during a transfer operation (the read operation is disabled when MODE3n = 0, and the write operation is disabled when MODE3n = 1).

**Remark** n = 0 to 2

# 11.3 Registers Controlling Serial Interfaces SIO30 to SIO32

The following registers control the serial interface SIO3n.

- Serial operating mode registers 30 to 32 (CSIM30 to CSIM32)
- Serial port select register 32 (SIO32SEL)

#### (1) Serial operating mode register 30 to 32 (CSIM30 to CSIM32)

These registers select the serial clock of SIO3n and an operating mode, and enable or disable the operation. CSIM3n is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears these registers to 00H.

#### Figure 11-4. Format of Serial Operating Mode Registers 30 to 32 (CSIM30 to CSIM32)

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      | Address | After reset | R/W |  |
|--------|--------|---|---|---|---|--------|--------|--------|---------|-------------|-----|--|
| CSIM30 | CSIE30 | 0 | 0 | 0 | 0 | MODE30 | SCL301 | SCL300 | FF6FH   | 00H         | R/W |  |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |  |
| CSIM31 | CSIE31 | 0 | 0 | 0 | 0 | MODE31 | SCL311 | SCL310 | FF6DH   | 00H         | R/W |  |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |  |
| CSIM32 | CSIE32 | 0 | 0 | 0 | 0 | MODE32 | SCL321 | SCL320 | FF6BH   | 00H         | R/W |  |

| CSIE3n | Enable/disable of SIO3n operation |                           |                                                   |  |  |  |  |  |  |
|--------|-----------------------------------|---------------------------|---------------------------------------------------|--|--|--|--|--|--|
|        | Shift register operation          | Serial counter            | Port                                              |  |  |  |  |  |  |
| 0      | Disables operation                | Cleared                   | Port function <sup>Note 1</sup>                   |  |  |  |  |  |  |
| 1      | Enables operation                 | Enables counter operation | Serial function + port function <sup>Note 2</sup> |  |  |  |  |  |  |

| MODE3n | Transfer operation mode flag      |                        |                          |  |  |  |  |  |  |
|--------|-----------------------------------|------------------------|--------------------------|--|--|--|--|--|--|
|        | Operating mode                    | Transfer start trigger | SO3n output              |  |  |  |  |  |  |
| 0      | Transmit or transmit/receive mode | SIO3n write            | Serial output            |  |  |  |  |  |  |
| 1      | Receive only mode                 | SIO3n read             | Fixed to low levelNote 3 |  |  |  |  |  |  |

| SCL3n1 | SCL3n0 | Clock selection               |  |  |  |  |  |
|--------|--------|-------------------------------|--|--|--|--|--|
| 0      | 0      | External clock input to SCK3n |  |  |  |  |  |
| 0      | 1      | fx/2 <sup>4</sup> (281 kHz)   |  |  |  |  |  |
| 1      | 0      | fx/2 <sup>5</sup> (141 kHz)   |  |  |  |  |  |
| 1      | 1      | fx/2 <sup>6</sup> (70.3 kHz)  |  |  |  |  |  |

- **Notes 1.** The SI3n, SO3n, and SCK3n pins can be used as port pins when CSIE3n = 0 (when SIO3n operation is stopped).
  - 2. When CSIE3n = 1 (when SIO3n operation is enabled), the SI3n pin can be used as a port pin if only the transmission function is used, and the SO3n pin can be used as a port pin in the receive mode.
  - **3.** The SO3n pin can be used as a port pin.

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

**2.** ( ): fx = 4.5 MHz

| Serial Type                                             | Serial Interface                                 | Serial Interface                                 | Serial Inter                                       | face SIO32                                          |
|---------------------------------------------------------|--------------------------------------------------|--------------------------------------------------|----------------------------------------------------|-----------------------------------------------------|
| Operation Mode                                          | SIO30                                            | SIO31                                            | S32SEL0 = 0                                        | S32SEL0 = 1                                         |
| Serial clock output                                     | PM72 = 0                                         | PM76 = 0                                         | PM122 = 0                                          | PM125 = 0                                           |
| (master transmission or                                 | (set P72/SCK30 pin                               | (set P76/SCK31 pin                               | (set P122/SCK32 pin                                | (set P125/SCK321                                    |
| reception)                                              | to output mode)                                  | to output mode)                                  | to output mode)                                    | pin to output mode)                                 |
| Serial clock input<br>(slave transmission or reception) | PM72 = 1<br>(set P72/SCK30 pin<br>to input mode) | PM76 = 1<br>(set P76/SCK31 pin<br>to input mode) | PM122 = 1<br>(set P122/SCK32 pin<br>to input mode) | PM125 = 1<br>(set P125/SCK321<br>pin to input mode) |
| In transmit or transmit/receive mode                    | PM71 = 0                                         | PM75 = 0                                         | PM121 = 0                                          | PM124 = 0                                           |
|                                                         | (set P71/SO30 pin to                             | (set P75/SO31 pin to                             | (set P121/SO32 pin                                 | (set P124/SO321 pin                                 |
|                                                         | output mode)                                     | output mode)                                     | to output mode)                                    | to output mode)                                     |
| In receive mode                                         | PM70 = 1                                         | PM74 = 1                                         | PM120 = 1                                          | PM123 = 1                                           |
|                                                         | (set P70/SI30 pin to                             | (set P74/SI31 pin to                             | (set P120/SI32 pin to                              | (set P123/SI321 pin                                 |
|                                                         | input mode)                                      | input mode)                                      | input mode)                                        | to input mode)                                      |

# Caution Set the port mode register (PM××) as follows in the 3-wire serial I/O mode. Set the output latch to 0.

# (2) Serial port select register 32 (SIO32SEL)

This register selects the port used for serial interface SIO32. SIO32SEL is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears this register to 00H.

| Symbol   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       | Address | After reset | R/W |
|----------|---|---|---|---|---|---|---|---------|---------|-------------|-----|
| SIO32SEL | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S32SEL0 | FF69H   | 00H         | R/W |

| S32SEL0             | Serial interface SIO32 port selection |            |             |  |  |  |  |  |  |
|---------------------|---------------------------------------|------------|-------------|--|--|--|--|--|--|
|                     | SI pin                                | SO pin     | SCK pin     |  |  |  |  |  |  |
| <sub>O</sub> Note 1 | P120/SI32                             | P121/SO32  | P122/SCK32  |  |  |  |  |  |  |
| 1 Note 2            | P123/SI321                            | P124/SO321 | P125/SCK321 |  |  |  |  |  |  |

Notes 1. The P123/SI321, P124/SO321, P125/SCK321 pins can be used as port pins.

2. The P120/SI32, P121/SO32, P122/SCK32 pins can be used as port pins.

# 11.4 Operations of Serial Interfaces SIO30 to SIO32

This section explains the two modes of the serial interfaces SIO30 to SIO32.

#### 11.4.1 Operation stop mode

In this mode, serial transfer is not performed.

The alternate-function pins used for the serial interface can be used as ordinary I/O port pins.

# (1) Register setting

The operation stop mode is set using serial operating mode register 3n (CSIM3n). CSIM3n is set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears this register to 00H.

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      | Address | After reset | R/W |
|--------|--------|---|---|---|---|--------|--------|--------|---------|-------------|-----|
| CSIM30 | CSIE30 | 0 | 0 | 0 | 0 | MODE30 | SCL301 | SCL300 | FF6FH   | 00H         | R/W |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| CSIM31 | CSIE31 | 0 | 0 | 0 | 0 | MODE31 | SCL311 | SCL310 | FF6DH   | 00H         | R/W |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| CSIM32 | CSIE32 | 0 | 0 | 0 | 0 | MODE32 | SCL321 | SCL320 | FF6BH   | 00H         | R/W |

| CSIE3n | Enable/disable of SIO3n operation |                         |                                        |  |  |  |  |  |
|--------|-----------------------------------|-------------------------|----------------------------------------|--|--|--|--|--|
|        | Shift register operation          | Serial counter          | Port                                   |  |  |  |  |  |
| 0      | Disables operation                | Cleared                 | Port function <sup>Note 1</sup>        |  |  |  |  |  |
| 1      | Enables operation                 | Enables count operation | Serial function + port function Note 2 |  |  |  |  |  |

- **Notes 1.** The SI3n, SO3n, and SCK3n pins can be used as port pins when CSIE3n = 0 (when SIO3n operation is stopped).
  - 2. When CSIE3n = 1 (when SIO3n operation is enabled), the SI3n pin can be used as a port pin if only the transmission function is used, and the SO3n pin can be used as a port pin in the receive mode.

Remark n = 0 to 2

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

The 3-wire serial I/O mode is useful for connecting a peripheral I/O or display controller equipped with a clocked serial interface.

In this mode, communication is executed by using three lines: serial clock (SCK3n), serial output (SO3n), and serial input (SI3n) lines.

# (1) Register setting

The 3-wire serial I/O mode is set using serial operating mode register 3n (CSIM3n). These registers are set with a 1-bit or 8-bit memory manipulation instruction. Reset input clears these registers to 00H.

| Symbol | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      | Address | After reset | R/W |
|--------|--------|---|---|---|---|--------|--------|--------|---------|-------------|-----|
| CSIM30 | CSIE30 | 0 | 0 | 0 | 0 | MODE30 | SCL301 | SCL300 | FF6FH   | 00H         | R/W |
|        |        |   |   |   |   |        |        |        |         |             |     |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| CSIM31 | CSIE31 | 0 | 0 | 0 | 0 | MODE31 | SCL311 | SCL310 | FF6DH   | 00H         | R/W |
|        |        |   |   |   |   |        |        |        |         |             |     |
|        | <7>    | 6 | 5 | 4 | 3 | 2      | 1      | 0      |         |             |     |
| CSIM32 | CSIE32 | 0 | 0 | 0 | 0 | MODE32 | SCL321 | SCL320 | FF6BH   | 00H         | R/W |

| CSIE3n | Enable/disable of SIO3n operation |                           |                                                   |  |  |  |  |  |  |  |
|--------|-----------------------------------|---------------------------|---------------------------------------------------|--|--|--|--|--|--|--|
|        | Shift register operation          | Serial counter            | Port                                              |  |  |  |  |  |  |  |
| 0      | Disables operation                | Cleared                   | Port function <sup>Note 1</sup>                   |  |  |  |  |  |  |  |
| 1      | Enables operation                 | Enables counter operation | Serial function + port function <sup>Note 2</sup> |  |  |  |  |  |  |  |

| MODE3n | Transfer operation mode flag      |                        |                          |  |  |  |  |  |  |
|--------|-----------------------------------|------------------------|--------------------------|--|--|--|--|--|--|
|        | Operating mode                    | Transfer start trigger | SO3n output              |  |  |  |  |  |  |
| 0      | Transmit or transmit/receive mode | SIO3n write            | Serial output            |  |  |  |  |  |  |
| 1      | Receive-only mode                 | SIO3n read             | Fixed to low levelNote 3 |  |  |  |  |  |  |

| SCL3n1 | SCL3n0 | Clock selection               |
|--------|--------|-------------------------------|
| 0      | 0      | External clock input to SCK3n |
| 0      | 1      | fx/2 <sup>4</sup> (281 kHz)   |
| 1      | 0      | f∞/2 <sup>5</sup> (141 kHz)   |
| 1      | 1      | fx/2 <sup>6</sup> (70.3 kHz)  |

- **Notes 1.** The SI3n, SO3n, and SCK3n pins can be used as port pins when CSIE3n = 0 (when SIO3n operation is stopped).
  - When CSIE3n = 1 (when SIO3n operation is enabled), the SI3n pin can be used as a port pin if only the transmission function is used, and the SO3n pin can be used as a port pin in the receive mode.
  - 3. The SO3n pin can be used as a port pin.

Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

| Serial Type                                                  | Serial Interface                                  | Serial Interface                                  | Serial Interface SIO32                              |                                                      |  |  |
|--------------------------------------------------------------|---------------------------------------------------|---------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|--|--|
| Operation Mode                                               | SIO30                                             | SIO31                                             | S32SEL0 = 0                                         | S32SEL0 = 1                                          |  |  |
| Serial clock output<br>(master transmission or<br>reception) | PM72 = 0<br>(set P72/SCK30 pin<br>to output mode) | PM76 = 0<br>(set P76/SCK31 pin<br>to output mode) | PM122 = 0<br>(set P122/SCK32 pin<br>to output mode) | PM125 = 0<br>(set P125/SCK321<br>pin to output mode) |  |  |
| Serial clock input<br>(slave transmission or reception)      | PM72 = 1<br>(set P72/SCK30 pin<br>to input mode)  | PM76 = 1<br>(set P76/SCK31 pin<br>to input mode)  | PM122 = 1<br>(set P122/SCK32 pin<br>to input mode)  | PM125 = 1<br>(set P125/SCK321<br>pin to input mode)  |  |  |
| In transmit or transmit/receive<br>mode                      | PM71 = 0<br>(set P71/SO30 pin to<br>output mode)  | PM75 = 0<br>(set P75/SO31 pin to<br>output mode)  | PM121 = 0<br>(set P121/SO32 pin<br>to output mode)  | PM124 = 0<br>(set P124/SO321 pin<br>to output mode)  |  |  |
| In receive mode                                              | PM70 = 1<br>(set P70/SI30 pin to<br>input mode)   | PM74 = 1<br>(set P74/SI31 pin to<br>input mode)   | PM120 = 1<br>(set P120/SI32 pin to<br>input mode)   | PM123 = 1<br>(set P123/SI321 pin<br>to input mode)   |  |  |

# Caution Set the port mode register (PM××) as follows in the 3-wire serial I/O mode. Set the output latch to 0.

## (2) Communication operation

In the 3-wire serial I/O mode, data is transmitted or received in 8-bit units. Data is transmitted or received in synchronization with the serial clock.

The shift operation of serial I/O shift register 3n (SIO3n) is performed at the falling edge of the serial clock  $(\overline{SCK3n})$ . The transmit data is retained in SO3n latch and is output from the SO3n pin. The receive data input to the SI3n pin is latched to SIO3n at the falling edge of the serial clock.

When 8-bit data has been transferred, the operation of SIO3n is automatically stopped, and an interrupt request flag (CSIIF3n) is set.





Transfer starts at falling edge of SCK3n

#### (3) Starting transfer

Serial transfer is started by writing (or reading) the transfer data to serial I/O shift register 3n (SIO3n) when the following conditions are satisfied.

- Operation control bit of SIO3n (bit 7 (CSIE3n) of serial operation mode register 3n (CSIM3n)) = 1
- If the internal serial clock is stopped or SCK3n is high level after transfer of 8-bit serial data
- Transmit/receive mode
   Transfer is started if SIO3n is written when bit 7 (CSIE3n) of CSIM3n = 1, and bit 2 (MODE3n) = 0
- Receive mode
   Transfer is started if SIO3n is read when bit 7 (CSIE3n) of CSIM3n = 1, and bit 2 (MODE3n) = 1

# Caution Serial transfer is not started even if 1 is written to CSIE3n after data is written to SIO3n.

On completion of transfer of the 8-bit data, serial transfer is automatically stopped, and an interrupt request flag (CSIIF3n) is set.

# **CHAPTER 12 INTERRUPT FUNCTIONS**

# **12.1 Interrupt Function Types**

The following three types of interrupt functions are used.

# (1) Non-maskable interrupts

This type of interrupt is acknowledged unconditionally even if interrupts are disabled. It does not undergo interrupt priority control and is given top priority over all other interrupt requests. It generates a standby release signal. One interrupt source from the watchdog timer is incorporated as a non-maskable interrupt.

#### (2) Maskable interrupts

These interrupts undergo mask control. Maskable interrupts can be divided into a high interrupt priority group and a low interrupt priority group by setting the priority specification flag register (PR).

Multiple interrupt servicing is possible if a high-priority interrupt is generated while a low-priority interrupt is being serviced. If two or more interrupts with the same priority are simultaneously generated, each interrupt has a predetermined priority (refer to **Table 12-1**).

A standby release signal is generated.

Maskable interrupts are provided for each product as follows.

• μPD178053, 178054, 178F054 Internal: 11, external: 5

# (3) Software interrupt

This is a vectored interrupt generated by executing the BRK instruction. It is acknowledged even in an interrupt disabled state. The software interrupt does not undergo interrupt priority control.

# 12.2 Interrupt Sources and Configuration

The  $\mu$ PD178053, 178054, and 178F054 have a total of 17 sources (non-maskable interrupt, maskable interrupt, software interrupt) (refer to **Table 12-1**).

**Remark** Either a non-maskable interrupt or a maskable interrupt (internal) can be selected for the watchdog timer interrupt source (INTWDT).

| Interrupt Type | Default<br>Priority <sup>Note 1</sup> |          | Interrupt Source                                                       | Internal/<br>External | Vector<br>Table | Basic<br>Configuration |  |
|----------------|---------------------------------------|----------|------------------------------------------------------------------------|-----------------------|-----------------|------------------------|--|
|                | Thomy                                 | Name     | Trigger                                                                | External              | Address         | Type <sup>Note 2</sup> |  |
| Non-maskable   | -                                     | INTWDT   | Overflow of watchdog timer<br>(when watchdog timer mode 1 is selected) | Internal              | 0004H           | (A)                    |  |
| Maskable       | 0                                     | INTWDT   | Overflow of watchdog timer<br>(when interval timer mode is selected)   |                       |                 | (B)                    |  |
|                | 1                                     | INTP0    | Pin input edge detection                                               | External              | 0006H           | (C)                    |  |
|                | 2                                     | INTP1    |                                                                        |                       | 0008H           |                        |  |
|                | 3                                     | INTP2    |                                                                        |                       | 000AH           |                        |  |
|                | 4                                     | INTP3    |                                                                        |                       | 000CH           |                        |  |
|                | 5                                     | INTP4    |                                                                        |                       | 000EH           |                        |  |
|                | 6                                     | INTKY    | Detection of key input of port 4                                       | Internal              | 0010H           | (B)                    |  |
|                | 7                                     | INTCSI31 | End of transfer by serial interface SIO31                              |                       | 0012H           |                        |  |
|                | 8                                     | INTBTM0  | Generation of basic timer match signal                                 |                       | 0014H           |                        |  |
|                | 9                                     | INTAD3   | End of conversion by A/D converter                                     |                       | 0016H           |                        |  |
|                | 10                                    | INTCSI32 | End of transfer by serial interface SIO32                              |                       | 0018H           |                        |  |
|                | 11                                    | INTCSI30 | End of transfer by serial interface SIO30                              |                       | 001AH           |                        |  |
|                | 12 INTTM                              |          | Generation of match signal of 8-bit timer/<br>event counter 50         |                       | 001CH           |                        |  |
|                | 13                                    | INTTM51  | Generation of match signal of 8-bit timer/<br>event counter 51         |                       | 001EH           |                        |  |
|                | 14                                    | INTTM52  | Generation of match signal of 8-bit timer/<br>event counter 52         |                       | 0020H           |                        |  |
|                | 15                                    | INTTM53  | Generation of match signal of 8-bit timer 53                           |                       | 0022H           |                        |  |
| Software       | -                                     | BRK      | Execution of BRK instruction                                           | _                     | 003EH           | (D)                    |  |

## Table 12-1. Interrupt Sources

**Notes 1.** If two or more maskable interrupts occur at the same time, they are acknowledged or held pending according to their default priorities. The default priority 0 is the highest, and 15 is the lowest.

2. (A) to (D) under the heading Basic Configuration Type correspond to (A) to (D) in Figure 12-1.

#### Figure 12-1. Basic Configuration of Interrupt Function (1/2)

(A) Internal non-maskable interrupt



## (B) Internal maskable interrupt



#### (C) External maskable interrupt



# Figure 12-1. Basic Configuration of Interrupt Function (2/2)

# (D) Software interrupt



#### Remark

- IF: Interrupt request flag IE: Interrupt enable flag
- ISP: Inservice priority flag
- MK: Interrupt mask flag
- PR: Priority specification flag

# **12.3 Registers Controlling Interrupt Functions**

The following six types of registers are used to control the interrupt functions.

- Interrupt request flag register (IF0L, IF0H)
- Interrupt mask flag register (MK0L, MK0H)
- Priority specification flag register (PR0L, PR0H)
- External interrupt rising edge enable register (EGP)
- External interrupt falling edge enable register (EGN)
- Program status word (PSW)

Table 12-2 gives a listing of interrupt request flags, interrupt mask flags, and priority specification flags corresponding to interrupt request sources.

#### Table 12-2. Various Flags Corresponding to Interrupt Request Sources

| Interrupt Source | Interrupt Requ | uest Flag | Interrupt Ma | sk Flag  | Priority Specification Flag |          |
|------------------|----------------|-----------|--------------|----------|-----------------------------|----------|
|                  |                | Register  |              | Register |                             | Register |
| INTWDT           | WDTIF          | IFOL      | WDTMK        | MK0L     | WDTPR                       | PR0L     |
| INTP0            | PIF0           |           | PMK0         |          | PPR0                        |          |
| INTP1            | PIF1           |           | PMK1         |          | PPR1                        |          |
| INTP2            | PIF2           |           | PMK2         |          | PPR2                        |          |
| INTP3            | PIF3           |           | РМК3         |          | PPR3                        |          |
| INTP4            | PIF4           |           | PMK4         |          | PPR4                        |          |
| INTKY            | KYIF           |           | КҮМК         |          | KYPR                        |          |
| INTCSI31         | CSIIF31        |           | CSIMK31      |          | CSIPR31                     |          |
| INTBTM0          | BTMIF0         | IF0H      | BTMMK0       | МК0Н     | BTMPR0                      | PR0H     |
| INTAD3           | ADIF           |           | ADMK         |          | ADPR                        |          |
| INTCSI32         | CSIIF32        |           | CSIMK32      |          | CSIPR32                     |          |
| INTCSI30         | CSIIF30        |           | CSIMK30      |          | CSIPR30                     |          |
| INTTM50          | TMIF50         |           | TMMK50       |          | TMPR50                      |          |
| INTTM51          | TMIF51         |           | TMMK51       |          | TMPR51                      |          |
| INTTM52          | TMIF52         |           | TMMK52       |          | TMPR52                      |          |
| INTTM53          | TMIF53         |           | ТММК53       |          | TMPR53                      |          |

#### (1) Interrupt request flag registers (IF0L, IF0H)

The interrupt request flags are set to 1 when the corresponding interrupt request is generated or an instruction is executed. They are cleared to 0 when an instruction is executed upon acknowledgment of an interrupt request or upon application of reset input.

IF0L and IF0H are set with a 1-bit or 8-bit memory manipulation instruction. If IF0L and IF0H are used as a 16-bit register IF0, use a 16-bit memory manipulation instruction for the setting. Reset input clears these registers to 00H.

Figure 12-2. Format of Interrupt Request Flag Registers (IF0L, IF0H)

| Symbol | <7>     | <6>    | <5>    | <4>    | <3>     | <2>     | <1>  | <0>    | Address | After reset | R/W |
|--------|---------|--------|--------|--------|---------|---------|------|--------|---------|-------------|-----|
| IF0L   | CSIIF31 | KYIF   | PIF4   | PIF3   | PIF2    | PIF1    | PIF0 | WDTIF  | FFE0H   | 00H         | R/W |
|        | <7>     | <6>    | <5>    | <4>    | <3>     | <2>     | <1>  | <0>    |         |             |     |
| IF0H   | TMIF53  | TMIF52 | TMIF51 | TMIF50 | CSIIF30 | CSIIF32 | ADIF | BTMIF0 | FFE1H   | 00H         | R/W |

| ××IF× | Interrupt request flag                                            |
|-------|-------------------------------------------------------------------|
| 0     | No interrupt request signal                                       |
| 1     | Interrupt request signal is generated;<br>Interrupt request state |

Cautions 1. WDTIF flag is R/W enabled only when a watchdog timer is used as an interval timer. If a watchdog timer is used in watchdog timer mode 1, set WDTIF flag to 0.

- 2. To operate the timers, serial interface, and A/D converter after the standby mode has been released, clear the interrupt request flag, because the interrupt request flag may be set by noise.
- 3. When an interrupt is acknowledged, the interrupt request flag is automatically cleared before entering the interrupt routine.

#### (2) Interrupt mask flag registers (MK0L, MK0H)

The interrupt mask flags are used to enable/disable the corresponding maskable interrupt servicing and to set standby clear enable/disable.

MK0L and MK0H are set with a 1-bit or 8-bit memory manipulation instruction. If MK0L and MK0H are used as a 16-bit register MK0, use a 16-bit memory manipulation instruction for the setting. Reset input sets these registers to FFH.



| ××MK× | Interrupt servicing control  |
|-------|------------------------------|
| 0     | Interrupt servicing enabled  |
| 1     | Interrupt servicing disabled |

Cautions 1. If the WDTMK flag is read when the watchdog timer is used in watchdog timer mode 1, MK0 value becomes undefined.

2. Because port 0 functions alternately as the external interrupt request input, when the output level is changed by specifying the output mode of the port function, an interrupt request flag is set. Therefore, the interrupt mask flag should be set to 1 before using the output mode.

# (3) Priority specification flag registers (PR0L, PR0H)

The priority specification flags are used to set the corresponding maskable interrupt priority orders. PR0L and PR0H are set with a 1-bit or 8-bit memory manipulation instruction. If PR0L and PR0H are used as a 16-bit register PR0, use a 16-bit memory manipulation instruction for the setting. Reset input sets these registers to FFH.

## Figure 12-4. Format of Priority Specification Flag Registers (PR0L, PR0H)

| Symbol | <7>     | <6>    | <5>    | <4>    | <3>     | <2>     | <1>  | <0>    | Address | After reset | R/W |
|--------|---------|--------|--------|--------|---------|---------|------|--------|---------|-------------|-----|
| PR0L   | CSIPR31 | KYPR   | PPR4   | PPR3   | PPR2    | PPR1    | PPR0 | WDTPR  | FFE8H   | FFH         | R/W |
|        | <7>     | <6>    | <5>    | <4>    | <3>     | <2>     | <1>  | <0>    |         |             |     |
| PR0H   | TMPR53  | TMPR52 | TMPR51 | TMPR50 | CSIPR30 | CSIPR32 | ADPR | BTMPR0 | FFE9H   | FFH         | R/W |

| ××PR× | Priority level selection |
|-------|--------------------------|
| 0     | High priority level      |
| 1     | Low priority level       |

Caution When the watchdog timer is used in watchdog timer mode 1, set the WDTPR flag to 1.

# (4) External interrupt rising edge enable register (EGP), external interrupt falling edge enable register (EGN)

These registers set the valid edge for INTP0 to INTP4.

EGP and EGN are set with a 1-bit or 8-bit memory manipulation instructions.

Reset input clears these registers to 00H.

# Figure 12-5. Format of External Interrupt Rising Edge Enable Register (EGP) and External Interrupt Falling Edge Enable Register (EGN)

| Symbol | 7 | 6 | 5 | 4    | 3    | 2    | 1    | 0    | Address | After reset | R/W |
|--------|---|---|---|------|------|------|------|------|---------|-------------|-----|
| EGP    | 0 | 0 | 0 | EGP4 | EGP3 | EGP2 | EGP1 | EGP0 | FF48H   | 00H         | R/W |
|        | 7 | 6 | 5 | 4    | 3    | 2    | 1    | 0    |         |             |     |
| EGN    | 0 | 0 | 0 | EGN4 | EGN3 | EGN2 | EGN1 | EGN0 | FF49H   | 00H         | R/W |

| EGPn | EGNn | INTPn pin valid edge selection $(n = 0 \text{ to } 4)$ |  |  |
|------|------|--------------------------------------------------------|--|--|
| 0    | 0    | nterrupt prohibited                                    |  |  |
| 0    | 1    | Falling edge                                           |  |  |
| 1    | 0    | Rising edge                                            |  |  |
| 1    | 1    | Both falling and rising edges                          |  |  |

# (5) Program status word (PSW)

The program status word is a register that holds the instruction execution result and the current status for interrupt request. The IE flag to set maskable interrupt enable/disable and the ISP flag to control multiple interrupt servicing are mapped.

Besides 8-bit unit read/write, this register can carry out operations with a bit manipulation instruction and dedicated instructions (EI and DI). When a vectored interrupt request is acknowledged, if the BRK instruction is executed, the contents of PSW are automatically saved into a stack and the IE flag is reset to 0. When a maskable interrupt request is acknowledged, the contents of the priority specification flag of the acknowledged interrupt are transferred to the ISP flag. The acknowledged interrupt is also saved into the stack with the PUSH PSW instruction. It is restored from the stack with the RETI, RETB, and POP PSW instructions. Reset input sets PSW to 02H.





#### 12.4 Interrupt Servicing Operations

#### 12.4.1 Non-maskable interrupt request acknowledgement operation

A non-maskable interrupt request is unconditionally acknowledged even if in an interrupt request acknowledgement disabled state. It does not undergo interrupt priority control and has the highest priority over all other interrupts.

If a non-maskable interrupt request is acknowledged, the acknowledged interrupt is saved to the stack, the program status word (PSW) and the program counter (PC), in that order, the IE and ISP flags are reset to 0, and the vector table contents are loaded into PC and branched.

A new non-maskable interrupt request generated during execution of a non-maskable interrupt servicing program is acknowledged after the current execution of the non-maskable interrupt servicing program is terminated (following RETI instruction execution) and one main routine instruction is executed. If a new non-maskable interrupt request is generated twice or more during non-maskable interrupt servicing program execution, only one non-maskable interrupt request is acknowledged after termination of the non-maskable interrupt servicing program execution.

Figure 12-7 shows the flowchart from generation of the non-maskable interrupt request to acknowledging it. Figure 12-8 shows the timing of acknowledging the non-maskable interrupt request, and Figure 12-9 shows the operation performed if a more than one non-maskable interrupt request occurs.









| CPU processing | Instruction | Instruction | PSW and PC save, jump to interrupt servicing | Interrupt servicing<br>program |
|----------------|-------------|-------------|----------------------------------------------|--------------------------------|
| WDTIF          |             |             |                                              |                                |

#### Figure 12-9. Non-Maskable Interrupt Request Acknowledgement Operation

(a) If a new non-maskable interrupt request is generated during non-maskable interrupt servicing program execution



(b) If two non-maskable interrupt requests are generated during non-maskable interrupt servicing program execution



#### 12.4.2 Maskable interrupt request acknowledgement operation

A maskable interrupt request becomes acknowledgeable when the interrupt request flag is set to 1 and the mask (MK) flag of the interrupt request is cleared to 0. A vectored interrupt request is acknowledged in an interrupt enable state (with IE flag set to 1). However, a low-priority interrupt request is not acknowledged during high-priority interrupt servicing (with ISP flag reset to 0).

Wait times from maskable interrupt request generation to interrupt request servicing are as follows. For the interrupt acknowledge timing, refer to **Figures 12-11** and **12-12**.

Table 12-3. Times from Maskable Interrupt Request Generation to Interrupt Servicing

|                      | Minimum Time | Maximum Time <sup>Note</sup> |
|----------------------|--------------|------------------------------|
| When $\times$ PR = 0 | 7 clocks     | 32 clocks                    |
| When ××PR = 1        | 8 clocks     | 33 clocks                    |

**Note** If an interrupt request is generated just before a divide instruction, the wait time is maximized.

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

If two or more maskable interrupt requests are generated simultaneously, the request specified for higher priority with the priority specification flag is acknowledged first. If two or more requests are specified as the same priority by the priority specification flag, the default priorities apply.

Any pending interrupt requests are acknowledged when they become acknowledgeable.

Figure 12-10 shows interrupt request acknowledgement algorithms.

If a maskable interrupt request is acknowledged, the acknowledged interrupt request is saved to the stack, the program status word (PSW) and the program counter (PC), in that order, the IE flag is reset to 0, and the acknowledged interrupt priority specification flag contents are transferred to the ISP flag. Further, the vector table data determined for each interrupt request is loaded into the PC and branched.

Return from the interrupt is possible with the RETI instruction.



Figure 12-10. Interrupt Request Acknowledgement Processing Algorithm

- ××IF: Interrupt request flag
- ××MK: Interrupt mask flag
- ××PR: Priority specification flag
- IE: Flag controlling acknowledging maskable interrupt request (1 = enable, 0 = disable)
- ISP: Flag indicating priority of interrupt currently being serviced (0 = interrupt with high priority serviced,

Vectored interrupt servicing

1 = interrupt request is not acknowledged, or interrupt with low priority serviced)



# Figure 12-11. Interrupt Request Acknowledgement Timing (Minimum Time)





| Remark | 1 clock: | fcpu | (fcpu: | CPU clock) |
|--------|----------|------|--------|------------|
|--------|----------|------|--------|------------|

#### 12.4.3 Software interrupt request acknowledgement operation

A software interrupt request is acknowledged by BRK instruction execution. Software interrupts cannot be disabled.

If a software interrupt request is acknowledged, it is saved to the stack, the program status word (PSW) and program counter (PC), in that order, the IE flag is reset to 0 and the contents of the vector tables (003EH and 003FH) are loaded into the PC and branched.

Return from the software interrupt is possible with the RETB instruction.

# Caution Do not use the RETI instruction for returning from a software interrupt.

#### 12.4.4 Multiple interrupt servicing

The acknowledgement of another interrupt request while an interrupt is being serviced is called multiple interrupt servicing.

Multiple interrupt servicing does not take place unless the interrupts (except the non-maskable interrupt) are abled to be acknowledged (IE = 1). Acknowledging another interrupt request is disabled (IE = 0) when one interrupt has been acknowledged. Therefore, to enable multiple interrupt servicing, the EI flag must be set to 1 during interrupt servicing, to enable other interrupts.

Multiple interrupt servicing may not occur even when interrupts are enabled. This is controlled by the priorities of the interrupts. Although two types of priorities, default priority and programmable priority, may be assigned to an interrupt, multiple interrupt servicing is controlled by using the programmable priority.

If an interrupt with the same priority as or a higher priority than the interrupt currently being serviced occurs, that interrupt can be acknowledged and serviced. If an interrupt with a priority lower than that of the interrupt currently being serviced occurs, that interrupt cannot be acknowledged and serviced.

An interrupt that is not acknowledged and serviced because it is disabled or it has a low priority is held pending. This interrupt is acknowledged after servicing of the current interrupt has been completed and one instruction of the main routine has been executed.

Multiple interrupt servicing is not enabled while a non-maskable interrupt is being serviced.

Table 12-4 shows the interrupts that can enter multiple interrupt servicing, and Figure 12-13 shows an example of multiple interrupt servicing.

#### Table 12-4. Interrupt Request Enabled for Multiple Interrupt Servicing During Interrupt Servicing

| Multi                                  | ple Interrupt | Non-Maskable         | M      | askable Inte | rrupt Reque | est    |
|----------------------------------------|---------------|----------------------|--------|--------------|-------------|--------|
| Request<br>Interrupt Being<br>Serviced |               | Interrupt<br>Request | PR = 0 |              | PR = 1      |        |
|                                        |               |                      | IE = 1 | IE = 0       | IE = 1      | IE = 0 |
| Non-maskable interrupt                 |               | D                    | D      | D            | D           | D      |
| Maskable interrupt                     | ISP = 0       | E                    | E      | D            | D           | D      |
|                                        | ISP = 1       | E                    | Е      | D            | E           | D      |
| Software interrupt servicing           |               | Е                    | Е      | D            | Е           | D      |

#### Remarks 1. E: Multiple interrupt servicing enabled

- **2.** D: Multiple interrupt servicing disabled
- 3. ISP and IE are the flags contained in PSW
  - ISP = 0: An interrupt with higher priority is being serviced
  - ISP = 1: An interrupt request is not accepted or an interrupt with lower priority is being serviced
  - IE = 0: Interrupt request acknowledgement is disabled
  - IE = 1: Interrupt request acknowledgement is enabled
- 4. PR is a flag contained in PR0L and PR0R.
  - PR = 0: Higher priority level
  - PR = 1: Lower priority level

#### Figure 12-13. Multiple Interrupt Servicing Example (1/2)



#### Example 1. Example where multiple interrupt occurs two times

Two interrupt requests, INTyy and INTzz, are acknowledged while interrupt INTxx is serviced, and multiple interrupt occurs. Before each interrupt request is acknowledged, the EI instruction is always executed, and the interrupt is enabled.

#### Example 2. Example where multiple interrupt does not occur because of priority control



Interrupt request INTyy that is generated while interrupt INTxx is being serviced is not acknowledged because its priority is lower than that of INTxx, and therefore, multiple interrupt does not occur. INTyy request is held pending, and is acknowledged after one instruction of the main routine has been executed.

- PR = 0: High-priority level
- PR = 1: Low-priority level
- IE = 0: Acknowledging interrupt request is disabled.

#### Figure 12-13. Multiple Interrupt Servicing Example (2/2)

#### Example 3. Example where multiple interrupt does not occur because interrupts are not enabled



Because interrupts are not enabled (EI instruction is not issued) in interrupt servicing INTxx, interrupt request INTyy is not acknowledged, and multiple interrupt does not occur. The INTyy request is held pending, and is acknowledged after one instruction of the main routine has been executed.

PR = 0: High priority level

IE = 0: Acknowledging interrupts is disabled.

#### 12.4.5 Pending interrupt requests

Even if an interrupt request is generated, the following instructions hold it pending.

- MOV PSW, #byte
- MOV A, PSW
- MOV PSW, A
- MOV1 PSW.bit, CY
- MOV1/AND1/OR1/XOR1 CY, PSW.bit
- SET1/CLR1 PSW.bit
- RETB
- RETI
- PUSH PSW
- POP PSW
- BT/BF/BTCLR PSW.bit, \$addr16
- EI
- DI
- Instructions manipulating IF0L, IF0H, MK0L, MK0H, PR0L, and PR0H registers

# Caution Because the IE flag is cleared to 0 by the software interrupt (caused by execution of the BRK instruction), a maskable interrupt request is not acknowledged even if it occurs while the BRK instruction is executed. However, a non-maskable interrupt is acknowledged.



| CPU processing | Instruction N | Instruction M | Save PSW and PC, jump to interrupt servicing | Interrupt servicing program |
|----------------|---------------|---------------|----------------------------------------------|-----------------------------|
| ××IF           |               |               |                                              |                             |

Remarks 1. Instruction N: Instruction that holds interrupt request pending

- 2. Instruction M: Instruction that does not hold interrupt request pending
- **3.** Operation of  $\times$ ×IF is not affected by value of  $\times$ ×PR.

# CHAPTER 13 PLL FREQUENCY SYNTHESIZER

# 13.1 Function of PLL Frequency Synthesizer

The PLL (Phase Locked Loop) frequency synthesizer is used to lock the frequency in the MF (Middle Frequency), HF (High Frequency), and VHF (Very High Frequency) ranges to a specific frequency by means of phase difference comparison.

The PLL frequency synthesizer divides the frequency of the signal input from the VCOL or VCOH pin by using a programmable divider, and outputs the phase difference between the frequency of this signal and reference frequency from the EO0 and EO1 pin.

The following input pin states and frequency division modes are used.

# (1) Direct division (MF) mode

The VCOL pin is used. The VCOH pin is set in the status specified by bit 3 (VCOHDMD) of the PLL mode select register (PLLMD).

# (2) Pulse swallow (HF) mode

The VCOL pin is used. The VCOH pin is set in the status specified by bit 3 (VCOHDMD) of PLLMD.

# (3) Pulse swallow (VHF) mode

The VCOH pin is used. The VCOL pin is set in the status specified by bit 2 (VCOLDMD) of PLLMD.

#### (4) VCOL and VCOH pin disable

The VCOL and VCOH pins are set in the status specified by bits 2 (VCOLDMD) and 3 (VCOHDMD) of PLLMD. At this time, the phase comparator, reference frequency generator, and charge pump operate.

#### (5) PLL disable

The PLL disabled status is set by the PLL reference mode register (PLLRF). The VCOH and VCOL pins are set in the status specified by bits 2 (VCOLDMD) and 3 (VCOHDMD) of PLLMD. The EO0 and EO1 pins go into a high-impedance state. At this time, all the internal PLL operations are stopped.

These division modes are selected by using the PLL mode select register (PLLMD).

The division value (N value) is set to the programmable divider by using the PLL data register. Frequency division in each of the above modes is carried out according to the value (N value) set to the programmable divider.

Table 13-1 shows the division modes, input pins used (VCOL pin or VCOH pin), and the value that can be set to the programmable divider.

| Division Mode        | Pin Used | Value That Can Be Set      |  |
|----------------------|----------|----------------------------|--|
| Direct division (MF) | VCOL     | 32 to 2 <sup>12</sup> –1   |  |
| Pulse swallow (HF)   | VCOL     | 1024 to 2 <sup>17</sup> –1 |  |
| Pulse swallow (VHF)  | VCOH     | 1024 to 2 <sup>17</sup> –1 |  |

# Table 13-1. Division Mode, Input Pin, and Division Value

Caution For the frequencies that can be actually input, and input amplitude, refer to CHAPTER 19 ELECTRICAL SPECIFICATIONS.

# 13.2 Configuration of PLL Frequency Synthesizer

The PLL frequency synthesizer consists of the following hardware.

Table 13-2. Configuration of PLL Frequency Synthesizer

| Item              | Configuration                                                                                                                                          |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data registers    | PLL data register L (PLLRL)<br>PLL data register H (PLLRH)<br>PLL data register 0 (PLLR0)                                                              |
| Control registers | PLL mode select register (PLLMD)<br>PLL reference mode register (PLLRF)<br>PLL unlock F/F judge register (PLLUL)<br>PLL data transfer register (PLLNS) |





**Note** External circuit

#### (1) PLL data register L (PLLRL), PLL data register H (PLLRH), and PLL data register 0 (PLLR0)

These registers set the division value of the PLL frequency synthesizer. The division value of the PLL frequency synthesizer is made up of 17 bits. The higher 16 bits of this value are set by PLL data register L (PLLRL) and PLL data register H (PLLRH). The higher 16 bits can also be set by the PLL data register (PLLR). The least significant bit is set by bit 7 (PLLSCN) of PLL data register 0 (PLLR0).

Reset input makes the contents of these registers undefined. These registers hold the current values in the STOP and HALT modes.

#### (2) Input select block

The input select block consists of the VCOL and VCOH pins, and input amplifiers of the respective pins.

#### (3) Programmable divider

The programmable divider consists of two modulus prescalers, a programmable counter (12 bits), a swallow counter (5 bits), and a division mode select switch.

#### (4) Reference frequency generator

The reference frequency generator consists of a divider that generates the reference frequency  $f_r$  of the PLL frequency synthesizer, and a multiplexer.

#### (5) Phase comparator

The phase comparator ( $\phi$ -DET) compares the phase of the divided frequency output f<sub>N</sub> of the programmable divider with that of the reference frequency output f<sub>r</sub> of the reference frequency generator, and outputs an up request signal ( $\overline{\text{UP}}$ ) and down request signal ( $\overline{\text{DW}}$ ).

#### (6) Unlock F/F

The unlock F/F detects the unlock status of the PLL frequency synthesizer from the up request signal ( $\overline{UP}$ ) and down request signal ( $\overline{DW}$ ) of the phase comparator ( $\phi$ -DET).

#### (7) Charge pump

The charge pump outputs the result of the output of the phase comparator from the error out pins (EO0 and EO1 pins).

# 13.3 Registers Controlling PLL Frequency Synthesizer

The PLL frequency synthesizer is controlled by the following four registers.

- PLL mode select register (PLLMD)
- PLL reference mode register (PLLRF)
- PLL unlock F/F judge register (PLLUL)
- PLL data transfer register (PLLNS)

### (1) PLL mode select register (PLLMD)

This register selects the input pin and division mode of the PLL frequency synthesizer.

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

Reset input clears this register to 00H.

In the STOP mode, only bits 3 and 2 (VCOHDMD and VCOLDMD) retain the previous value. Bits 1 and 0 (PLLMD1 and PLLMD0) are reset to 0.

In the HALT mode, it holds the value immediately before the HALT mode was set.

#### Figure 13-2. Format of PLL Mode Select Register (PLLMD)

| Symbol | 7 | 6 | 5 | 4 | <3>     | <2>     | <1>    | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|---------|---------|--------|--------|---------|-------------|-----|
| PLLMD  | 0 | 0 | 0 | 0 | VCOHDMD | VCOLDMD | PLLMD1 | PLLMD0 | FFA0H   | 00H         | R/W |

| VCOH<br>DMD | Selection of disable status of VCOH pin |  |  |  |  |  |  |
|-------------|-----------------------------------------|--|--|--|--|--|--|
| 0           | Connected to pull-down resistor.        |  |  |  |  |  |  |
| 1           | High-impedance state                    |  |  |  |  |  |  |

| VCOL<br>DMD | Selection of disable status of VCOL pin |
|-------------|-----------------------------------------|
| 0           | Connected to pull-down resistor.        |
| 1           | High-impedance state                    |

| PLLMD1 | PLLMD0 | Selection of division mode of PLL frequency synthesizer and VCO input pin |  |  |  |  |  |  |
|--------|--------|---------------------------------------------------------------------------|--|--|--|--|--|--|
| 0      | 0      | Disables VCOL and VCOH pins <sup>Note</sup>                               |  |  |  |  |  |  |
| 0      | 1      | Direct division (VCOL pin and MF mode)                                    |  |  |  |  |  |  |
| 1      | 0      | Pulse swallow (VCOH pin and VHF mode)                                     |  |  |  |  |  |  |
| 1      | 1      | Pulse swallow (VCOL pin and HF mode)                                      |  |  |  |  |  |  |

**Note** This does not mean that the PLL is disabled. The VCOH and VCOL pins become the status specified by bit 3 (VCOHDMD) and bit 2 (VCOLDMD). The EO0 and EO1 pins go low.

**Remark** Bits 4 to 7 are fixed to 0 by hardware.

#### (2) PLL reference mode register (PLLRF)

This register selects the reference frequency  $f_r$  of the PLL frequency synthesizer and sets the disabled status of the PLL frequency synthesizer.

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

The value of this register is set to 0FH after reset and in the STOP mode.

In the HALT mode, it holds the value immediately before the HALT mode was set.

# Figure 13-3. Format of PLL Reference Mode Register (PLLRF)

| Symbol | 7 | 6 | 5 | 4 | <3>    | <2>    | <1>    | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|--------|--------|--------|--------|---------|-------------|-----|
| PLLRF  | 0 | 0 | 0 | 0 | PLLRF3 | PLLRF2 | PLLRF1 | PLLRF0 | FFA1H   | 0FH         | R/W |

| PLLRF3 | PLLRF2 | PLLRF1 | PLLRF0 | Setting of reference frequency fr of PLL frequency synthesizer |
|--------|--------|--------|--------|----------------------------------------------------------------|
| 0      | 0      | 0      | 0      | 50 kHz                                                         |
| 0      | 0      | 0      | 1      | 25 kHz                                                         |
| 0      | 0      | 1      | 0      | 12.5 kHz                                                       |
| 0      | 0      | 1      | 1      | 9 kHz                                                          |
| 0      | 1      | 0      | 0      | 1 kHz                                                          |
| 0      | 1      | 0      | 1      | 3 kHz                                                          |
| 0      | 1      | 1      | 0      | 10 kHz                                                         |
| 0      | 1      | 1      | 1      | Setting prohibited                                             |
| 1      | ×      | ×      | ×      | PLL disable <sup>Note</sup>                                    |

Note When PLL disable is selected, the status of the VCOL, VCOH, EO0, and EO1 pins are as follows:

VCOH, VCOL pins: Status specified by bit 3 (VCOHDMD) and bit 2 (VCOLDMD) of the PLL mode select register (PLLMD).

EO0, EO1 pins: High-impedance state

**Remark** Bits 4 to 7 are fixed to 0 by hardware.

×: Don't care

# (3) PLL unlock F/F judge register (PLLUL)

This register detects whether the PLL frequency synthesizer is in the unlock status. Because this register is an R&RESET register, it is reset to 0 after it has been read. Reset input sets this register to  $0 \times H^{Note 1}$ .

In the STOP and HALT modes, this register holds the value immediately before the STOP or HALT mode was set.

## Figure 13-4. Format of PLL Unlock F/F Judge Register (PLLUL)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | <0>    | Address | After reset           | R/W          |
|--------|---|---|---|---|---|---|---|--------|---------|-----------------------|--------------|
| PLLUL  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PLLUL0 | FFA2H   | 0×H <sup>Note 1</sup> | $R^{Note 2}$ |

| PLLUL0 | Detection of status of unlock F/F |  |  |  |  |  |
|--------|-----------------------------------|--|--|--|--|--|
| 0      | Unlock F/F = 0: PLL lock status   |  |  |  |  |  |
| 1      | Unlock F/F = 1: PLL unlock status |  |  |  |  |  |

- **Notes 1.** The value of bit 0 (PLLUL0) at reset differs depending on the type of reset that has been executed (refer to the table below).
  - 2. Bit 0 (PLLUL0) is R&Reset.

|             |                | 7 |   | 6 |   | 5 | 5 | 4 | 4 | :        | 3 | 2 | 2 | 1 |           | 0        |
|-------------|----------------|---|---|---|---|---|---|---|---|----------|---|---|---|---|-----------|----------|
| After reset | Power-on clear | 0 | 0 |   | ( | ) | 0 |   | 0 |          | 0 |   | 0 |   | Undefined |          |
|             | Watchdog timer |   |   |   |   |   |   |   |   |          |   |   |   |   |           | Retained |
|             | RESET input    |   |   |   |   |   |   |   |   |          |   |   |   |   |           | Retained |
| STOP mode   |                |   |   |   |   |   |   |   |   |          |   |   |   |   |           | Retained |
| HALT m      | •              |   | v |   | , | 1 | , | v |   | <b>v</b> |   |   | , |   | Retained  |          |

**Remark** Bits 1 to 7 are fixed to 0 by hardware.

#### (4) PLL data transfer register (PLLNS)

This register transfers the values of the PLL data registers (PLLRL, PLLRH, and PLLR0) to the programmable counter and swallow counter.

The value of this register is 00H after reset and in the STOP mode.

In the HALT mode, this register holds the previous value immediately before the HALT mode is set.

### Figure 13-5. Format of PLL Data Transfer Register (PLLNS)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|---|---|---|--------|---------|-------------|-----|
| PLLNS  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PLLNS0 | FFA3H   | 00H         | W   |

| PLLNS0 | Transfers value of PLL data register to programmable counter and swallow counter |  |  |  |  |  |  |  |
|--------|----------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0      | Does not transfer                                                                |  |  |  |  |  |  |  |
| 1      | Transfers                                                                        |  |  |  |  |  |  |  |

Remark Bits 1 to 7 are fixed to 0 by hardware.

## 13.4 Operation of PLL Frequency Synthesizer

#### 13.4.1 Operation of each block of PLL frequency synthesizer

#### (1) Operation of input select block and programmable divider

The input select block and programmable divider select the input pin and division mode of the PLL frequency synthesizer and divide the frequency in the selected division mode, according to the setting of the PLL mode select register (PLLMD).

The programmable counter (12 bits) and pulse swallow counter (5 bits) are binary counters.

The division value (N value) is set to the programmable counter (12 bits) and swallow counter (5 bits) by the PLL data registers (PLLRL, PLLRH, and PLLR0).

When the N value has been transferred to the programmable counter and swallow counter, frequency division is performed in the selected division mode according to the status of bit 0 (PLLNS0) of the PLL data transfer register.

Figure 13-6 shows the configuration of the input select block and programmable divider.





# (2) Operation of reference frequency generator

The reference frequency generator divides the 4.5 MHz output of the crystal oscillator and generates seven types of reference frequency fr for the PLL frequency synthesizer. Reference frequency fr is selected by the PLL reference mode register (PLLRF). Figure 13-7 shows the configuration of the reference frequency generator.



### Figure 13-7. Configuration of Reference Frequency Generator

### (3) Operation of phase comparator ( $\phi$ -DET)

Figure 13-8 shows the configuration of the phase comparator ( $\phi$ -DET), charge pump, and unlock F/F. The phase comparator ( $\phi$ -DET) compares the phase of the divided frequency  $f_N$  of the programmable divider with that of the reference frequency  $f_r$  of the reference frequency generator, and outputs an up request signal,  $\overline{UP}$ , or a down request signal,  $\overline{DW}$ .

If the divided frequency  $f_N$  is lower than the reference frequency  $f_r$ , the up request signal is output. If  $f_N$  is higher than  $f_r$ , the down request signal is output.

Figure 13-9 shows the relation among reference frequency  $f_r$ , divided frequency  $f_N$ , up request signal  $\overline{UP}$ , and down request signal  $\overline{DW}$ .

When the PLL is disabled, neither the up nor the down request signal is output.

The up and down request signals are input to the charge pump and unlock F/F.





# Figure 13-9. Relationship Between $f_r$ , $f_N$ , $\overline{UP}$ , and $\overline{DW}$



# (4) Operation of charge pump

The charge pump outputs the result of the up request  $(\overline{UP})$  or down request  $(\overline{DW})$  signal from the phase comparator ( $\phi$ -DET) from the error out pins (EO0 and EO1 pins). Table 13-3 shows the output signals. The EO0 and EO1 pins are of voltage-driven type pins.

Figure 13-10 shows the configuration of the error out pins.

 Table 13-3.
 Error Out Output Signal

| Relationship Between Divided Frequency<br>f <sub>N</sub> and Reference Frequency f <sub>r</sub> | Error Out Output Signal   |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|--|
| When $f_r > f_N$                                                                                | Low level                 |  |  |  |  |  |
| When $f_r < f_N$                                                                                | High level                |  |  |  |  |  |
| When $f_r = f_N$                                                                                | Floating (high impedance) |  |  |  |  |  |

Figure 13-10. Configuration of Error Out Output



#### (5) Operation of unlock F/F

The unlock F/F detects the unlock status of the PLL frequency synthesizer.

The unlock status of the PLL frequency synthesizer is detected from the up request signal  $\overline{UP}$  and down request signal  $\overline{DW}$  of the phase comparator ( $\phi$ -DET).

Because either of the up request or down request signal outputs a low level in the unlock status, the unlock status can be detected by using this low-level signal.

The status of the unlock F/F is detected by bit 0 (PLLUL0) of the PLL unlock F/F judge register (PLLUL). The unlock F/F is set at the cycle of reference frequency  $f_f$  selected at that time.

The PLL unlock F/F judge register is reset when its contents have been read.

To read the PLLUL, therefore, it must be read at a cycle longer than the cycle (1/fr) of the reference frequency.

### 13.4.2 Operation to set N value of PLL frequency synthesizer

The division value (N value) is set to the programmable counter (12 bits) and swallow counter (5 bits) by the PLL data registers (PLLRL, PLLRH, and PLLR0).

When the N value has been transferred to the programmable counter and swallow counter by bit 0 (PLLNS0) of the PLL data transfer register (PLLNS), frequency division is carried out in the selected division mode.

Examples of setting the N value in the respective division modes (MF, HF, and VHF) are shown below.

## (1) Direct division mode (MF)

(a) Calculating division value N (value set to PLL data register)

 $N = \frac{f_{VCOL}}{f_r}$ where, f\_{VCOL}: Input frequency of V\_{COL} pin f\_r: Reference frequency

### (b) Example of setting PLL data register

An example of setting the PLL data register to receive broadcasting stations in the following MW band is shown below.

Receive frequency:1422 kHz (MW band)Reference frequency:9 kHzIntermediate frequency:450 kHz

Division value N is calculated as follows:

 $N = \frac{f_{VCOL}}{f_r} = \frac{1422 + 450}{9} = 208 \text{ (decimal)}$ = 0D0H (hexadecimal)

Data is set to the PLL data registers (PLLR and PLLR0) as follows.

|     | PLLR                |     |     |     |      |       |    |       |     |    |    |       |     | PLLR0    |    |    |     |       |     |    |    |    |    |
|-----|---------------------|-----|-----|-----|------|-------|----|-------|-----|----|----|-------|-----|----------|----|----|-----|-------|-----|----|----|----|----|
|     | PLLRH               |     |     |     |      |       |    | PLLRL |     |    |    |       | -   | - PLLSCN |    |    |     |       |     |    |    |    |    |
| b7  | b6                  | b5  | b4  | b3  | b2   | b1    | b0 | b7    | b6  | b5 | b4 | b3    | b2  | b1       | b0 | b7 | b6  | b5    | b4  | b3 | b2 | b1 | b0 |
| b16 | b15                 | b14 | b13 | b12 | b11  | b10   | b9 | b8    | b7  | b6 | b5 | b4    | b3  | b2       | b1 | b0 |     |       |     |    |    |    |    |
| 4   | Programmable counte |     |     |     | inte | r val | ue |       |     | -  | Do | n't c | are |          | 4  |    | Fix | ced t | o 0 |    |    |    |    |
| 0   | 0                   | 0   | 0   | 1   | 1    | 0     | 1  | 0     | 0   | 0  | 0  |       |     |          |    |    |     |       |     |    |    |    |    |
| L   | . (                 | )   |     |     | . [  | <br>C |    |       | . ( | D  |    | 1     |     |          |    |    |     |       |     |    |    |    |    |

After setting the above PLL data registers (PLLR and PLLR0), data must be transferred to the programmable counter by setting bit 0 (PLLNS0) of the PLL data transfer register (PLLNS).

### (2) Pulse swallow mode (HF)

## (a) Calculating division value N (value set to PLL data register)

 $N = \frac{f_{VCOL}}{f_r}$ 

where,

fvcoL: Input frequency of VcoL pin

fr: Reference frequency

# (b) Example of setting PLL data register

An example of setting the PLL data register to receive broadcasting stations in the following SW band is shown below.

Receive frequency:25.50 MHz (SW band)Reference frequency:10 kHz

Intermediate frequency: 450 kHz

Division value N is calculated as follows:

 $N = \frac{f_{VCOL}}{f_r} = \frac{25500 + 450}{10} = 2595 \text{ (decimal)}$ = 0A23H (hexadecimal)

Because the least significant bit of the division value N must be set to bit 7 (PLLSCN) of PLL data register 0 (PLLR0), data must be set by shifting the result of the above calculation 1 bit to the right. Data is set to the PLL data registers (PLLR and PLLR0) as follows.



After setting the above PLL data registers (PLLR and PLLR0), data must be transferred to the programmable counter and swallow counter by setting bit 0 (PLLNS0) of the PLL data transfer register (PLLNS).

In this example, a value of half the N value is set to the high-order 16 bits of the PLL data register (PLLR) by shifting the N value resulting from calculation 1 bit to the right.

If the N value is calculated as follows with the least significant bit of the N value in PLLSCN fixed to 0, the result of the calculation (NPLLR) can be set to the PLL data register (PLLR) as is.

If the calculation result is set in this way, however, the input frequency ( $f_{VCOL}$ ) is  $2 \times f_r$  (reference frequency) of the set value NPLLR.

$$N_{PLLR} = \frac{f_{VCOL}}{2f_r}$$

#### (3) Pulse swallow mode (VHF)

(a) Calculating division value N (value set to PLL data register)

 $N = \frac{f_{VCOH}}{f_r}$ 

where, fvcoH: Input frequency of VCOH pin fr: Reference frequency

## (b) Example of setting PLL data register

An example of setting the PLL data register to receive broadcasting stations in the following FM band is shown below.

Receive frequency:100.0 MHz (FM band)Reference frequency:50 kHzIntermediate frequency:+10.7 MHz

Division value N is calculated as follows:

$$N = \frac{f_{VCOH}}{f_r} = \frac{100.0 + 10.7}{0.05} = 2214 \text{ (decimal)}$$
$$= 08A6H \text{ (hexadecimal)}$$

Because the least significant bit of the division value N must be set to the PLL data register 0 (PLLR0), data must be set by shifting the value calculated by the above expression 1 bit to the right. Data is set to the PLL data registers (PLLR and PLLR0) as follows.



After setting the above PLL data registers (PLLR and PLLR0), data must be transferred to the programmable counter and swallow counter by setting bit 0 (PLLNS0) of the PLL data transfer register (PLLNS).

In this example, a value of half the N value is set to the higher 16 bits of the PLL data register (PLLR) by shifting the N value resulting from calculation 1 bit to the right.

If the N value is calculated as follows with the least significant bit of the N value in PLLSCN fixed to 0, the result of the calculation (NPLLR) can be set to the PLL data register (PLLR) as is.

If the calculation result is set in this way, however, the input frequency ( $f_{VCOH}$ ) is  $2 \times f_r$  (reference frequency) of the set value NPLLR.

$$N_{PLLR} = \frac{f_{VCOH}}{2f_r}$$

# 13.5 PLL Disable Status

The PLL frequency synthesizer can be stopped (PLL disabled status) by performing any of the following settings while the PLL frequency synthesizer is operating.

- Setting value of bit 3 (PLLRF3) of the PLL reference mode register (PLLRF) to 1 to set PLL disabled status
- Setting STOP mode with the STOP instruction
- · Setting reset status with the reset function

The following table shows the operation of each block and the status of each register in the PLL disabled status.

| Table 13-4. | Operation of Each Blo | ock and Register Status in PLL Disabled Status |
|-------------|-----------------------|------------------------------------------------|
|             |                       |                                                |

| Block/Register                | Status in PLL Disabled Status                              |
|-------------------------------|------------------------------------------------------------|
| VCOL and VCOH pins            | Status set in bit 3 (VCOHDMD) and bit 2 (VCOLDMD) of PLLMD |
| Programmable divider          | Division stops                                             |
| Reference frequency generator | Output stops                                               |
| Phase comparator              | Output stops                                               |
| EO0 and EO1 pin               | High impedance                                             |
| PLL mode select register      | Retains value on execution of write instruction            |
| PLL data register             |                                                            |
| PLL unlock F/F judge register |                                                            |

# 13.6 Notes on PLL Frequency Synthesizer

## • Notes on using PLL frequency synthesizer

Because the input pins (VCOL and VCOH pins) of the PLL frequency synthesizer are provided with an AC amplifier, cut the DC component of the input signal by connecting a capacitor to the input pins in series. The potential of the selected input pin is intermediate (about 1/2Vpb). The input pin not selected becomes the status set in bit 3 (VCOHDMD) and bit 2 (VCOLDMD) of the PLL mode select register (PLLMD). For the frequencies that can be actually input and input amplitude, refer to CHAPTER 19 ELECTRICAL SPECIFICATIONS.

# CHAPTER 14 FREQUENCY COUNTER

# 14.1 Function of Frequency Counter

The frequency counter counts the intermediate frequency (IF) of a tuner.

The intermediate frequency input to the FMIFC or AMIFC pin is counted for a specific time (1 ms, 4 ms, 8 ms, or open) by a 16-bit counter. The count value of the frequency counter is stored in the IF counter register.

For the range of the frequency that can be input to the FMIFC and AMIFC pins, refer to **CHAPTER 19 ELECTRICAL SPECIFICATIONS**.

# 14.2 Configuration of Frequency Counter

The frequency counter consists of the following hardware.

# Table 14-1. Configuration of Frequency Counter

| Item              | Configuration                                                                                                           |
|-------------------|-------------------------------------------------------------------------------------------------------------------------|
| Counter register  | IF counter register (IFCR)                                                                                              |
| Control registers | IF counter mode select register (IFCMD)<br>IF counter control register (IFCR)<br>IF counter gate judge register (IFCJG) |





#### (1) IF counter input select block

The IF counter input select block selects the pin to be used from the FMIFC and AMIFC pins, and a count mode.

### (2) Gate time control block

The gate time control block sets a gate time (count time).

#### (3) Start/stop control block

The start/stop control block starts counting by the IF counter register and detects the end of counting.

#### (4) IF counter register block

The IF counter register block is a 16-bit register that counts up the frequency input in the set gate time. The count value is stored to the IF counter register (IFCR). When the count value reaches FFFFH, the IF counter register holds FFFFH at the next input, and stops counting. The value of this register is reset to 0000H after reset or in the STOP mode. In the HALT mode, it holds the current count value.

# 14.3 Registers Controlling Frequency Counter

The frequency counter is controlled by the following three registers.

- IF counter mode select register (IFCMD)
- IF counter control register (IFCCR)
- IF counter gate judge register (IFCJG)

## (1) IF counter mode select register (IFCMD)

This register selects the input pin of the frequency counter, and selects a mode and gate time (count time). This register is set with a 1-bit or 8-bit memory manipulation instruction.

The value of this register is reset to 00H after reset or in the STOP mode.

In the HALT mode, this register holds the value immediately before the HALT mode is set.

# Figure 14-2. Format of IF Counter Mode Select Register (IFCMD)

| Symbol | 7 | 6 | 5 | 4 | <3>    | <2>    | <1>    | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|--------|--------|--------|--------|---------|-------------|-----|
| IFCMD  | 0 | 0 | 0 | 0 | IFCMD1 | IFCMD0 | IFCCK1 | IFCCK0 | FFA9H   | 00H         | R/W |

| IFCMD1 | IFCMD0 | Selection of frequency counter pin and mode |
|--------|--------|---------------------------------------------|
| 0      | 0      | Disables FMIFC, AMIFC pins <sup>Note</sup>  |
| 0      | 1      | AMIFC pin, AMIF count mode                  |
| 1      | 0      | FMIFC pin, FMIF count mode                  |
| 1      | 1      | FMIFC pin, AMIF count mode                  |

| IFCCK1 | IFCCK0 | Selection of gate time |
|--------|--------|------------------------|
| 0      | 0      | 1 ms                   |
| 0      | 1      | 4 ms                   |
| 1      | 0      | 8 ms                   |
| 1      | 1      | Open                   |

Note The FMIFC and AMFIC pins are in a high-impedance state.

**Remark** Bits 4 to 7 are fixed to 0 by hardware.

### (2) IF counter control register (IFCCR)

This register starts counting by the IF counter register and clears the IF counter register. IFCCR is set with a 1-bit or 8-bit memory manipulation instruction.

The value of this register is reset to 00H after reset and in the STOP mode.

In the HALT mode, this register holds the value immediately before the HALT mode is set.

### Figure 14-3. Format of IF Counter Control Register (IFCCR)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | <1>   | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|---|---|-------|--------|---------|-------------|-----|
| IFCCR  | 0 | 0 | 0 | 0 | 0 | 0 | IFCST | IFCRES | FFACH   | 00H         | W   |

| IFCST  | Setting of IF counter register start         |
|--------|----------------------------------------------|
| 0      | Nothing is affected                          |
| 1      | Starts counting                              |
|        |                                              |
| IFCRES | Setting of data clear of IF counter register |
| 0      | Nothing is affected                          |
| 1      | Clears data of IF counter register           |

**Remark** Bits 2 to 7 are fixed to 0 by hardware.

### (3) IF counter gate judge register (IFCJG)

This register detects opening/closing of the gate of the frequency counter. The value of this register is reset to 00H after reset and in the STOP mode. In the HALT mode, this register holds the value immediately before the HALT mode is set.

### Figure 14-4. Format of IF Counter Gate Judge Register (IFCJG)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | <0>    | Address | After reset | R/W |
|--------|---|---|---|---|---|---|---|--------|---------|-------------|-----|
| IFCJG  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | IFCJG0 | FFABH   | 00H         | R   |

| IFCJG0 | Detection of opening/closing of frequency counter gate                                                                                                                                                                              |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Gate is closed                                                                                                                                                                                                                      |
| 1      | <ul> <li>If gate time is set to other than open<br/>Status until gate is closed after IFCST has been set to 1</li> <li>If gate time is set to open<br/>Status where gate is open as soon as it has been set to be opened</li> </ul> |

**Remark** Bits 1 to 7 are fixed to 0 by hardware.

Caution IFCJG0 remains set even if the IF counter register overflows and stops counting, until the set gate time expires.

#### 14.4 Operation of Frequency Counter

- <1> Select an input pin, mode, and gate time using the IF counter mode select register (IFCMD). Figure 14-5 shows a block diagram of input pin and mode selection.
- <2> Set bit 0 (IFCRES) of the IF counter control register (IFCCR) to 1, and clear the data of the IF counter register.
- <3> Set bit 1 (IFCST) of the IF counter control register (IFCCR) to 1.
- <4> The gate is opened only for the set gate time since a 1 kHz internal signal has risen after IFCST was set. If the gate time is set to be opened, the gate is opened as soon as it has been specified to be opened. Bit 0 (IFCJG0) of the IF counter gate judge register (IFCJG) is automatically set to 1 as soon as IFCST has been set to 1. When the gate time has elapsed, bit 0 (IFCJG0) of the IF counter gate judge register (IFCJG) is automatically

cleared to 0. If it is specified that the gate be open, however, IFCJG0 is not automatically cleared. In this case, set a gate time. Figure 14-6 shows the gate timing of the frequency counter.

<5> While the gate opens the frequency input to the selected FMIFC or AMIFC pin, the IF counter register counts the frequency.

If the FMIFC pin is used in the FMIF count mode, however, the input frequency is divided by half before it is counted.

The relationship between the count value x (decimal), the input frequencies (ffmifc and famifc), and the gate time (TGATE) is shown below.

• FMIF count mode (FMIFC pin)

$$f_{\text{FMIFC}} = \frac{x}{T_{\text{GATE}}} \times 2 \text{ (kHz)}$$

AMIF count mode (FMIFC or AMIFC pin)

$$f_{AMIFC} = \frac{x}{T_{GATE}} \quad (kHz)$$





#### Figure 14-6. Gate Timing of Frequency Counter





Caution If counting is started by using IFCST while this gate is open, the gate is closed after an undefined time. To open the gate, therefore, do not set IFCST to 1.

 Remark
 IFCST:
 Bit 1 of IF counter control register (IFCCR)

 IFCJG0:
 Bit 0 of IF counter gate judge register (IFCJG)

 IFCCK1, 0:
 Bits 1 and 0 of IF counter mode select register (IFCMD)

#### 14.5 Notes on Frequency Counter

## (1) Notes on using frequency counter

Because signals are input to the frequency counter from an input pin (FMIFC or AMIFC pin) with an AC amplifier as shown in Figure 14-7, cut the DC component of the input signals by using capacitor C.

If the FMIFC or AMIFC pin is selected by the IF counter mode select register, switch SW1 turns ON, and switch SW2 turns OFF. As a result, the voltage on the pin is about 1/2Vpd.

Unless the voltage has risen to a sufficient intermediate level at this time, counting may not be performed normally because the AC amplifier is not in the normal operating range.

Therefore, make sure that sufficient wait time elapses after a pin has been selected and before counting is started (IFCST = 1).





### (2) Notes in HALT mode

The FMIFC and AMIFC pins hold the status immediately before the HALT status was set.

To release the HALT mode by using the interrupt of the frequency counter at this time, the following point must be noted.

The gate will not be opened if the HALT instruction is executed after counting has been started by IFCST before the gate is actually opened.

Therefore, wait for at least 1 ms before executing the HALT instruction.



#### Figure 14-8. Gate Status When HALT Instruction Is Executed

## (3) Error of frequency counter

The error of the frequency counter includes an error of gate time and a count error.

## (1) Error of gate time

The gate time of the frequency counter is created by dividing 4.5 MHz. Therefore, if 4.5 MHz is shifted "+x" ppm, the gate time is also shifted "-x" ppm.

# (2) Count error

The frequency counter counts the frequency at the rising edge of the input signal. If a high level is input to the pin when the gate is opened, therefore, one excess pulse is counted. When the gate is closed, however, counting is not affected by the status of the pin. Therefore, the count error is "maximum + 1".

# CHAPTER 15 STANDBY FUNCTION

# 15.1 Standby Function and Configuration

### 15.1.1 Standby function

The standby function is designed to decrease power consumption of the system. The following two modes are available.

# (1) HALT mode

HALT instruction execution sets the HALT mode. The HALT mode is intended to stop the CPU operation clock. System clock oscillator continues oscillation. In this mode, current consumption cannot be decreased as in the STOP mode. The HALT mode is valid to restart immediately upon interrupt request and to carry out intermittent operations such as in watch applications.

Although the CPU stops operating, the peripheral functions can operate. To lower the current consumption, therefore, stop all unnecessary circuits before executing the HALT instruction.

## (2) STOP mode

STOP instruction execution sets the STOP mode. In the STOP mode, the system clock oscillator stops and the whole system stops. CPU current consumption can be considerably decreased.

Data memory low-voltage hold (down to  $V_{DD} = 2.2 \text{ V}$ ) is possible. Thus, the STOP mode is effective to hold data memory contents with ultra-low current consumption.

If the supply voltage drops below 2.2 V, the system is reset by means of power-on clear reset. For reset, refer to **CHAPTER 16 RESET FUNCTION**.

Because this mode can be cleared upon interrupt request, it enables intermittent operations to be carried out. However, because a wait time is necessary to secure an oscillation stabilization time after the STOP mode is cleared, select the HALT mode if it is necessary to start processing immediately upon interrupt request. All the functions stop operating.

Some registers of the PLL frequency synthesizer and frequency counter are reset, but the other functions are stopped with their current status retained.

- Cautions 1. When shifting to the STOP mode, be sure to stop the peripheral hardware operation before executing the STOP instruction.
  - 2. The following sequence is recommended for power consumption reduction of the A/D converter: first clear bit 7 (ADCS3) of ADM3 to 0 to stop the A/D conversion operation, then execute the HALT or STOP instruction.

#### 15.1.2 Register controlling standby function

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

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

Reset input sets OSTS to 04H.



# Figure 15-1. Format of Oscillation Stabilization Time Select Register (OSTS)

- **Remark** fx: System clock oscillation frequency (): fx = 4.5 MHz
- Caution The wait time when the STOP mode is released does not include the time required for the clock oscillation to start after the STOP mode has been released (see "a" in the figure below), regardless of whether the mode has been released by the RESET signal or an interrupt request.

STOP mode release X1 pin voltage ---waveform

# 15.2 Operations of Standby Function

# 15.2.1 HALT mode

# (1) HALT mode set and operating status

The HALT mode is set by executing the HALT instruction. The operating status in the HALT mode is described below.

# Table 15-1. HALT Mode Operating Status

| Item                                 | Status                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock generator                      | Can oscillate system clock. Stops clock supply to CPU.                                                                                                                                                                                                                                                                                                                                                                                                       |
| CPU                                  | Stops operating.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Port                                 | Holds status before HALT mode is set.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8-bit timer/event counter            | Holds operation before HALT mode is set and can operate.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Basic timer                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Watchdog timer                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Buzzer output controller             |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| A/D converter                        | <ul> <li>Retains operation performed when HALT mode is set.</li> <li>However, comparison cannot be performed correctly in A/D conversion operation mode.</li> <li>In power-fail comparison mode, operation is as follows depending on setting of bit 5 (PFHRM3) of power-fail comparison mode register 3 (PFM3):</li> <li>PFHRM3 = 0: Comparison cannot be performed normally.</li> <li>PFHRM3: Power-fail comparison operation can be performed.</li> </ul> |
| Serial interface<br>(SIO30 to SIO32) | Retains operation performed when HALT mode is set and can operate.                                                                                                                                                                                                                                                                                                                                                                                           |
| External interrupt                   | Hold operation before HALT mode is set and can operate.                                                                                                                                                                                                                                                                                                                                                                                                      |
| PLL frequency synthesizer            |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Frequency counter                    | Retains operation performed before HALT mode is set.<br>However, operation is not performed correctly though it is continued.                                                                                                                                                                                                                                                                                                                                |
| Power-on clear circuit               | Reset when voltage of less than 3.5 V is detected.                                                                                                                                                                                                                                                                                                                                                                                                           |

#### (2) HALT mode release

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

## (a) Release upon 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 disabled, the next address instruction is executed.





- **Remarks 1.** The broken lines indicate the case when the interrupt request that released the standby status is acknowledged.
  - 2. Wait time will be as follows:
    - When vectored interrupt servicing is carried out: 8 to 9 clocks
    - · When vectored interrupt servicing is not carried out: 2 to 3 clocks

#### (b) Release upon non-maskable interrupt request

When a non-maskable interrupt is generated, the HALT mode is released and vectored interrupt servicing is carried out whether interrupt acknowledgement is enabled or disabled.

# (c) Release by $\overline{\text{RESET}}$ input

If the RESET signal is input, the HALT mode is released. As is the case with normal reset operation, the program is executed after branch to the reset vector address.

Figure 15-3. HALT Mode Release by RESET Input



Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

| Table 15-2 | 2. Operati | ion After H | HALT Mod | e Release |  |
|------------|------------|-------------|----------|-----------|--|
|            |            |             |          |           |  |

| Release Source                 | MK×× | PR×× | IE | ISP | Operation                          |
|--------------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt             | 0    | 0    | 0  | ×   | Next address instruction execution |
| request                        | 0    | 0    | 1  | ×   | Interrupt servicing execution      |
|                                | 0    | 1    | 0  | 1   | Next address instruction execution |
|                                | 0    | 1    | ×  | 0   |                                    |
|                                | 0    | 1    | 1  | 1   | Interrupt servicing execution      |
|                                | 1    | ×    | ×  | ×   | HALT mode hold                     |
| Non-maskable interrupt request | _    | _    | ×  | ×   | Interrupt servicing execution      |
| RESET input                    | -    | -    | ×  | х   | Reset processing                   |

Remark ×: Don't care

#### 15.2.2 STOP mode

#### (1) STOP mode set and operating status

The STOP mode is set by executing the STOP instruction.

- Cautions 1. When the STOP mode is set, the X1 pin is pulled down to GND, and the X2 pin is internally pulled up to VDD to minimize the leakage current at the crystal oscillator block.
  - 2. Because the interrupt request signal is used to clear the standby mode, if there is an interrupt source with the interrupt request flag set and the interrupt mask flag reset, the standby mode is immediately released if set. Thus, the STOP mode is reset to the HALT mode immediately after execution of the STOP instruction. After the wait set using the oscillation stabilization time select register (OSTS), the operation mode is set.

The operating status in the STOP mode is described below.

| Item                                 | Status                                                 |  |  |  |  |
|--------------------------------------|--------------------------------------------------------|--|--|--|--|
| Clock generator                      | Can oscillate system clock. Stops clock supply to CPU. |  |  |  |  |
| CPU                                  | Stops operating.                                       |  |  |  |  |
| Port                                 | Holds status before HALT mode is set.                  |  |  |  |  |
| 8-bit timer/event counter            | Operation stops and cannot operate.                    |  |  |  |  |
| Basic timer                          |                                                        |  |  |  |  |
| Watchdog timer                       |                                                        |  |  |  |  |
| Buzzer output controller             |                                                        |  |  |  |  |
| A/D converter                        |                                                        |  |  |  |  |
| Serial interface<br>(SIO30 to SIO32) |                                                        |  |  |  |  |
| External interrupt                   | Can operate.                                           |  |  |  |  |
| PLL frequency synthesizer            | Operation stops and cannot operate.                    |  |  |  |  |
| Frequency counter                    |                                                        |  |  |  |  |
| Power-on clear circuit               | RESET generated when detecting 2.2 V or less.          |  |  |  |  |

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

#### (2) STOP mode release

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

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

When an unmasked interrupt request is generated, the STOP mode is released. If interrupt request acknowledgement is enabled after the lapse of oscillation stabilization time, vectored interrupt servicing is carried out. If interrupt request acknowledgement is disabled, the next address instruction is executed.





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

# (b) Release by RESET input

If the RESET signal is input, the STOP mode is released, and after the lapse of oscillation stabilization time, a reset operation is carried out.



Figure 15-5. Release by STOP Mode RESET Input

Remarks 1. fx: System clock oscillation frequency

**2.** ( ): fx = 4.5 MHz

### Table 15-4. Operation After STOP Mode Release

| Release Source             | MK×× | PR×× | IE | ISP | Operation                          |
|----------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt request | 0    | 0    | 0  | ×   | Next address instruction execution |
|                            | 0    | 0    | 1  | ×   | Interrupt servicing execution      |
|                            | 0    | 1    | 0  | 1   | Next address instruction execution |
|                            | 0    | 1    | ×  | 0   |                                    |
|                            | 0    | 1    | 1  | 1   | Interrupt servicing execution      |
|                            | 1    | ×    | ×  | ×   | STOP mode hold                     |
| RESET input                | _    | -    | ×  | ×   | Reset processing                   |

Remark ×: Don't care

# **CHAPTER 16 RESET FUNCTION**

# 16.1 Reset Function

The following three operations are available to generate the reset signal.

- (1) External reset input via a RESET pin
- (2) Internal reset by inadvertent program loop time detection watchdog timer
- (3) Internal reset by power-on clear (POC)

## (1) External reset input by RESET pin

When a low level is input to the RESET pin, the device is reset, and each hardware unit enters the status shown in Table 16-1. While the reset signal is input and during the oscillation stabilization time immediately after the RESET signal has been deasserted, each pin goes into a high-impedance state (however, the P130 to P132 pins become low level, and the VCOH and VCOL pins are pulled down).

The  $\overline{\text{RESET}}$  signal is deasserted when a high level is input to the  $\overline{\text{RESET}}$  pin, and the program execution is started after the oscillation stabilization time (2<sup>17</sup>/fx) has elapsed.

### (2) Internal reset by inadvertent program loop time detection of watchdog timer

Reset is effected and each hardware unit enters the status shown in Table 16-1 when the watchdog timer overflow. While reset is in effect and during the oscillation stabilization time immediately after the effect of reset has been cleared, each pin goes into a high-impedance state (however, the P130 to P132 pins become low level, and the VCOH and VCOL pins are pulled down).

Reset by the watchdog timer is cleared immediately after reset has been effected, and the program execution is started after the oscillation stabilization time  $(2^{17}/fx)$  has elapsed.

### (3) Internal reset by power-on clear (POC)

Reset is effected by means of power-on clear under the following conditions:

- If supply voltage is less than 3.5 V<sup>Note</sup> on power application
- If supply voltage drops to less than 2.2 V<sup>Note</sup> in STOP mode
- If supply voltage drops to less than 3.5 V<sup>Note</sup> (including HALT mode)

When these reset conditions of power-on clear are satisfied, reset is effected, and each hardware unit enters the status shown in Table 16-1. While the reset signal is input and during the oscillation stabilization time immediately after the reset signal has been deasserted, each pin goes into a high-impedance state (the P130 to P132 pins become low level, however).

Reset by power-on clear is cleared if the supply voltage rises beyond a specific level, and the program execution is started after the oscillation stabilization time  $(2^{17}/f_x)$  has elapsed.

Note These voltage values are maximum values. Actually, reset is effected at a voltage lower than these.

- Cautions 1. For an external reset, input a low level for 10  $\mu$ s or more to the **RESET** pin.
  - 2. During reset input, system clock oscillation remains stopped.
  - 3. When the STOP mode is released by RESET input, the STOP mode register contents are held during reset input. However, the I/O port pin becomes high-impedance. Output dedicated port pin (P130 to P132) becomes low level regardless of the previous status.





# Figure 16-2. Timing of Reset by RESET Input

# (a) In normal operation mode



(b) In STOP mode





## Figure 16-3. Timing of Reset due to Watchdog Timer Overflow

#### Figure 16-4. Timing of Reset by Power-on Clear

# (a) At power application



(c) In normal operating mode (including HALT mode)



|                                        | Hardware                                                | Status After Reset                                           |
|----------------------------------------|---------------------------------------------------------|--------------------------------------------------------------|
| Program counter (PC) <sup>Note ·</sup> | 1                                                       | Contents of reset<br>vector table (0000H,<br>0001H) are set. |
| Stack pointer (SP)                     | Undefined                                               |                                                              |
| Program status word (PSW               | Undefined                                               |                                                              |
| RAM                                    | Data memory                                             | Undefined <sup>Note 2</sup>                                  |
|                                        | General-purpose register                                | Undefined <sup>Note 2</sup>                                  |
| Port (output latch)                    | Ports 0, 1, 3 to 7, 12, 13 (P0, P1, P3 to P7, P12, P13) | 00H                                                          |
| Port mode registers (PM0,              | FFH                                                     |                                                              |
| Pull-up resistor option regis          | ster 4 (PU4)                                            | 00H                                                          |
| Processor clock control reg            | 04H                                                     |                                                              |
| Oscillation stabilization time         | 04H                                                     |                                                              |
| DTS system clock select re             | 00HNote 3                                               |                                                              |
| Memory size switching reg              | CFH <sup>Note 4</sup>                                   |                                                              |
| Internal expansion RAM size            | 0CHNote 5                                               |                                                              |
| 8-bit timer/event counter              | Counters 50 to 53 (TM50 to TM53)                        | 00H                                                          |
|                                        | Compare registers 50 to 53 (CR50 to CR53)               | Undefined                                                    |
|                                        | Clock select registers 50 to 53 (TCL50 to TCL53)        | 00H                                                          |
|                                        | Mode control registers 50 to 53 (TMC50 to TMC53)        | 00H                                                          |
| Watchdog timer                         | Clock select register (WDCS)                            | 00H                                                          |
|                                        | Mode register (WDTM)                                    | 00H                                                          |
| Buzzer output controller               | BEEP clock select register 0 (BEEPCL0)                  | 00H                                                          |
|                                        | Clock output select register (CKS)                      | 00H                                                          |
| Serial interface                       | Shift registers 30 to 32 (SIO30 to SIO32)               | Undefined                                                    |
|                                        | Operating mode registers 30 to 32 (CSIM30 to CSIM32)    | 00H                                                          |
|                                        | Port select register 32 (SIO32SEL)                      | 00H                                                          |

### Table 16-1. Hardware Status After Reset (1/2)

**Notes 1.** During reset input or oscillation stabilization time wait, only the PC contents among the hardware statuses become undefined. All other hardware statuses remain unchanged after reset.

- 2. The status before reset is retained even after reset in the standby mode.
- **3.** Though the initial value is 00H, be sure to set it to 01H before use.
- 4. The initial value is CFH. Set the following value to this register depending on the model:  $\mu$ PD178053: C6H

μPD178054: C8H

 $\mu$ PD178F054: Value corresponding to mask ROM versions

5. Do not assign a value other than 0CH.

|                           | Hardware                                                | Status After Reset         |
|---------------------------|---------------------------------------------------------|----------------------------|
| A/D converter             | Mode register 3 (ADM3)                                  | 00H                        |
|                           | A/D conversion result register 3 (ADCR3)                | Undefined                  |
|                           | Analog input channel specification register 3 (ADS3)    | 00H                        |
|                           | Power-fail comparison mode register 3 (PFM3)            | 00H                        |
|                           | Power-fail comparison threshold value register 3 (PFT3) | 00H                        |
| Interrupt                 | Request flag registers (IF0L and IF0H)                  | 00H                        |
|                           | Mask flag registers (MK0L and MK0H)                     | FFH                        |
|                           | Priority specification flag registers (PR0L and PR0H)   | FFH                        |
|                           | External interrupt rising edge enable register (EGP)    | 00H                        |
|                           | External interrupt falling edge enable register (EGN)   | 00H                        |
| PLL frequency synthesizer | PLL mode select register (PLLMD)                        | 00H                        |
|                           | PLL reference mode register (PLLRF)                     | 0FH                        |
|                           | PLL unlock F/F judge register (PLLUL)                   | Retained <sup>Note 1</sup> |
|                           | PLL data registers (PLLRH, PLLRL, and PLLR0)            | Undefined                  |
|                           | PLL data transfer register (PLLNS)                      | 00H                        |
| Frequency counter         | IF counter mode select register (IFCMD)                 | 00H                        |
|                           | IF counter gate judge register (IFCJG)                  | 00H                        |
|                           | IF counter control register (IFCCR)                     | 00H                        |
|                           | IF counter register (IFCR)                              | 0000H                      |
| Power-on clear            | POC status register (POCS)                              | Retained <sup>Note 2</sup> |

## Table 16-1. Hardware Status After Reset (2/2)

Notes 1. Undefined only at power-on clear reset

2. 03H only at power-on clear reset

#### **16.2 Power Failure Detection Function**

If reset is effected by means of power-on clear, bit 0 (POCM) of the POC status register (POCS) is set to 1. If reset is effected by the  $\overrightarrow{\text{RESET}}$  pin or the watchdog timer, however, POCM holds the previous status.

A power failure status can be detected by detecting this POCM after reset by power-on clear has been cleared (after program execution has been started from address 0000H).

#### Figure 16-5. Format of POC Status Register (POCS)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    | Address After reset R/W                  |
|--------|---|---|---|---|---|---|------|------|------------------------------------------|
| POCS   | 0 | 0 | 0 | 0 | 0 | 0 | VM45 | РОСМ | 1 FF1BH Retained <sup>Note</sup> R&Reset |

| POCM   | Detection of power-on clear occurrence status |  |  |  |  |  |  |  |
|--------|-----------------------------------------------|--|--|--|--|--|--|--|
| 0      | Power-on clear does not occur                 |  |  |  |  |  |  |  |
| 1 Note | Reset is effected by power-on clear           |  |  |  |  |  |  |  |

- **Note** The value of this register is set to 03H only when reset is effected through power-on clearing. It is not reset by the  $\overrightarrow{\mathsf{RESET}}$  pin or watchdog timer.
- **Remark** The values of the special function registers, other than POCS and PLLUL, at power-on clear are the same as the values following a reset by the  $\overline{\text{RESET}}$  pin or watchdog timer (see **Table 16-1**).

## 16.3 4.5 V Voltage Detection Function

This function is used to detect a voltage drop on the V<sub>DD</sub> pin below 4.5 V ( $4.5 V \pm 0.3 V$ ). If the voltage on the V<sub>DD</sub> pin drops below 4.5 V ( $4.5 V \pm 0.3 V$ ), bit 1 (VM45) of the POC status register (POCS) is set.

Note, however, that this 4.5 V voltage detection function does not cause internal reset.

#### Figure 16-6. Format of POC Status Register (POCS)

| Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    | Address | After reset              | R/W     |
|--------|---|---|---|---|---|---|------|------|---------|--------------------------|---------|
| POCS   | 0 | 0 | 0 | 0 | 0 | 0 | VM45 | POCM | FF1BH   | Retained <sup>Note</sup> | R&Reset |

| VM45 | Detection of voltage level of VDD pin                              |
|------|--------------------------------------------------------------------|
| 0    | Does not detect if V_DD pin is less than 4.5 V (4.3 V $\pm$ 0.3 V) |
| 1    | Detects if V_DD pin is less than 4.5 V (4.3 V $\pm$ 0.3 V)         |

**Note** The value of this register is set to 03H only at power-on clear reset, and is not reset by the RESET pin and watchdog timer.

**Remark** The values of the special function registers, other than POCS and PLLUL, at power-on clear are the same as the values following a reset by the RESET pin or watchdog timer (see **Table 16-1**).

## **CHAPTER 17** µ**PD178F054**

The  $\mu$ PD178F054 is provided with a flash memory to/from which data can be rewritten/erased with the device mounted on the printed circuit board. The differences between the flash memory ( $\mu$ PD178F054) and mask ROM versions ( $\mu$ PD178053 and 178054) are shown in Table 17-1.

Table 17-1. Differences Between  $\mu \text{PD178F054}$  and Mask ROM Versions

| Item                                                      |               | μPD178F054                     | μPD178053, 178054                    |  |
|-----------------------------------------------------------|---------------|--------------------------------|--------------------------------------|--|
| Internal memory                                           | ROM structure | Flash memory                   | Mask ROM                             |  |
|                                                           | ROM capacity  | 32 KB                          | μPD178053: 24 KB<br>μPD178054: 32 KB |  |
| Internal ROM capacity select size switching register (IMS |               | Equivalent to mask ROM version | μΡD178053: C6H<br>μΡD178054: C8H     |  |
| IC pin                                                    |               | Not provided                   | Provided                             |  |
| VPP pin                                                   |               | Provided                       | Not provided                         |  |
| Electrical specifications                                 |               | Refer to CHAPTER 19 ELECTRICAL | SPECIFICATIONS.                      |  |

## 17.1 Memory Size Switching Register (IMS)

The internal memory capacity of the  $\mu$ PD178F054 can be changed using the memory size switching register (IMS). By using this register, the memory of the  $\mu$ PD178F054 can be mapped in the same manner as a mask ROM version with a different internal memory capacity.

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

Reset input sets this register to CFH.

Be sure to set IMS to C6H or C8H.

#### Figure 17-1. Format of Memory Size Switching Register (IMS)

| Symbol | 7    | 6    | 5    | 4 | 3    | 2    | 1    | 0    | Address | After reset | R/W |
|--------|------|------|------|---|------|------|------|------|---------|-------------|-----|
| IMS    | RAM2 | RAM1 | RAM0 | 0 | ROM3 | ROM2 | ROM1 | ROM0 | FFF0H   | CFH         | R/W |

| RAM2  | RAM1     | RAM0 | Selection of internal high-speed RAM capacity |
|-------|----------|------|-----------------------------------------------|
| 0     | 1        | 0    | 512 bytes                                     |
| 1     | 1        | 0    | 1024 bytes                                    |
| Other | than abo | ove  | Setting prohibited                            |

| ROM3  | ROM2     | ROM1 | ROM0 | Selection of internal ROM capacity |
|-------|----------|------|------|------------------------------------|
| 0     | 1        | 1    | 0    | 24 KB                              |
| 1     | 0        | 0    | 0    | 32 KB                              |
| Other | than abo | ove  |      | Setting prohibited                 |

Table 17-2 shows the setting of IMS to perform the same memory mapping as that of a mask ROM version.

#### Table 17-2. Set Value of Memory Size Switching Register

| Targeted Model | Set Value of IMS |
|----------------|------------------|
| μPD178053      | C6H              |
| μPD178054      | C8H              |

## 17.2 Internal Expansion RAM Size Switching Register (IXS)

The internal expansion RAM capacity of the  $\mu$ PD178F054 can be changed using the internal expansion RAM size switching register (IXS). By using this register, the memory of the  $\mu$ PD178F054 can be mapped in the same manner as a mask ROM version with a different internal expansion RAM capacity.

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

Reset input sets this register to 0CH.

#### Caution Do not set a value other than the initial value.

#### Figure 17-2. Format of Internal Expansion RAM Size Switching Register (IXS)

| Symbol | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      | _ | Address | After reset | R/W |
|--------|---|---|---|--------|--------|--------|--------|--------|---|---------|-------------|-----|
| IXS    | 0 | 0 | 0 | IXRAM4 | IXRAM3 | IXRAM2 | IXRAM1 | IXRAM0 |   | FFF4H   | 0CH         | R/W |

| IXRAM4 | IXRAM3   | IXRAM2 | IXRAM1 | IXRAM0 | Selection of internal expansion RAM capacity |
|--------|----------|--------|--------|--------|----------------------------------------------|
| 0      | 1        | 1      | 0      | 0      | 0 bytes                                      |
| Other  | than abo | ve     |        |        | Setting prohibited                           |

Table 17-3 shows the setting of IXS to perform the same memory mapping as that of a mask ROM version.

#### Table 17-3. Set Value of Internal Expansion RAM Size Switching Register

| Targeted Model    | Set Value of IXS |
|-------------------|------------------|
| μPD178053, 178054 | 0CH              |

## 17.3 Flash Memory Programming

The program memory provided in the  $\mu$ PD178F054 is flash memory.

The flash memory can be written on-board, i.e., with the  $\mu$ PD178F054 mounted on the target system. To do so, connect a dedicated flash programmer (Flashpro III (Part number: FL-PR3, PG-FP3)) to the host machine and target system.

Remark FL-PR3 and PG-FP3 are products of Naito Densei Machida Mfg. Co., Ltd.

#### 17.3.1 Selecting communication mode

The flash memory is written by using Flashpro III and by means of serial communication. Select a communication mode from those listed in Table 17-4. To select a communication mode, the format shown in Figure 17-3 is used. Each communication mode is selected depending on the number of VPP pulses shown in Table 17-4.

| Communication Mode       | Pins Used                            | Number of VPP Pulses |
|--------------------------|--------------------------------------|----------------------|
| 3-wire serial I/O (SIO3) | SI30/P70<br>SO30/P71<br>SCK30/P72    | 0                    |
|                          | SI31/P74<br>SO31/P75<br>SCK31/P76    | 1                    |
|                          | SI32/P120<br>SO32/P121<br>SCK32/P122 | 2                    |

Table 17-4. Communication Modes

Caution Be sure to select a communication mode by the number of VPP pulses shown in Table 17-4.





#### 17.3.2 Flash memory programming function

An operation such as writing the flash memory is performed when a command or data is transmitted/received in the selected communication mode. The major flash memory programming functions are listed in Table 17-5.

| Table 17-5. | <b>Major Functions</b> | of Flash Memory | Programming |
|-------------|------------------------|-----------------|-------------|
|-------------|------------------------|-----------------|-------------|

| Function          | Description                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------------------|
| Batch erase       | Erases all memory contents.                                                                                       |
| Batch blank check | Checks erased status of entire memory.                                                                            |
| Data write        | Writes data to flash memory starting from write start address and based on number of data (bytes) to be written). |
| Batch verify      | Compares all contents of memory with input data.                                                                  |

#### 17.3.3 Connecting Flashpro III

The connection between Flashpro III and the  $\mu$ PD178F054 is shown in Figure 17-4.

## Figure 17-4. Connection of Flashpro III in 3-Wire Serial I/O Mode



**Note** n = 1, 2

## 17.3.4 Setting example for Flashpro III (PG-FP3)

When writing data to flash memory using Flashpro III (PG-FP3), use the following settings.

- <1> Load parameter file.
- <2> Select the serial mode and serial cock using the type command.
- <3> An example of the settings for PG-FP3 is shown in Table 17-6.

## Table 17-6. Setting Example for Flashpro III (PG-FP3)

| Communication Mode        | Settin          | Number of VPP PulsesNote |   |
|---------------------------|-----------------|--------------------------|---|
| 3-wire serial I/O (SIO3)  | COMM PORT       | SIO ch-0                 | 0 |
|                           | CPU CLK         | On Target Board          |   |
|                           |                 | In Flashpro              |   |
|                           | On Target Board | 4.1943 MHz               |   |
|                           | SIO CLK         | 1.0 MHz                  |   |
|                           | In Flashpro     | 4.0 MHz                  |   |
|                           | SIO CLK         | 1.0 MHz                  |   |
| 3-wire serial I/O (SIO31) | COMM PORT       | SIO-ch1                  | 1 |
|                           | CPU CLK         | On Target Board          |   |
|                           |                 | In Flashpro              |   |
|                           | On Target Board | 4.1943 MHz               |   |
|                           | SIO CLK         | 1.0 MHz                  |   |
|                           | In Flashpro     | 4.0 MHz                  |   |
|                           | SIO CLK         | 1.0 MHz                  |   |
| 3-wire serial I/O (SIO32) | COMM PORT       | SIO-ch2                  | 2 |
|                           | CPU CLK         | On Target Board          |   |
|                           |                 | In Flashpro              |   |
|                           | On Target Board | 4.1943 MHz               |   |
|                           | SIO CLK         | 1.0 MHz                  |   |
|                           | In Flashpro     | 4.0 MHz                  |   |
|                           | SIO CLK         | 1.0 MHz                  |   |

**Note** Number of VPP pulse supplied by Flashpro III (PG-FP3) when serial mode is initialized. This determines the pin used for the communication.

**Remark** COMM PORT: Selection of serial port

- SIO CLK: Selection of serial clock frequency
- CPU CLK: Selection of CPU clock source to be input

## **CHAPTER 18 INSTRUCTION SET**

This chapter describes each instruction set of the  $\mu$ PD178054 Subseries as list table. For details of its operation and operation code, refer to the **78K/0 Series User's Manual Instruction (U12326E)**.

## 18.1 Conventions

#### 18.1.1 Operand symbols and description

Operands are written in the "Operand" column of each instruction in accordance with the description of the instruction operand symbols (refer to the assembler specifications for detail). When there are two or more descriptions, select one of them. Alphabetic letters in capitals and symbols, #, !, \$ and [] are key words and must be written as they are. Each symbol has the following meaning.

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

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

For operand register symbols, 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.

| Symbol                    | Description                                                                                                                                                                                                      |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| r                         | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7),                                                                                                                                                  |
| rp                        | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                                                                                                                                                                           |
| sfr                       | Special-function register symbol <sup>Note</sup>                                                                                                                                                                 |
| sfrp                      | Special-function register symbol (16-bit manipulatable register even addresses only) <sup>Note</sup>                                                                                                             |
| saddr                     | FE20H to FF1FH Immediate data or labels                                                                                                                                                                          |
| saddrp                    | FE20H to FF1FH Immediate data or labels (even address only)                                                                                                                                                      |
| addr16<br>addr11<br>addr5 | 0000H to FFFFH Immediate data or labels<br>(Only even addresses for 16-bit data transfer instructions)<br>0800H to 0FFFH Immediate data or labels<br>0040H to 007FH Immediate data or labels (even address only) |
| word                      | 16-bit immediate data or label                                                                                                                                                                                   |
| byte                      | 8-bit immediate data or label                                                                                                                                                                                    |
| bit                       | 3-bit immediate data or label                                                                                                                                                                                    |
| RBn                       | RB0 to RB3                                                                                                                                                                                                       |

| Table 18-1. | <b>Operand S</b> | ymbols and | Descriptions |
|-------------|------------------|------------|--------------|
|-------------|------------------|------------|--------------|

**Note** Addresses from FFD0H to FFDFH cannot be accessed with these operands.

Remark For special function register symbols, refer to Table 3-4 Special Function Registers.

#### 18.1.2 Description of "operation" column

- A: A register; 8-bit accumulator
- X: X register B: B register
- B: B register C: C register
- C: C register D: D register
- E: E register
- H: H register
- L: L register
- AX: AX register pair; 16-bit accumulator
- BC: BC register pair
- DE: DE register pair
- HL: HL register pair
- PC: Program counter
- SP: Stack pointer
- PSW: Program status word
- CY: Carry flag
- AC: Auxiliary carry flag
- Z: Zero flag
- RBS: Register bank select flag
- IE: Interrupt request enable flag
- NMIS: Non-maskable interrupt servicing flag
- (): Memory contents indicated by address or register contents in parentheses
- $\times_{H}, \times_{L}:$  Higher 8 bits and lower 8 bits of 16-bit register
- $\wedge$ : Logical product (AND)
- V: Logical sum (OR)
- $\forall$ : Exclusive logical sum (exclusive OR)
- ----: Inverted data
- addr16: 16-bit immediate data or label
- jdisp8: Signed 8-bit data (displacement value)

## 18.1.3 Description of "flag operation" column

- (Blank): Nt affected
- 0: Cleared to 0
- 1: Set to 1
- ×: Set/cleared according to the result
- R: Previously saved value is restored

## 18.2 Operation List

| Instruction Mnemonic       |              | Operands       | Byte | e Clock |                           | Operation                       |   | Fla | ıg  |
|----------------------------|--------------|----------------|------|---------|---------------------------|---------------------------------|---|-----|-----|
| Group                      |              |                |      | Note 1  | Note 2                    |                                 | z | AC  | ССХ |
| 8-bit data MOV<br>transfer | r, #byte     | 2              | 4    | -       | r ← byte                  |                                 |   |     |     |
|                            | saddr, #byte | 3              | 6    | 7       | $(saddr) \leftarrow byte$ |                                 |   |     |     |
|                            |              | sfr, #byte     | 3    | -       | 7                         | sfr ← byte                      |   |     |     |
|                            |              | A, r Note 3    | 1    | 2       | -                         | $A \leftarrow r$                |   |     |     |
|                            |              | r, A Note 3    | 1    | 2       | -                         | $r \leftarrow A$                |   |     |     |
|                            |              | A, saddr       | 2    | 4       | 5                         | $A \leftarrow (saddr)$          |   |     |     |
|                            |              | saddr, A       | 2    | 4       | 5                         | $(saddr) \leftarrow A$          |   |     |     |
|                            |              | A, sfr         | 2    | -       | 5                         | $A \leftarrow sfr$              |   |     |     |
|                            |              | sfr, A         | 2    | -       | 5                         | $sfr \leftarrow A$              |   |     |     |
|                            |              | A, !addr16     | 3    | 8       | 9                         | $A \leftarrow (addr16)$         |   |     |     |
|                            |              | !addr16, A     | 3    | 8       | 9                         | $(addr16) \leftarrow A$         |   |     |     |
|                            |              | PSW, #byte     | 3    | -       | 7                         | $PSW \leftarrow byte$           | × | ×   | ×   |
|                            |              | A, PSW         | 2    | -       | 5                         | $A \leftarrow PSW$              |   |     |     |
|                            |              | PSW, A         | 2    | -       | 5                         | $PSW \leftarrow A$              | × | ×   | ×   |
|                            |              | A, [DE]        | 1    | 4       | 5                         | $A \leftarrow (DE)$             |   |     |     |
|                            |              | [DE], A        | 1    | 4       | 5                         | $(DE) \leftarrow A$             |   |     |     |
|                            |              | A, [HL]        | 1    | 4       | 5                         | $A \leftarrow (HL)$             |   |     |     |
|                            |              | [HL], A        | 1    | 4       | 5                         | $(HL) \leftarrow A$             |   |     |     |
|                            |              | A, [HL + byte] | 2    | 8       | 9                         | $A \leftarrow (HL + byte)$      |   |     |     |
|                            |              | [HL + byte], A | 2    | 8       | 9                         | (HL + byte) ← A                 |   |     |     |
|                            |              | A, [HL + B]    | 1    | 6       | 7                         | $A \leftarrow (HL + B)$         |   |     |     |
|                            |              | [HL + B], A    | 1    | 6       | 7                         | $(HL + B) \leftarrow A$         |   |     |     |
|                            |              | A, [HL + C]    | 1    | 6       | 7                         | $A \leftarrow (HL + C)$         |   |     |     |
|                            |              | [HL + C], A    | 1    | 6       | 7                         | $(HL+C) \leftarrow A$           |   |     |     |
|                            | ХСН          | A, r Note 3    | 1    | 2       | -                         | $A \leftrightarrow r$           |   |     |     |
|                            |              | A, saddr       | 2    | 4       | 6                         | $A \leftrightarrow (saddr)$     |   |     |     |
|                            |              | A, sfr         | 2    | -       | 6                         | $A \leftrightarrow sfr$         |   |     |     |
|                            |              | A, !addr16     | 3    | 8       | 10                        | $A \leftrightarrow (addr16)$    |   |     |     |
|                            |              | A, [DE]        | 1    | 4       | 6                         | $A \leftrightarrow (DE)$        |   |     |     |
|                            |              | A, [HL]        | 1    | 4       | 6                         | $A \leftrightarrow (HL)$        |   |     | -   |
|                            |              | A, [HL + byte] | 2    | 8       | 10                        | $A \leftrightarrow (HL + byte)$ |   |     | -   |
|                            |              | A, [HL + B]    | 2    | 8       | 10                        | $A \leftrightarrow (HL + B)$    |   |     |     |
|                            |              | A, [HL + C]    | 2    | 8       | 10                        | $A \leftrightarrow (HL + C)$    |   |     |     |

Notes 1. When the internal high-speed RAM area is accessed or instruction with no data access

- 2. When an area except the internal high-speed RAM area is accessed.
- 3. Except "r = A"
- **Remarks 1.** One instruction clock cycle is one cycle of the CPU clock ( $f_{CPU}$ ) selected by the PCC register.
  - 2. This clock cycle applies to internal ROM program.

| Instruction Mnemonic Group |              | Operands       | Byte   | Byte Clock |                                         | Operation                                      |   | Fla | g  |
|----------------------------|--------------|----------------|--------|------------|-----------------------------------------|------------------------------------------------|---|-----|----|
|                            |              |                |        | Note 1     | Note 2                                  | 1                                              | z | AC  | CY |
| 16-bit data                | MOVW         | rp, #word      | 3      | 6          | -                                       | $rp \leftarrow word$                           |   |     |    |
| transfer                   |              | saddrp, #word  | 4      | 8          | 10                                      | $(saddrp) \leftarrow word$                     |   |     | -  |
|                            |              | sfrp, #word    | 4      | -          | 10                                      | $sfrp \leftarrow word$                         |   |     |    |
|                            | AX, saddrp   | 2              | 6      | 8          | $AX \leftarrow (saddrp)$                |                                                |   |     |    |
|                            | saddrp, AX   | 2              | 6      | 8          | $(saddrp) \leftarrow AX$                |                                                |   |     |    |
|                            |              | AX, sfrp       | 2      | -          | 8                                       | $AX \leftarrow sfrp$                           |   |     |    |
|                            |              | sfrp, AX       | 2      | -          | 8                                       | $sfrp \leftarrow AX$                           |   |     |    |
|                            |              | AX, rp No      | te 3 1 | 4          | _                                       | AX ← rp                                        |   |     |    |
|                            |              | rp, AX No      | te 3 1 | 4          | _                                       | $rp \leftarrow AX$                             |   |     |    |
|                            |              | AX, !addr16    | 3      | 10         | 12                                      | $AX \leftarrow (addr16)$                       |   |     |    |
|                            |              | !addr16, AX    | 3      | 10         | 12                                      | $(addr16) \leftarrow AX$                       |   |     |    |
|                            | XCHW         | AX, rp No      | te 3 1 | 4          | _                                       | $AX \leftrightarrow rp$                        |   |     |    |
| 8-bit ADD operation        | A, #byte     | 2              | 4      | -          | A, CY $\leftarrow$ A + byte             | ×                                              | Х | ×   |    |
|                            | saddr, #byte | 3              | 6      | 8          | (saddr), CY $\leftarrow$ (saddr) + byte | ×                                              | Х | ×   |    |
|                            |              | A, r No        | te 4 2 | 4          | -                                       | A, CY $\leftarrow$ A + r                       | × | Х   | ×  |
|                            |              | r, A           | 2      | 4          | -                                       | $r, CY \leftarrow r + A$                       | × | ×   | ×  |
|                            |              | A, saddr       | 2      | 4          | 5                                       | A, CY $\leftarrow$ A + (saddr)                 | × | Х   | ×  |
|                            |              | A, !addr16     | 3      | 8          | 9                                       | A, CY $\leftarrow$ A + (addr16)                | × | Х   | ×  |
|                            |              | A, [HL]        | 1      | 4          | 5                                       | A, CY $\leftarrow$ A + (HL)                    | × | Х   | ×  |
|                            |              | A, [HL + byte] | 2      | 8          | 9                                       | A, CY $\leftarrow$ A + (HL + byte)             | × | ×   | ×  |
|                            |              | A, [HL + B]    | 2      | 8          | 9                                       | $A,CY\leftarrowA+(HL+B)$                       | × | Х   | ×  |
|                            |              | A, [HL + C]    | 2      | 8          | 9                                       | $A,CY\leftarrowA+(HL+C)$                       | × | Х   | ×  |
|                            | ADDC         | A, #byte       | 2      | 4          | -                                       | A, CY $\leftarrow$ A + byte + CY               | × | Х   | ×  |
|                            |              | saddr, #byte   | 3      | 6          | 8                                       | (saddr), $CY \leftarrow$ (saddr) + byte + $CY$ | × | Х   | ×  |
|                            |              | A, r No        | te 4 2 | 4          | -                                       | $A,CY\leftarrowA+r+CY$                         | × | Х   | ×  |
|                            |              | r, A           | 2      | 4          | -                                       | $r,CY\leftarrowr+A+CY$                         | × | Х   | ×  |
|                            |              | A, saddr       | 2      | 4          | 5                                       | A, CY $\leftarrow$ A + (saddr) + CY            | × | Х   | ×  |
|                            |              | A, !addr16     | 3      | 8          | 9                                       | A, CY $\leftarrow$ A + (addr16) + CY           | × | ×   | ×  |
|                            |              | A, [HL]        | 1      | 4          | 5                                       | $A,CY \leftarrow A + (HL) + CY$                | × | ×   | ×  |
|                            |              | A, [HL + byte] | 2      | 8          | 9                                       | A, CY $\leftarrow$ A + (HL + byte) + CY        | × | ×   | Х  |
|                            |              | A, [HL + B]    | 2      | 8          | 9                                       | $A,CY \leftarrow A + (HL + B) + CY$            | × | ×   | ×  |
|                            |              | A, [HL + C]    | 2      | 8          | 9                                       | $A,CY\leftarrowA+(HL+C)+CY$                    | × | ×   | ×  |

2. When an area except the internal high-speed RAM area is accessed

**3.** Only when rp = BC, DE or HL

4. Except "r = A"

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the PCC register.

2. This clock cycle applies to internal ROM program.

| Instruction Mnemonic<br>Group |          | Operands       | Byte | Clock  |                                | Operation                                    |   | Fla | g  |
|-------------------------------|----------|----------------|------|--------|--------------------------------|----------------------------------------------|---|-----|----|
|                               |          |                |      | Note 1 | Note 2                         |                                              | z | AC  | CY |
| 8-bit                         | SUB      | A, #byte       | 2    | 4      | -                              | A, CY $\leftarrow$ A – byte                  | × | ×   | ×  |
| operation                     |          | saddr, #byte   | 3    | 6      | 8                              | (saddr), CY $\leftarrow$ (saddr) – byte      | × | Х   | ×  |
|                               |          | A, r Note 3    | 2    | 4      | -                              | A, CY $\leftarrow$ A – r                     | × | ×   | ×  |
|                               | r, A     | 2              | 4    | -      | $r, CY \leftarrow r - A$       | ×                                            | × | ×   |    |
|                               | A, saddr | 2              | 4    | 5      | A, CY $\leftarrow$ A – (saddr) | ×                                            | × | ×   |    |
|                               |          | A, !addr16     | 3    | 8      | 9                              | A, CY $\leftarrow$ A – (addr16)              | × | ×   | ×  |
|                               |          | A, [HL]        | 1    | 4      | 5                              | A, CY $\leftarrow$ A – (HL)                  | × | ×   | ×  |
|                               |          | A, [HL + byte] | 2    | 8      | 9                              | A, CY $\leftarrow$ A – (HL + byte)           | × | ×   | ×  |
| SUBC                          |          | A, [HL + B]    | 2    | 8      | 9                              | $A,CY \leftarrow A - (HL + B)$               | × | х   | ×  |
|                               |          | A, [HL + C]    | 2    | 8      | 9                              | $A,CY\leftarrowA-(HL+C)$                     | × | х   | ×  |
|                               | SUBC     | A, #byte       | 2    | 4      | -                              | A, CY $\leftarrow$ A – byte – CY             | × | ×   | ×  |
|                               |          | saddr, #byte   | 3    | 6      | 8                              | (saddr), CY $\leftarrow$ (saddr) – byte – CY | × | х   | ×  |
|                               |          | A, r Note 3    | 2    | 4      | -                              | $A,CY\leftarrowA-r-CY$                       | × | ×   | ×  |
|                               |          | r, A           | 2    | 4      | -                              | $r,CY\leftarrowr-A-CY$                       | × | Х   | ×  |
|                               |          | A, saddr       | 2    | 4      | 5                              | A, CY $\leftarrow$ A – (saddr) – CY          | × | Х   | ×  |
|                               |          | A, !addr16     | 3    | 8      | 9                              | A, CY $\leftarrow$ A – (addr16) – CY         | × | ×   | ×  |
|                               |          | A, [HL]        | 1    | 4      | 5                              | $A,CY \leftarrow A - (HL) - CY$              | × | ×   | ×  |
|                               |          | A, [HL + byte] | 2    | 8      | 9                              | A, CY $\leftarrow$ A – (HL + byte) – CY      | × | Х   | ×  |
|                               |          | A, [HL + B]    | 2    | 8      | 9                              | $A,CY \leftarrow A - (HL + B) - CY$          | × | Х   | ×  |
|                               |          | A, [HL + C]    | 2    | 8      | 9                              | $A,CY \leftarrow A - (HL + C) - CY$          | × | Х   | ×  |
|                               | AND      | A, #byte       | 2    | 4      | -                              | $A \leftarrow A \land byte$                  | × |     |    |
|                               |          | saddr, #byte   | 3    | 6      | 8                              | $(saddr) \leftarrow (saddr) \land byte$      | × |     |    |
|                               |          | A, r Note 3    | 2    | 4      | -                              | $A \leftarrow A \wedge r$                    | × |     |    |
|                               |          | r, A           | 2    | 4      | -                              | $r \leftarrow r \land A$                     | × |     |    |
|                               |          | A, saddr       | 2    | 4      | 5                              | $A \leftarrow A \land (saddr)$               | × |     |    |
|                               |          | A, !addr16     | 3    | 8      | 9                              | $A \leftarrow A \land (addr16)$              | × |     |    |
|                               |          | A, [HL]        | 1    | 4      | 5                              | $A \leftarrow A \land [HL]$                  | × |     |    |
|                               |          | A, [HL + byte] | 2    | 8      | 9                              | $A \leftarrow A \land [HL + byte]$           | × |     |    |
|                               |          | A, [HL + B]    | 2    | 8      | 9                              | $A \leftarrow A \land [HL + B]$              | × |     |    |
|                               |          | A, [HL + C]    | 2    | 8      | 9                              | $A \leftarrow A \land [HL + C]$              | × |     |    |

2. When an area except the internal high-speed RAM area is accessed

3. Except "r = A"

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the PCC register.2. This clock cycle applies to internal ROM program.

| Instruction Mnemonic |          | Operands       | Byte   | Clock  |                         | Operation                                 |    | Flag | g |
|----------------------|----------|----------------|--------|--------|-------------------------|-------------------------------------------|----|------|---|
| Group                |          |                | Note 1 | Note 2 | -                       | Z                                         | AC | CY   |   |
| 8-bit                | OR       | A, #byte       | 2      | 4      | _                       | $A \leftarrow A \lor byte$                | ×  |      |   |
| operation            |          | saddr, #byte   | 3      | 6      | 8                       | $(saddr) \leftarrow (saddr) \lor byte$    | ×  |      |   |
|                      | A, r Not | e 3 2          | 4      | -      | $A \leftarrow A \lor r$ | ×                                         |    |      |   |
|                      |          | r, A           | 2      | 4      | -                       | $r \leftarrow r \lor A$                   | ×  |      |   |
|                      |          | A, saddr       | 2      | 4      | 5                       | $A \leftarrow A \lor (saddr)$             | ×  |      |   |
|                      |          | A, !addr16     | 3      | 8      | 9                       | $A \leftarrow A \lor$ (addr16)            | ×  |      |   |
|                      |          | A, [HL]        | 1      | 4      | 5                       | $A \leftarrow A \lor (HL)$                | ×  |      |   |
|                      |          | A, [HL + byte] | 2      | 8      | 9                       | $A \leftarrow A \lor (HL + byte)$         | ×  |      |   |
|                      |          | A, [HL + B]    | 2      | 8      | 9                       | $A \leftarrow A \lor (HL + B)$            | ×  |      |   |
|                      |          | A, [HL + C]    | 2      | 8      | 9                       | $A \leftarrow A \lor (HL + C)$            | ×  |      |   |
| хо                   | XOR      | A, #byte       | 2      | 4      | -                       | $A \leftarrow A \forall byte$             | ×  |      |   |
|                      |          | saddr, #byte   | 3      | 6      | 8                       | $(saddr) \leftarrow (saddr) \forall byte$ | ×  |      |   |
|                      |          | A, r Not       | e 3 2  | 4      | _                       | $A \leftarrow A \forall r$                | ×  |      |   |
|                      |          | r, A           | 2      | 4      | _                       | $r \leftarrow r \forall A$                | ×  |      |   |
|                      |          | A, saddr       | 2      | 4      | 5                       | $A \leftarrow A \lor$ (saddr)             | ×  |      |   |
|                      |          | A, !addr16     | 3      | 8      | 9                       | $A \leftarrow A \forall$ (addr16)         | ×  |      |   |
|                      |          | A, [HL]        | 1      | 4      | 5                       | $A \leftarrow A \not \forall (HL)$        | ×  |      |   |
|                      |          | A, [HL + byte] | 2      | 8      | 9                       | $A \leftarrow A \not \forall (HL + byte)$ | ×  |      |   |
|                      |          | A, [HL + B]    | 2      | 8      | 9                       | $A \leftarrow A \not \forall (HL + B)$    | ×  |      | - |
|                      |          | A, [HL + C]    | 2      | 8      | 9                       | $A \leftarrow A \not \leftarrow (HL + C)$ | ×  |      | - |
|                      | CMP      | A, #byte       | 2      | 4      | -                       | A – byte                                  | ×  | ×    | × |
|                      |          | saddr, #byte   | 3      | 6      | 8                       | (saddr) – byte                            | ×  | ×    | × |
|                      |          | A, r Not       | e 3 2  | 4      | -                       | A – r                                     | ×  | ×    | × |
|                      |          | r, A           | 2      | 4      | -                       | r – A                                     | ×  | ×    | × |
|                      |          | A, saddr       | 2      | 4      | 5                       | A – (saddr)                               | ×  | ×    | × |
|                      |          | A, !addr16     | 3      | 8      | 9                       | A – (addr16)                              | ×  | ×    | × |
|                      |          | A, [HL]        | 1      | 4      | 5                       | A – (HL)                                  | ×  | ×    | × |
|                      |          | A, [HL + byte] | 2      | 8      | 9                       | A – (HL + byte)                           | ×  | х    | × |
|                      |          | A, [HL + B]    | 2      | 8      | 9                       | A – (HL + B)                              | ×  | ×    | × |
|                      |          | A, [HL + C]    | 2      | 8      | 9                       | A – (HL + C)                              | ×  | ×    | × |

2. When an area except the internal high-speed RAM area is accessed

**3.** Except "r = A"

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPU) selected by the PCC register.

2. This clock cycle applies to internal ROM program.

| Instruction Mnemonic<br>Group |       | Operands      | Byte | 0      | Clock  | Operation                                                                                                                      |   | Flag | g  |
|-------------------------------|-------|---------------|------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------|---|------|----|
|                               |       |               |      | Note 1 | Note 2 |                                                                                                                                | Z | AC   | CY |
| 16-bit                        | ADDW  | AX, #word     | 3    | 6      | -      | AX, CY $\leftarrow$ AX + word                                                                                                  | × | Х    | ×  |
| operation                     | SUBW  | AX, #word     | 3    | 6      | -      | AX, CY $\leftarrow$ AX – word                                                                                                  | × | ×    | ×  |
|                               | CMPW  | AX, #word     | 3    | 6      | -      | AX – word                                                                                                                      | × | ×    | ×  |
| Multiply/                     | MULU  | Х             | 2    | 16     | -      | $AX \leftarrow A \times X$                                                                                                     |   |      |    |
| divide                        | DIVUW | С             | 2    | 25     | -      | AX (Quotient), C (Remainder) $\leftarrow$ AX $\div$ C                                                                          |   |      |    |
| Increment/                    | INC   | r             | 1    | 2      | -      | r ← r + 1                                                                                                                      | × | ×    |    |
| decrement                     |       | saddr         | 2    | 4      | 6      | $(saddr) \leftarrow (saddr) + 1$                                                                                               | × | ×    |    |
|                               | DEC   | r             | 1    | 2      | -      | r ← r − 1                                                                                                                      | × | ×    |    |
|                               |       | saddr         | 2    | 4      | 6      | $(saddr) \leftarrow (saddr) - 1$                                                                                               | × | ×    |    |
|                               | INCW  | rp            | 1    | 4      | -      | $rp \leftarrow rp + 1$                                                                                                         |   |      |    |
|                               | DECW  | rp            | 1    | 4      | -      | $rp \leftarrow rp - 1$                                                                                                         |   |      |    |
| Rotate                        | ROR   | A, 1          | 1    | 2      | -      | (CY, $A_7 \leftarrow A_0$ , $A_{m-1} \leftarrow A_m$ ) × 1 time                                                                |   |      | ×  |
|                               | ROL   | A, 1          | 1    | 2      | -      | $(CY, A_0 \leftarrow A_7, A_{m+1} \leftarrow A_m) \times 1$ time                                                               |   |      | ×  |
|                               | RORC  | A, 1          | 1    | 2      | -      | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1$ time                                                 |   |      | ×  |
| F                             | ROLC  | A, 1          | 1    | 2      | -      | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$ time                                                 |   |      | ×  |
|                               | ROR4  | [HL]          | 2    | 10     | 12     | A <sub>3-0</sub> ← (HL) <sub>3-0</sub> , (HL) <sub>7-4</sub> ← A <sub>3-0</sub> ,<br>(HL) <sub>3-0</sub> ← (HL) <sub>7-4</sub> |   |      |    |
|                               | ROL4  | [HL]          | 2    | 10     | 12     | A <sub>3-0</sub> ← (HL) <sub>7-4</sub> , (HL) <sub>3-0</sub> ← A <sub>3-0</sub> ,<br>(HL) <sub>7-4</sub> ← (HL) <sub>3-0</sub> |   |      |    |
| BCD<br>adjust                 | ADJBA |               | 2    | 4      | -      | Decimal Adjust Accumulator after<br>Addition                                                                                   | × | ×    | ×  |
|                               | ADJBS |               | 2    | 4      | -      | Decimal Adjust Accumulator after<br>Subtract                                                                                   | × | ×    | ×  |
| Bit                           | MOV1  | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow (saddr.bit)$                                                                                                    |   |      | ×  |
| manipulate                    |       | CY, sfr.bit   | 3    | -      | 7      | CY ← sfr.bit                                                                                                                   |   |      | ×  |
|                               |       | CY, A.bit     | 2    | 4      | -      | CY ← A.bit                                                                                                                     |   |      | ×  |
|                               |       | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow PSW.bit$                                                                                                        |   |      | ×  |
|                               |       | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow (HL).bit$                                                                                                       |   |      | ×  |
|                               |       | saddr.bit, CY | 3    | 6      | 8      | $(saddr.bit) \leftarrow CY$                                                                                                    |   |      |    |
|                               |       | sfr.bit, CY   | 3    | -      | 8      | $sfr.bit \leftarrow CY$                                                                                                        |   |      |    |
|                               |       | A.bit, CY     | 2    | 4      | -      | A.bit ← CY                                                                                                                     |   |      |    |
|                               |       | PSW.bit, CY   | 3    | -      | 8      | $PSW.bit \leftarrow CY$                                                                                                        | × | ×    |    |
|                               |       | [HL].bit, CY  | 2    | 6      | 8      | (HL).bit ← CY                                                                                                                  |   |      |    |

2. When an area except the internal high-speed RAM area is accessed

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the PCC register.2. This clock cycle applies to internal ROM program.

| Instruction | Mnemonic | Operands      | Byte | 0      | Clock  | Operation                                     | Flag | g  |
|-------------|----------|---------------|------|--------|--------|-----------------------------------------------|------|----|
| Group       |          |               |      | Note 1 | Note 2 | 1                                             | Z AC | CY |
| Bit         | AND1     | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \land (saddr.bit)$          |      | ×  |
| manipulate  |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \land sfr.bit$              |      | ×  |
|             |          | CY, A.bit     | 2    | 4      | -      | $CY \leftarrow CY \land A.bit$                |      | ×  |
|             |          | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow CY \land PSW.bit$              |      | ×  |
|             |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \land (HL).bit$             |      | ×  |
|             | OR1      | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \lor (saddr.bit)$           |      | ×  |
|             |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \lor sfr.bit$               |      | ×  |
|             |          | CY, A.bit     | 2    | 4      | -      | $CY \leftarrow CY \lor A.bit$                 |      | ×  |
|             |          | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow CY \lor PSW.bit$               |      | ×  |
|             |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \lor (HL).bit$              |      | ×  |
|             | XOR1     | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \not\leftarrow (saddr.bit)$ |      | ×  |
|             |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \forall sfr.bit$            |      | ×  |
|             |          | CY, A.bit     | 2    | 4      | -      | $CY \leftarrow CY \forall A.bit$              |      | ×  |
|             |          | CY, PSW. bit  | 3    | -      | 7      | $CY \leftarrow CY \forall PSW.bit$            |      | ×  |
|             |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \forall (HL).bit$           |      | ×  |
|             | SET1     | saddr.bit     | 2    | 4      | 6      | $(saddr.bit) \leftarrow 1$                    |      |    |
|             |          | sfr.bit       | 3    | -      | 8      | sfr.bit $\leftarrow$ 1                        |      |    |
|             |          | A.bit         | 2    | 4      | -      | A.bit $\leftarrow$ 1                          |      |    |
|             |          | PSW.bit       | 2    | -      | 6      | PSW.bit ← 1                                   | × ×  | ×  |
|             |          | [HL].bit      | 2    | 6      | 8      | (HL).bit $\leftarrow$ 1                       |      |    |
|             | CLR1     | saddr.bit     | 2    | 4      | 6      | $(saddr.bit) \leftarrow 0$                    |      |    |
|             |          | sfr.bit       | 3    | -      | 8      | sfr.bit $\leftarrow 0$                        |      |    |
|             |          | A.bit         | 2    | 4      | -      | A.bit $\leftarrow 0$                          |      |    |
|             |          | PSW.bit       | 2    | -      | 6      | $PSW.bit \gets 0$                             | × ×  | ×  |
|             |          | [HL].bit      | 2    | 6      | 8      | (HL).bit $\leftarrow 0$                       |      |    |
|             | SET1     | CY            | 1    | 2      | -      | CY ← 1                                        |      | 1  |
|             | CLR1     | CY            | 1    | 2      | -      | $CY \leftarrow 0$                             |      | 0  |
|             | NOT1     | CY            | 1    | 2      | _      | $CY \leftarrow \overline{CY}$                 |      | ×  |

2. When an area except the internal high-speed RAM area is accessed

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the PCC register.

2. This clock cycle applies to internal ROM program.

| Instruction | Mnemonic | Operands  | Byte | 0      | Clock  | Operation                                                                                                                                                                                                             |   | Flag | g  |
|-------------|----------|-----------|------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
| Group       |          |           |      | Note 1 | Note 2 |                                                                                                                                                                                                                       | z | AC   | CY |
| Call/return | CALL     | !addr16   | 3    | 7      | -      | $\begin{split} (SP-1) \leftarrow (PC+3)_{H,} \ (SP-2) \leftarrow (PC+3)_{L}, \\ PC \leftarrow addr16, \ SP \leftarrow SP-2 \end{split}$                                                                               |   |      |    |
|             | CALLF    | !addr11   | 2    | 5      | -      | $\begin{array}{l} (SP-1) \leftarrow (PC+2)_{H},  (SP-2) \leftarrow (PC+2)_{L}, \\ PC_{15\text{-}11} \leftarrow 00001,  PC_{10\text{-}0} \leftarrow addr11, \\ SP \leftarrow SP-2 \end{array}$                         |   |      |    |
|             | CALLT    | [addr5]   | 1    | 6      | _      | $\begin{array}{l} (SP-1) \leftarrow (PC+1)_{H},  (SP-2) \leftarrow (PC+1)_{L}, \\ PC_{H} \leftarrow (0000000,  addr5+1), \\ PC_{L} \leftarrow (0000000,  addr5), \\ SP \leftarrow SP-2 \end{array}$                   |   |      |    |
|             | BRK      |           | 1    | 6      | -      | $\begin{array}{l} (SP-1) \leftarrow PSW,  (SP-2) \leftarrow (PC+1)_{H}, \\ (SP-3) \leftarrow (PC+1)_{L},  PC_{H} \leftarrow (003FH), \\ PC_{L} \leftarrow (003EH),  SP \leftarrow SP-3,  IE \leftarrow 0 \end{array}$ |   |      |    |
|             | RET      |           | 1    | 6      | -      | $PC_{H} \leftarrow (SP + 1), PC_{L} \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                       |   |      |    |
|             | RETI     |           | 1    | 6      | -      | $\begin{array}{l} PC_{H} \leftarrow (SP+1), \ PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2), \ SP \leftarrow SP+3, \\ NMIS \leftarrow 0 \end{array}$                                                               | R | R    | R  |
|             | RETB     |           | 1    | 6      | -      | $\begin{array}{l} PC_{H} \leftarrow (SP+1), \ PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2), \ SP \leftarrow SP+3 \end{array}$                                                                                     | R | R    | R  |
| Stack       | PUSH     | PSW       | 1    | 2      | -      | $(SP - 1) \leftarrow PSW, SP \leftarrow SP - 1$                                                                                                                                                                       |   |      |    |
| manipulate  |          | rp        | 1    | 4      | -      | $(SP - 1) \leftarrow rp_{H}, (SP - 2) \leftarrow rp_{L},$<br>$SP \leftarrow SP - 2$                                                                                                                                   |   |      |    |
|             | POP      | PSW       | 1    | 2      | _      | $PSW \leftarrow (SP),  SP \leftarrow SP + 1$                                                                                                                                                                          | R | R    | R  |
|             |          | rp        | 1    | 4      | -      | $\begin{array}{l} rp_{H} \leftarrow (SP + 1), \ rp_{L} \leftarrow (SP), \\ SP \leftarrow SP + 2 \end{array}$                                                                                                          |   |      |    |
|             | MOVW     | SP, #word | 4    | -      | 10     | $SP \leftarrow word$                                                                                                                                                                                                  |   |      |    |
|             |          | SP, AX    | 2    | -      | 8      | $SP \leftarrow AX$                                                                                                                                                                                                    |   |      |    |
|             |          | AX, SP    | 2    | -      | 8      | $AX \leftarrow SP$                                                                                                                                                                                                    |   |      |    |
| Uncondi-    | BR       | !addr16   | 3    | 6      | I      | $PC \leftarrow addr16$                                                                                                                                                                                                |   |      |    |
| tional      |          | \$addr16  | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$                                                                                                                                                                                       |   |      |    |
| branch      |          | AX        | 2    | 8      | I      | $PC_{H} \leftarrow A,  PC_{L} \leftarrow X$                                                                                                                                                                           |   |      |    |
| Conditional | BC       | \$addr16  | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 1$                                                                                                                                                                           |   |      |    |
| branch      | BNC      | \$addr16  | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } CY = 0$                                                                                                                                                                    |   |      |    |
|             | BZ       | \$addr16  | 2    | 6      | I      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 1$                                                                                                                                                                            |   |      |    |
|             | BNZ      | \$addr16  | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 0$                                                                                                                                                                            |   |      | _  |

2. When an area except the internal high-speed RAM area is accessed

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcPu) selected by the PCC register.2. This clock cycle applies to internal ROM program.

| Instruction | Mnemonic | Operands            | Byte | 0      | Clock  | Operation                                                                                     |   | Flag  |
|-------------|----------|---------------------|------|--------|--------|-----------------------------------------------------------------------------------------------|---|-------|
| Group       |          |                     |      | Note 1 | Note 2 | 1                                                                                             | Z | AC CY |
| Conditional | вт       | saddr.bit, \$addr16 | 3    | 8      | 9      | $PC \leftarrow PC + 3 + jdisp8 if(saddr.bit) = 1$                                             |   |       |
| branch      |          | sfr.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1                                                |   |       |
|             |          | A.bit, \$addr16     | 3    | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1                                                  |   |       |
|             |          | PSW.bit, \$addr16   | 3    | -      | 9      | $PC \leftarrow PC + 3 + jdisp8$ if PSW.bit = 1                                                |   |       |
|             |          | [HL].bit, \$addr16  | 3    | 10     | 11     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1                                               |   |       |
|             | BF       | saddr.bit, \$addr16 | 4    | 10     | 11     | $PC \leftarrow PC + 4 + jdisp8 if(saddr.bit) = 0$                                             |   |       |
|             |          | sfr.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 0                                                |   |       |
|             |          | A.bit, \$addr16     | 3    | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 0                                                  |   |       |
|             |          | PSW.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if PSW. bit = 0                                               |   |       |
|             |          | [HL].bit, \$addr16  | 3    | 10     | 11     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 0                                               |   |       |
|             | BTCLR    | saddr.bit, \$addr16 | 4    | 10     | 12     | $PC \leftarrow PC + 4 + jdisp8 if(saddr.bit) = 1$<br>then reset(saddr.bit)                    |   |       |
|             |          | sfr.bit, \$addr16   | 4    | -      | 12     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1<br>then reset sfr.bit                          |   |       |
|             |          | A.bit, \$addr16     | 3    | 8      | _      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1<br>then reset A.bit                              |   |       |
|             |          | PSW.bit, \$addr16   | 4    | -      | 12     | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1<br>then reset PSW.bit                          | × | × ×   |
|             |          | [HL].bit, \$addr16  | 3    | 10     | 12     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1 then reset (HL).bit                           |   |       |
|             | DBNZ     | B, \$addr16         | 2    | 6      | -      | B ← B − 1, then<br>PC ← PC + 2 + jdisp8 if B $\neq$ 0                                         |   |       |
|             |          | C, \$addr16         | 2    | 6      | -      | $C \leftarrow C -1$ , then<br>PC $\leftarrow$ PC + 2 + jdisp8 if C $\neq 0$                   |   |       |
|             |          | saddr. \$addr16     | 3    | 8      | 10     | $(saddr) \leftarrow (saddr) - 1$ , then<br>PC $\leftarrow$ PC + 3 + jdisp8 if(saddr) $\neq 0$ |   |       |
| CPU         | SEL      | RBn                 | 2    | 4      | -      | RBS1, 0 ← n                                                                                   |   |       |
| control     | NOP      |                     | 1    | 2      | -      | No Operation                                                                                  |   |       |
|             | EI       |                     | 2    | -      | 6      | $IE \leftarrow 1(Enable Interrupt)$                                                           |   |       |
|             | DI       |                     | 2    | _      | 6      | $IE \leftarrow 0(Disable Interrupt)$                                                          |   |       |
|             | HALT     |                     | 2    | 6      | _      | Set HALT Mode                                                                                 |   |       |
|             | STOP     |                     | 2    | 6      | _      | Set STOP Mode                                                                                 |   |       |

Notes 1. When the internal high-speed RAM area is accessed or instruction with no data access2. When an area except the internal high-speed RAM area is accessed

Remarks 1. One instruction clock cycle is one cycle of the CPU clock (fcpu) selected by the PCC register.2. This clock cycle applies to internal ROM program.

# 18.3 Instructions Listed by Addressing Type

## (1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

| 2nd Operand<br>1st Operand          | #byte                                                        | A                                                            | <sub>r</sub> Note                                                   | sfr        | saddr                                                               | !addr16                                                             | PSW | [DE]       | [HL]                                                                | [HL + byte]<br>[HL + B]<br>[HL + C]                                 |      | 1                          | None         |
|-------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|------------|---------------------------------------------------------------------|---------------------------------------------------------------------|-----|------------|---------------------------------------------------------------------|---------------------------------------------------------------------|------|----------------------------|--------------|
| A                                   | ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP        |                                                              | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |      | ROR<br>ROL<br>RORC<br>ROLC |              |
| r                                   | MOV                                                          | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | INC<br>DEC   |
| B, C                                |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     | DBNZ |                            |              |
| sfr                                 | MOV                                                          | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| saddr                               | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     | DBNZ |                            | INC<br>DEC   |
| !addr16                             |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| PSW                                 | MOV                                                          | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | PUSH<br>POP  |
| [DE]                                |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| [HL]                                |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | ROR4<br>ROL4 |
| [HL + byte]<br>[HL + B]<br>[HL + C] |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| х                                   |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | MULU         |
| С                                   |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | DIVUW        |

Note Except r = A

## (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 2nd Operand | #word                | AX       | rp <sup>Note</sup> | sfrp | saddrp | !addr16 | SP   | None                        |
|-------------|----------------------|----------|--------------------|------|--------|---------|------|-----------------------------|
| 1st Operand |                      |          |                    |      |        |         |      |                             |
| AX          | ADDW<br>SUBW<br>CMPW |          | MOVW<br>XCHW       | MOVW | MOVW   | MOVW    | MOVW |                             |
| rp          | MOVW                 | MOVWNote |                    |      |        |         |      | INCW<br>DECW<br>PUSH<br>POP |
| sfrp        | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| saddrp      | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| !addr16     |                      | MOVW     |                    |      |        |         |      |                             |
| SP          | MOVW                 | MOVW     |                    |      |        |         |      |                             |

**Note** Only when rp = BC, DE, HL

## (3) Bit manipulation instructions

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| 2nd Operand | A.bit                       | sfr.bit                     | saddr.bit                   | PSW.bit                     | [HL].bit                    | CY   | \$addr16          | None                 |
|-------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| 1st Operand |                             |                             |                             |                             |                             |      |                   |                      |
| A.bit       |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit     |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit   |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit     |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| [HL].bit    |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| СҮ          | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

### (4) Call/instructions/branch instructions

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

| 2nd Operand<br>1st Operand | AX | !addr16    | !addr11 | [addr5] | \$addr16                     |
|----------------------------|----|------------|---------|---------|------------------------------|
| Basic instruction          | BR | CALL<br>BR | CALLF   | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| Compound<br>instruction    |    |            |         |         | BT<br>BF<br>BTCLR<br>DBNZ    |

## (5) Other instructions

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

## **CHAPTER 19 ELECTRICAL SPECIFICATIONS**

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

\*

| Parameter                | Symbol    |                                      | Conditions                             |            | Ratings                                         | Unit |
|--------------------------|-----------|--------------------------------------|----------------------------------------|------------|-------------------------------------------------|------|
| Supply voltage           | Vdd       |                                      |                                        |            | -0.3 to +6.0                                    | V    |
|                          | VDDPORT   |                                      |                                        |            | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 1</sup> | V    |
|                          | VDDPLL    |                                      |                                        |            | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 1</sup> | V    |
|                          | Vpp       | μPD178F054 on                        | ly                                     |            | -0.3 to +10.5                                   | V    |
| Input voltage            | Vi        |                                      |                                        |            | -0.3 to V <sub>DD</sub> + 0.3                   | V    |
| Output voltage           | Vo        | Excluding P130                       | to P132                                |            | -0.3 to VDD + 0.3                               | V    |
| Output withstand voltage | VBDS      | P130 to P132                         | N-ch open drain                        |            | 16                                              | V    |
| Analog input voltage     | Van       | P10 to P15                           | Analog input pin                       |            | -0.3 to V <sub>DD</sub> + 0.3                   | V    |
| Output current, high     | Іон       | Per pin                              |                                        |            | -8                                              | mA   |
|                          |           | Total of P00 to F<br>P60 to P67, and | P06, P30 to P37, P54 t<br>P120 to P125 | o P57,     | -15                                             | mA   |
|                          |           | Total of P40 to F                    | P47, P50 to P53, and F                 | P70 to P77 | -15                                             | mA   |
| Output current, low      | IOLNote 2 | Per pin                              |                                        | Peak value | 16                                              | mA   |
|                          |           |                                      |                                        | rms value  | 8                                               | mA   |
|                          |           | Total of P00 to F                    | P06, P30 to P37,                       | Peak value | 30                                              | mA   |
|                          |           | P40 to P47, P50                      | ) to P57, P60 to P67,                  | rms value  | 15                                              | mA   |
|                          |           | P70 to P77, P12<br>P130 to P132      | 20 to P125, and                        |            |                                                 |      |
| Operating temperature    | TA        | In normal operat                     | tion mode                              |            | -40 to +85                                      | °C   |
|                          |           | During flash mer<br>(µPD178F054 or   | mory programming<br>nly)               |            | 10 to 40                                        |      |
| Storage temperature      | Tstg      |                                      |                                        |            | -55 to +125                                     | °C   |

Notes 1. Keep the voltage at VDDPORT and VDDPLL same as that at the VDD pin.

- **2.** The rms value should be calculated as follows: [rms value] = [Peak value]  $x \sqrt{Duty}$
- 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.

## Recommended Supply Voltage Ranges ( $T_A = -40$ to $+85^{\circ}C$ )

| Parameter                | Symbol | Conditions                               | MIN. | TYP. | MAX. | Unit |
|--------------------------|--------|------------------------------------------|------|------|------|------|
| Supply voltage           | VDD1   | When CPU and PLL are operating           | 4.5  | 5.0  | 5.5  | V    |
|                          | Vdd2   | When CPU is operating and PLL is stopped | 3.5  | 5.0  | 5.5  | V    |
| Data retention voltage   | Vddr   | When crystal oscillation stops           | 2.3  |      | 5.5  | V    |
| Output withstand voltage | VBDS   | P130 to P132 (N-ch open drain)           |      |      | 15   | V    |

| Parameter                      | Symbol | Condit                                                                                                              | ons                                                                                                  | MIN.      | TYP. | MAX.    | Unit |
|--------------------------------|--------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------|------|---------|------|
| Input voltage, high            | VIH1   |                                                                                                                     | P10 to P15, P30 to P32, P35 to P37, P40 to P47,<br>P50 to P57, P60 to P67, P71, P73, P75, P121, P124 |           |      |         | V    |
|                                | Vih2   | P00 to P06, P33, P34, P70,<br>P120, P122, P123, P125, R                                                             | 0.8 Vdd                                                                                              |           | Vdd  | V       |      |
| Input voltage, low             | VIL1   |                                                                                                                     | P10 to P15, P30 to P32, P35 to P37, P40 to P47,<br>P50 to P57, P60 to P67, P71, P73, P75, P121, P124 |           |      | 0.3 Vdd | V    |
|                                | VIL2   | P00 to P06, P33, P34, P70,<br>P120, P122, P123, P125, R                                                             |                                                                                                      | 0         |      | 0.2 Vdd | V    |
| Output voltage, high           | Vон1   | P00 to P06, P30 to P37,<br>P40 to P47, P50 to P57,                                                                  | 4.5 V ≤ V <sub>DD</sub> ≤ 5.5 V,<br>Іон = −1 mA                                                      | Vdd - 1.0 |      |         | V    |
|                                |        | P60 to P67, P70 to P77,<br>P120 to P125                                                                             | $3.5 V \le V_{DD} < 4.5 V,$<br>Іон = -100 $\mu$ А                                                    | Vdd - 0.5 |      |         | V    |
|                                | Vон2   | EO0, EO1                                                                                                            | 4.5 V ≤ V <sub>DD</sub> ≤ 5.5 V,<br>Іон = −3 mA                                                      | Vdd – 1.0 |      |         | V    |
| Output voltage, low            | Vol1   | P00 to P06, P30 to P37,<br>P40 to P47, P50 to P57,                                                                  | $4.5 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V},$<br>Iol = 1 mA                          |           |      | 1.0     | V    |
|                                |        | P60 to P67, P70 to P77,<br>P120 to P125,<br>P130 to P132                                                            | $3.5 \text{ V} \le \text{V}_{\text{DD}} < 4.5 \text{ V},$<br>IoL = 100 $\mu$ A                       |           |      | 0.5     | V    |
|                                | Vol2   | EO0, EO1                                                                                                            | V <sub>DD</sub> = 4.5 to 5.5 V,<br>Io∟ = 3 mA                                                        |           |      | 1.0     | V    |
| Input leakage<br>current, high | Ішнт   | P00 to P06, P10 to P15,<br>P30 to P37, P40 to P47,<br>P50 to P57, P60 to P67,<br>P70 to P77, P120 to P125,<br>RESET | Vin = Vdd                                                                                            |           |      | 3       | μΑ   |

# DC Characteristics (TA = -40 to +85°C, V<sub>DD</sub> = 3.5 to 5.5 V) (1/2)

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

| Parameter                      | Symbol | Condit                                                                                                              | ions                                                               | MIN. | TYP. | MAX. | Unit |
|--------------------------------|--------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------|------|------|------|
| Input leakage<br>current, low  | ILIL1  | P00 to P06, P10 to P15,<br>P30 to P37, P40 to P47,<br>P50 to P57, P60 to P67,<br>P70 to P77, P120 to P125,<br>RESET | Vin = 0 V                                                          |      |      | -3   | μΑ   |
| Output off                     | LOH1   | P130 to P132                                                                                                        | Vout = 15 V                                                        |      |      | -3   | μA   |
| leakage current                | ILOL1  | P130 to P132                                                                                                        | Vout = 0 V                                                         |      |      | 3    | μA   |
|                                | ILOH2  | EO0, EO1                                                                                                            | Vout = Vdd                                                         |      |      | -3   | μA   |
|                                | ILOL2  | EO0, EO1                                                                                                            | Vout = 0 V                                                         |      |      | 3    | μA   |
| Supply current <sup>Note</sup> | IDD1   | When CPU is operating and PLL is stopped.                                                                           | μPD178053,<br>μPD178054                                            |      | 2.5  | 15   | mA   |
|                                |        | Sine wave input to X1 pin<br>At fx = 4.5 MHz<br>VIN = VDD                                                           | μPD178F054                                                         |      | 5.0  | 18   | mA   |
|                                | IDD2   | In HALT mode with PLL stopped.                                                                                      | μPD178053,<br>μPD178054                                            |      | 0.2  | 0.8  | mA   |
|                                |        | Sine wave input to X1 pin<br>At fx = 4.5 MHz<br>VIN = VDD                                                           | μPD178F054                                                         |      | 0.3  | 0.8  | mA   |
| Data retention                 | VDDR1  | When crystal resonator is o                                                                                         | scillating                                                         | 3.5  |      | 5.5  | V    |
| voltage                        | Vddr2  | When crystal oscillation is stopped                                                                                 | Power-failure detection function                                   | 2.2  |      |      | V    |
|                                | Vddr3  |                                                                                                                     | Data memory retained                                               | 2.0  |      |      | V    |
| Data retention current         | IDDR1  | When crystal oscillation is stopped                                                                                 | $T_{A} = 25^{\circ}C,$ $V_{DD} = 5 V$                              |      | 2.0  | 4.0  | μΑ   |
|                                | Iddr2  |                                                                                                                     | $T_A = -40 \text{ to } +85^{\circ}\text{C},$<br>VDD = 3.5 to 5.5 V |      | 2.0  | 20   | μA   |

## DC Characteristics (TA = -40 to +85°C, VDD = 3.5 to 5.5 V) (2/2)

**Note** Excluding AVDD current and VDDPLL current.

Remarks 1. fx: System clock oscillation frequency

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

| Parameter      | Symbol | Conditions                                                                                                                   | MIN. | TYP. | MAX. | Unit |
|----------------|--------|------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|
| Supply current | Idd3   | When CPU and PLL are operating. Sine wave input to VCOH pin At $f_{IN} = 160 \text{ MHz}$<br>$V_{IN} = 0.15 \text{ V}_{P-P}$ |      | 5    |      | mA   |

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

#### **AC Characteristics**

# (1) Basic operation (TA = -40 to $+85^{\circ}$ C, VDD = 3.5 to 5.5 V)

| Parameter                                             | Symbol         | Conditions     | MIN. | TYP. | MAX. | Unit |
|-------------------------------------------------------|----------------|----------------|------|------|------|------|
| Cycle time<br>(minimum instruction<br>execution time) | Тсү            | fx = 4.5 MHz   | 0.44 |      | 7.11 | μs   |
| TI50, TI51 input<br>frequency                         | fti5           |                |      |      | 2    | MHz  |
| TI50, TI51 input<br>high-/low-level widths            | t⊤iH5<br>t⊤iL5 |                | 200  |      |      | ns   |
| Interrupt input<br>high-/low-level widths             | tinth<br>tintl | INTP0 to INTP4 | 1    |      |      | μs   |
| RESET pin<br>low-level width                          | trsl           |                | 10   |      |      | μs   |

## (2) Serial interface SIO3 (TA = -40 to $+85^{\circ}$ C, VDD = 3.5 to 5.5 V)

#### Symbol MIN. TYP. MAX. Unit Parameter Conditions SCK3 cycle time 800 tkCY1 ns SCK3 high/low-level width tĸнı, tксү1/2 – 50 ns **t**KL1 SI3 setup time to SCK3↑ 100 tsik1 ns SI3 hold time from $\overline{\text{SCK3}}$ 400 **t**KSI1 ns Output delay time from $\overline{\text{SCK3}}\downarrow$ to $C = 100 \text{ pF}^{\text{Note}}$ tkso1 300 ns SO3

## (a) 3-wire serial I/O mode (SCK3 ... internal clock output)

**Note** C is the load capacitance of SCK3 and SO3 output line.

## (b) 3-wire serial I/O mode (SCK3 ... external clock input)

| Parameter                                                        | Symbol        | Conditions                 | MIN. | TYP. | MAX. | Unit |
|------------------------------------------------------------------|---------------|----------------------------|------|------|------|------|
| SCK3 cycle time                                                  | tксү2         |                            | 800  |      |      | ns   |
| SCK3 high/low-level width                                        | tкн2,         |                            | 400  |      |      | ns   |
|                                                                  | tĸ∟2          |                            |      |      |      |      |
| SI3 setup time to SCK3↑                                          | tsik2         |                            | 100  |      |      | ns   |
| SI3 hold time from SCK3↑                                         | <b>t</b> KSI2 |                            | 400  |      |      | ns   |
| Output delay time from $\overline{\text{SCK3}}\downarrow$ to SO3 | tkso2         | C = 100 pF <sup>Note</sup> |      |      | 300  | ns   |
| SCK3 at rising or falling edge time                              | tr2, tr2      |                            |      |      | 1000 | ns   |

**Note** C is the load capacitance of SO3 output line.

# AC Timing Test Point (Excluding X1 Input)



**TI** Timing



## Interrupt Input Timing



**RESET** Input Timing



# Serial Transfer Timing

## 3-wire serial I/O mode:





| Parameter                   | Symbol | Conditions                     | MIN. | TYP. | MAX. | Unit |
|-----------------------------|--------|--------------------------------|------|------|------|------|
| Resolution                  |        |                                | 8    | 8    | 8    | bit  |
| Total conversion            |        | V <sub>DD</sub> = 4.5 to 5.5 V |      |      | ±1.0 | %FSR |
| error <sup>Notes 1, 2</sup> |        |                                |      |      | ±1.4 | %FSR |
| Conversion time             | tconv  |                                | 21.3 |      | 64.0 | μs   |
| Analog input voltage        | Vian   |                                | 0    |      | Vdd  | V    |

## A/D Converter Characteristics ( $T_A = -40$ to $+85^{\circ}C$ , $V_{DD} = 3.5$ to 5.5 V)

**Notes 1.** Excluding quantization error (±0.2%FSR)

2. This value is indicated as a ratio to the full-scale value (%FSR).

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

| Parameter           | Symbol | Conditions                                                              | MIN. | TYP. | MAX. | Unit |
|---------------------|--------|-------------------------------------------------------------------------|------|------|------|------|
| Operating frequency | fin1   | VCOL pin, MF mode, sine wave input, V_IN = 0.15 V_{P-P}                 | 0.5  |      | 3.0  | MHz  |
|                     | fin2   | VCOL pin, HF mode, sine wave input, $V_{IN} = 0.15 V_{P-P}$             | 10   |      | 40   | MHz  |
|                     | finз   | VCOH pin, VHF mode, sine wave input, VIN = 0.15 VP-P                    | 60   |      | 130  | MHz  |
|                     | fin4   | VCOH pin, VHF mode, sine wave input, V $_{\rm IN}$ = 0.3 V $_{\rm P-P}$ | 40   |      | 160  | MHz  |

## IFC Characteristics (T<sub>A</sub> = -40 to +85°C, V<sub>DD</sub> = 4.5 to 5.5 V)

| Parameter           | Symbol | Conditions                                                                           | MIN. | TYP. | MAX. | Unit |
|---------------------|--------|--------------------------------------------------------------------------------------|------|------|------|------|
| Operating frequency | fin5   | AMIFC pin, AMIF count mode, sine wave input, $V_{\text{IN}} = 0.15 \ V_{\text{P-P}}$ | 0.4  |      | 0.5  | MHz  |
|                     | fin6   | FMIFC pin, FMIF count mode, sine wave input, $V_{IN} = 0.15 V_{P-P}$                 | 10   |      | 11   | MHz  |
|                     | fin7   | FMIFC pin, AMIF count mode, sine wave input, $V_{IN}$ = 0.15 V <sub>P-P</sub>        | 0.4  |      | 0.5  | MHz  |

## Flash Memory Programming Characteristics (VDD = 3.5 to 5.5 V, TA = 10 to 40°C) (µPD178F054 only)

| Parameter                               | Symbol       | Conditions                                | MIN. | TYP. | MAX.    | Unit  |
|-----------------------------------------|--------------|-------------------------------------------|------|------|---------|-------|
| Write current (VDD pin) <sup>Note</sup> | IDDW         | When $V_{PP} = V_{PP1}$ , fx = 4.5 MHz    |      |      | 20      | mA    |
| Write current (VPP pin)Note             | <b>I</b> PPW | When $V_{PP} = V_{PP1}$ , fx = 4.5 MHz    |      |      | 20      | mA    |
| Delete current (VDD pin)Note            | IDDE         | When VPP = VPP1, fx = 4.5 MHz             |      |      | 20      | mA    |
| Delete current (VPP pin)Note            | PPE          | When VPP = VPP1                           |      |      | 100     | mA    |
| Unit delete time                        | ter          |                                           | 0.5  | 1    | 1       | s     |
| Total delete time                       | tera         |                                           |      |      | 20      | s     |
| Number of overwrite                     |              | Delete and write are counted as one cycle |      |      | 20      | times |
| VPP power supply voltage                | VPP0         | In normal mode                            | 0    |      | 0.2 Vdd | V     |
|                                         | Vpp1         | During flash memory programming           | 9.7  | 10.0 | 10.3    | V     |

## (1) Write/delete characteristics

Note Port current (including current flowing to internal pull-up resistors) is not included.

Remark fx: System clock oscillation frequency

#### (2) Serial write operation characteristics

| Parameter                                                          | Symbol         | Conditions       | MIN. | TYP. | MAX. | Unit |
|--------------------------------------------------------------------|----------------|------------------|------|------|------|------|
| VPP setup time                                                     | <b>t</b> psron | VPP high voltage | 1.0  |      |      | μs   |
| V <sub>PP</sub> ↑ setup time from V <sub>DD</sub> ↑                | <b>t</b> DRPSR | VPP high voltage | 1.0  |      |      | μs   |
| $\overline{\text{RESET}}\uparrow$ setup time from $V_{PP}\uparrow$ | <b>t</b> PSRRF | VPP high voltage | 1.0  |      |      | μs   |
| VPP count start time from RESET                                    | <b>t</b> RFCF  |                  | 1.0  |      |      | μs   |
| Count execution time                                               | <b>t</b> COUNT |                  |      |      | 2.0  | ms   |
| VPP counter high-level width                                       | tсн            |                  | 8.0  |      |      | μs   |
| VPP counter low-level width                                        | tc∟            |                  | 8.0  |      |      | μs   |
| VPP counter noise elimination width                                | <b>t</b> NFW   |                  |      | 40   |      | ns   |

# Flash Write Mode Setting Timing



# 80-PIN PLASTIC QFP (14x14)

\*



NOTE

Each lead centerline is located within 0.13 mm of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS                     |
|------|---------------------------------|
| A    | 17.20±0.20                      |
| В    | 14.00±0.20                      |
| С    | 14.00±0.20                      |
| D    | 17.20±0.20                      |
| F    | 0.825                           |
| G    | 0.825                           |
| Н    | 0.32±0.06                       |
| I    | 0.13                            |
| J    | 0.65 (T.P.)                     |
| K    | 1.60±0.20                       |
| L    | 0.80±0.20                       |
| М    | $0.17\substack{+0.03 \\ -0.07}$ |
| N    | 0.10                            |
| Р    | 1.40±0.10                       |
| Q    | 0.125±0.075                     |
| R    | 3° <sup>+7°</sup><br>-3°        |
| S    | 1.70 MAX.                       |
|      | P80GC-65-8BT-1                  |

## **CHAPTER 21 RECOMMENDED SOLDERING CONDITIONS**

The  $\mu$ PD178053, 178054, and 178F054 should be soldered and mounted under the following recommended conditions.

For details of the recommended soldering conditions, refer to the document **Semiconductor Device Mounting Technology Manual (C10535E)**.

For soldering methods and conditions other than those recommended below, contact an NEC sales representative.

## Table 21-1. Surface Mounting Type Soldering Conditions

 $\mu$ PD178053GC- $\times$ ××-8BT: 80-pin plastic QFP (14 × 14)  $\mu$ PD178054GC- $\times$ ××-8BT: 80-pin plastic QFP (14 × 14)  $\mu$ PD178F054GC-8BT: 80-pin plastic QFP (14 × 14)

\*

| Soldering<br>Method | Soldering Conditions                                                                                                                               | Recommended<br>Condition Symbol |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Infrared reflow     | Package peak temperature: 235°C, Time: 30 seconds max.<br>(at 210°C or higher), Count: Twice or less                                               | IR35-00-2                       |
| VPS                 | Package peak temperature: 215°C, Time: 40 seconds max.<br>(at 200°C or higher), Count: Twice or less                                               | VP15-00-2                       |
| Wave soldering      | Soldering bath temperature: 260°C or less, Time: 10 seconds max.,<br>Count: Once, Preheating temperature: 120°C max. (package surface temperature) | WS60-00-1                       |
| Partial heating     | Pin temperature: 300°C or less, Time: 3 seconds max. (per pin row)                                                                                 | -                               |

Caution Do not use different soldering methods together (except for partial heating).

## APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for the development of systems which employ the  $\mu$ PD178054 Subseries. Figure A-1 shows the configuration example of the tools.

## • Support for PC98-NX series

Unless otherwise specified, products supported by IBM PC/AT<sup>TM</sup> compatibles can be used for PC98-NX series computers. When using PC98-NX series computers, refer to the description for IBM PC/AT compatibles.

#### • Windows

\*

Unless otherwise specified, "Windows" means the following OSs.

- Windows 3.1
- Windows 95
- Windows 98
- Windows 2000
- Windows NT<sup>TM</sup> Ver. 4.0



(1) When using the in-circuit emulator IE-78K0-NS



- Notes 1. The C compiler source file is not included in the software package.
  - 2. The project manager is included in the assembler package.
    - The project manager is only used for Windows.

#### Figure A-1. Configuration of Development Tools (2/2)

#### (2) When using the in-circuit emulator IE-78001-R-A



Remark Items in broken line boxes differ according to the development environment. Refer to A.5 Debugging Tools (Hardware).

#### A.1 Software Package

| SP78K0           | This package contains various software tools for 78K/0 Series development. |
|------------------|----------------------------------------------------------------------------|
| Software package | The following tools are included.                                          |
|                  | RA78K0, CC78K0, ID78K0-NS, SM78K0, and various device files                |
|                  | Part Number: µSxxxxSP78K0                                                  |

**Remark** ×××× in the part number differs depending on the OS used.

#### $\mu S \times \times \times SP78K0$

| XXXX | Host Machine          | OS                         | Supply Medium |
|------|-----------------------|----------------------------|---------------|
| AB17 | PC-9800 series,       | Windows (Japanese version) | CD-ROM        |
| BB17 | IBM PC/AT compatibles | Windows (English version)  |               |

#### A.2 Language Processing Software

| RA78K0                                    | This assembler converts programs written in mnemonics into an object codes executable                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Assembler package                         | <ul> <li>with a microcontroller.</li> <li>Further, this assembler is provided with functions capable of automatically creating symbol tables and branch instruction optimization.</li> <li>This assembler should be used in combination with an optical device file (DF178054).</li> <li><precaution environment="" in="" pc="" ra78k0="" using="" when=""></precaution></li> <li>This assembler package is a DOS-based application. It can also be used in Windows, however, by using the Project Manager (included in assembler package) on Windows.</li> </ul> |
|                                           | Part Number: µSxxxxRA78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CC78K0<br>C compiler package              | This compiler converts programs written in C language into object codes executable with a microcontroller.         This compiler should be used in combination with an optical assembler package and device file. <precaution cc78k0="" environment="" in="" pc="" using="" when="">         This C compiler package is a DOS-based application. It can also be used in Windows, however, by using the Project Manager (included in assembler package) on Windows.</precaution>                                                                                   |
|                                           | Part Number: µSxxxxCC78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| DF178054 <sup>Note 1</sup><br>Device file | This file contains information peculiar to the device.<br>This device file should be used in combination with an optical tool (RA78K0, CC78K0, SM78K0, ID78K0-NS, and ID78K0).<br>Corresponding OS and host machine differ depending on the tool used.                                                                                                                                                                                                                                                                                                            |
|                                           | Part Number: µSxxxxDF178054                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CC78K0-LNote 2<br>C library source file   | <ul> <li>This is a source file of functions configuring the object library included in the C compiler package.</li> <li>This file is required to match the object library included in C compiler package to the user's specifications.</li> <li>It does not depend on the operating environment because it is a source file.</li> </ul>                                                                                                                                                                                                                           |
|                                           | Part Number: µSxxxxCC78K0-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Notes 1. The DF178054 can be used in common with the RA78K0, CC78K0, SM78K0, ID78K0-NS, and ID78K0.

2. CC78K0-L is not included in the software package (SP78K0).

Remark xxxx in the part number differs depending on the host machine and OS used.

#### $\mu$ S××××RA78K0

μS<u>××××</u>CC78K0

| xxxx | Host Machine                    | OS                                                                    | Supply Medium   |
|------|---------------------------------|-----------------------------------------------------------------------|-----------------|
| AB13 | PC-9800 series,                 | Windows (Japanese version)                                            | 3.5-inch 2HD FD |
| BB13 | IBM PC/AT compatibles           | Windows (English version)                                             |                 |
| AB17 |                                 | Windows (Japanese version)                                            | CD-ROM          |
| BB17 |                                 | Windows (English version)                                             |                 |
| 3P17 | HP9000 series 700 <sup>TM</sup> | HP-UX <sup>™</sup> (Rel. 10.10)                                       |                 |
| 3K17 | SPARCstation <sup>TM</sup>      | SunOS <sup>™</sup> (Rel. 4.1.1),<br>Solaris <sup>™</sup> (Rel. 2.5.1) |                 |

#### μS××××DF178054

µS<u>××××</u>CC78K0-L

| -[ | XXXX | Host Machine          | OS                         | Supply Medium   |
|----|------|-----------------------|----------------------------|-----------------|
| ſ  | AB13 | PC-9800 series,       | Windows (Japanese version) | 3.5-inch 2HD FD |
|    | BB13 | IBM PC/AT compatibles | Windows (English version)  |                 |
|    | 3P16 | HP9000 series 700     | HP-UX (Rel. 10.10)         | DAT             |
|    | 3K13 | SPARCstation          | SunOS (Rel. 4.1.1),        | 3.5-inch 2HD FD |
|    | 3K15 |                       | Solaris (Rel. 2.5.1)       | 1/4-inch CGMT   |

#### A.3 Control Software

| Project manager | This is control software designed to enable efficient user program development in the Windows environment. All operations used in development of a user program, such as starting the editor, building, and starting the debugger, can be performed from the project manager. |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <caution></caution>                                                                                                                                                                                                                                                           |
|                 | The project manager is included in the assembler package (RA78K0).                                                                                                                                                                                                            |
|                 | It can only be used in Windows.                                                                                                                                                                                                                                               |

#### A.4 Flash Memory Writing Tools

| Flashpro III<br>(Part number: FL-PR3, PG-FP3)<br>Flash programmer | Flash programmer dedicated to microcontrollers with on-chip flash memory.                                       |
|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| FA-80GC<br>Flash memory writing adapter                           | Flash memory writing adapter used connected to the Flashpro III.<br>• FA-80GC: 80-pin plastic QFP (GC-8BT type) |
| Flashpro III controller                                           | Control program that runs on a PC. This is supplied with Flashpro III.                                          |

**Remark** Flashpro III and FA-80GC are products of Naito Densei Machida Mfg. Co., Ltd. Contact: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.

#### A.5 Debugging Tools (Hardware) (1/2)

#### (1) When using the in-circuit emulator IE-78K0-NS

| IE-78K0-NS<br>In-circuit emulator      |                                                                                    | The in-circuit emulator serves to debug hardware and software when developing application systems using a 78K/0 Series product. It corresponds to integrated debugger (ID78K0-NS). This emulator should be used in combination with power supply unit, emulation probe, and interface adapter which is required to connect this emulator to the host machine. |
|----------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IE-78K0-NS-PA<br>Performance board     |                                                                                    | This board is used for extending the IE-78K0-NS functions, and is used connected to the IE-78K0-NS. With the addition of this board, the addition of a coverage function, enhancement of tracer and timer functions, and other such debugging function enhancements are possible.                                                                             |
| IE-78K0-NS-A<br>In-circuit emulate     | or                                                                                 | In-circuit emulator that combines IE-78K0-NS and IE-78K0-NS-PA                                                                                                                                                                                                                                                                                                |
| IE-70000-MC-PS<br>Power supply un      |                                                                                    | This adapter is used for supplying power from a receptacle of 100 to 240 V AC.                                                                                                                                                                                                                                                                                |
| IE-70000-98-IF-C<br>Interface adapter  |                                                                                    | This adapter is required when using the PC-9800 series computer (except notebook type) as the IE-78K0-NS host machine (C bus compatible).                                                                                                                                                                                                                     |
| IE-70000-CD-IF-A<br>PC card interface  |                                                                                    | This is PC card and interface cable required when using the notebook-type computer as the IE-78K0-NS host machine (PCMCIA socket compatible).                                                                                                                                                                                                                 |
| IE-70000-PC-IF-C<br>Interface adapter  |                                                                                    | This adapter is required when using the IBM PC compatible computers as the IE-78K0-<br>NS host machine (ISA bus compatible).                                                                                                                                                                                                                                  |
| IE-70000-PCI-IF-A<br>Interface adapter |                                                                                    | This adapter is required when using a PC with a PCI bus as the IE-78K0-NS host machine.                                                                                                                                                                                                                                                                       |
| IE-178054-NS-EM1<br>Emulation board    |                                                                                    | This board emulates the operations of the peripheral hardware peculiar to a device. It should be used in combination with an in-circuit emulator.                                                                                                                                                                                                             |
| NP-80GC<br>Emulation probe             |                                                                                    | This probe is used to connect the in-circuit emulator to the target system and is designed for 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                                              |
|                                        | EV-9200GC-80<br>Conversion socket<br>(Refer to <b>Figures</b><br><b>A-2, A-3</b> ) | This conversion socket connects the NP-80GC to the target system board designed to mount an 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                                                 |

Remarks 1. NP-80GC is a product of Naito Densei Machida Mfg. Co., Ltd.

Contact: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.

**2.** EV-9200GC-80 is sold in five-unit sets.

# A.5 Debugging Tools (Hardware) (2/2)

#### (2) When using the in-circuit emulator IE-78001-R-A

| 15 70004 D 4                                                                       |   | The in aircuit emulator ection to debug bardware and software when developing                                                                                                                                                                                                                                                           |  |
|------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| IE-78001-R-A<br>In-circuit emulator                                                |   | The in-circuit emulator serves to debug hardware and software when developing application systems using a 78K/0 Series product. It corresponds to integrated debugger (ID78K0). This emulator should be used in combination with emulation probe and interface adapter, which is required to connect this emulator to the host machine. |  |
| IE-70000-98-IF-C<br>Interface adapter                                              |   | This adapter is required when using the PC-9800 series computer (except notebook type) as the IE-78001-R-A host machine (C bus compatible).                                                                                                                                                                                             |  |
| IE-70000-PC-IF-<br>Interface adapte                                                | - | This adapter is required when using the IBM PC/AT compatible computers as the IE-78001-R-A host machine (ISA bus compatible).                                                                                                                                                                                                           |  |
| IE-70000-PCI-IF<br>Interface adapte                                                |   | This adapter is required when using a PC with a PCI bus as the IE-78001-R-A host machine.                                                                                                                                                                                                                                               |  |
| IE-78000-R-SV3<br>Interface adapter                                                |   | This is adapter and cable required when using an EWS computer as the IE-78001-R-A host machine, and is used connected to the board in the IE-78000-R-A. As Ethernet <sup>TM</sup> , 10Base-5 is supported. With the other method, a commercially available conversion adapter is necessary.                                             |  |
| IE-178054-NS-E<br>Emulation board                                                  |   | This board emulates the operations of the peripheral hardware peculiar to a device. It should be used in combination with an in-circuit emulator and emulation conversion board.                                                                                                                                                        |  |
| IE-78K0-R-EX1<br>Emulation probe<br>conversion board                               |   | This board is required when using the IE-178054-NS-EM1 on the IE-78001-R-A.                                                                                                                                                                                                                                                             |  |
| EP-78230GC-R<br>Emulation probe                                                    |   | This probe is used to connect the in-circuit emulator to the target system and is designed for 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                        |  |
| EV-9200GC-80<br>Conversion socket<br>(Refer to <b>Figures</b><br><b>A-2, A-3</b> ) |   | This conversion socket connects the EP-78230GC-R to the target system board designed to mount an 80-pin plastic QFP (GC-8BT type).                                                                                                                                                                                                      |  |

Remark EV-9200GC-80 is sold in five-unit sets.

## A.6 Debugging Tools (Software)

| SM78K0<br>System simulator                                                                                                                                                                | <ul> <li>This is a system simulator for the 78K/0S Series. The SM78K0 is Windows-based software.</li> <li>It is used to perform debugging at the C source level or assembler level while simulating the operation of the target system on a host machine.</li> <li>Use of the SM78K0 allows the execution of application logical testing and performance testing on an independent basis from hardware development, thereby providing higher development efficiency and software quality.</li> <li>The SM78K0 should be used in combination with the device file (DF178054) (sold separately).</li> <li>Part Number: μSxxxxSM78K0</li> </ul> |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ID78K0-NS<br>Integrated debugger<br>(supporting in-circuit emulators<br>IE-78K0-NS and IE-78K0-NS-A)<br>ID78K0<br>Integrated debugger<br>(supporting in-circuit emulator<br>IE-78001-R-A) | This debugger supports the in-circuit emulators for the 78K/0 Series. The ID78K0-NS and ID78K0 are Windows-based software.<br>ID78K0: Supports in-circuit emulator IE-78001-R-A.<br>ID78K0-NS: Supports in-circuit emulators IE-78K0-NS and IE-78K0-NS-A.<br>It has improved C-compatible debugging functions and can display the results of tracing with the source program using an integrating window function that associates the source program, disassemble display, and memory display with the trace result.<br>It should be used in combination with the device file (sold separately).                                             |  |

**Remark** ×××× in the part number differs depending on the host machine and OS used.

#### $\mu$ S××××SM78K0 $\mu$ S××××ID78K0-NS $\mu$ S××××ID78K0

| _ | XXXX | Host Machine          | OS                         | Supply Medium   |
|---|------|-----------------------|----------------------------|-----------------|
|   | AB13 | IBM PC/AT compatibles | Windows (Japanese version) | 3.5-inch 2HD FD |
|   | BB13 |                       | Windows (English version)  |                 |
|   | AB17 |                       | Windows (Japanese version) | CD-ROM          |
|   | BB17 |                       | Windows (English version)  |                 |

#### A.7 Embedded Software

| RX78K0<br>Real-time OS | RX78K0 is a real-time OS conforming to the $\mu$ ITRON specifications.<br>Tool (configurator) for generating nucleus of RX78K0 and plural information tables is supplied.                                         |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | Used in combination with an optional assembler package (RA78K0) and device file (DF178054). <pre></pre> <pre></pre> <pre></pre> <pre></pre> <pre></pre> <pre>Option when using RX78K0 in PC environment&gt;</pre> |
|                        | The real-time OS is a DOS-based application. It should be used in the DOS Prompt when using in Windows.                                                                                                           |
|                        | Part number: $\mu S \times \times RX78013 \cdot \Delta \Delta \Delta$                                                                                                                                             |

# Caution When purchasing the RX78K0, fill in the purchase application form in advance and sign the user agreement.

**Remark** xxxx and  $\Delta\Delta\Delta\Delta$  in the part number differ depending on the host machine and OS used.

#### $\mu S \times \times \times RX78013 - \Delta \Delta \Delta \Delta$

| ΔΔΔΔ | Product Outline        | Maximum Number for Use in Mass Production |
|------|------------------------|-------------------------------------------|
| 001  | Evaluation object      | Do not use for mass-produced product.     |
| 100K | Mass-production object | 0.1 million units                         |
| 001M |                        | 1 million units                           |
| 010M |                        | 10 million units                          |
| S01  | Source program         | Source program for mass-produced object   |

| ×××× | Host Machine          | OS                         | Supply Medium   |
|------|-----------------------|----------------------------|-----------------|
| AA13 | PC-9800 series        | Windows (Japanese version) | 3.5-inch 2HD FD |
| AB13 | IBM PC/AT compatibles | Windows (Japanese version) |                 |
| BB13 |                       | Windows (English version)  |                 |

#### A.8 System Upgrade from Former In-circuit Emulator for 78K/0 Series to IE-78001-R-A

If you already have a former in-circuit emulator for 78K/0 Series microcontrollers (IE-78000-R or IE-78000-R-A), that in-circuit emulator can operate as an equivalent to the IE-78001-R-A by replacing its internal break board with the IE-78001-R-BK.

#### Table A-1. System Upgrade Method from Former In-circuit Emulator for 78K/0 Series to IE-78001-R-A

| In-circuit Emulator Owned | In-circuit Emulator Cabinet System Upgrade Note | Board to Be Purchased |
|---------------------------|-------------------------------------------------|-----------------------|
| IE-78000-R                | Required                                        | IE-78001-R-BK         |
| IE-78000-R-A              | Not required                                    |                       |

Note For upgrading a cabinet, send user's in-circuit emulator to NEC.

Drawing for Conversion Socket (EV-9200GC-80) Package and Recommended Board Mounting Pattern



<u>н</u> ।

Figure A-2. EV-9200GC-80 Package Drawing (for Reference Only)

|      |             | EV-9200GC-80-G1E |
|------|-------------|------------------|
| ITEM | MILLIMETERS | INCHES           |
| А    | 18.0        | 0.709            |
| В    | 14.4        | 0.567            |
| С    | 14.4        | 0.567            |
| D    | 18.0        | 0.709            |
| Е    | 4-C 2.0     | 4-C 0.079        |
| F    | 0.8         | 0.031            |
| G    | 6.0         | 0.236            |
| Н    | 16.0        | 0.63             |
| I    | 18.7        | 0.736            |
| J    | 6.0         | 0.236            |
| К    | 16.0        | 0.63             |
| L    | 18.7        | 0.736            |
| М    | 8.2         | 0.323            |
| Ν    | 8.0         | 0.315            |
| 0    | 2.5         | 0.098            |
| Р    | 2.0         | 0.079            |
| Q    | 0.35        | 0.014            |
| R    | ø2.3        | ¢0.091           |
| S    | ¢1.5        | ¢0.059           |

#### EV-9200GC-80-G1E



Figure A-3. EV-9200GC-80 Recommended Board Mounting Pattern (for Reference Only)

EV-9200GC-80-P1E

| ITEM | MILLIMETERS                                | INCHES                                                             |
|------|--------------------------------------------|--------------------------------------------------------------------|
| А    | 19.7                                       | 0.776                                                              |
| В    | 15.0                                       | 0.591                                                              |
| С    | $0.65 \pm 0.02 \times 19 = 12.35 \pm 0.05$ | $0.026^{+0.001}_{-0.002} \times 0.748 {=} 0.486^{+0.003}_{-0.002}$ |
| D    | $0.65\pm0.02 \times 19=12.35\pm0.05$       | $0.026^{+0.001}_{-0.002} \times 0.748 {=} 0.486^{+0.003}_{-0.002}$ |
| Е    | 15.0                                       | 0.591                                                              |
| F    | 19.7                                       | 0.776                                                              |
| G    | 6.0±0.05                                   | $0.236\substack{+0.003\\-0.002}$                                   |
| Н    | 6.0±0.05                                   | $0.236\substack{+0.003\\-0.002}$                                   |
| I    | 0.35±0.02                                  | $0.014^{+0.001}_{-0.001}$                                          |
| J    | ¢2.36±0.03                                 | $\phi 0.093^{+0.001}_{-0.002}$                                     |
| К    | <i>\$</i> 2.3                              | ¢0.091                                                             |
| L    | ¢1.57±0.03                                 | Ø0.062 <sup>+0.001</sup>                                           |

**Caution** Dimensions of mount pad for EV-9200 and that for target device (QFP) may be different in some parts. For the recommended mount pad dimensions for QFP, refer to "SEMICONDUCTOR DEVICE MOUNTING TECHNOLOGY MANUAL" (C10535E).

#### APPENDIX B REGISTER INDEX

#### **B.1 Register Index**

8-bit compare register 50 (CR50) ... 100
8-bit compare register 51 (CR51) ... 100
8-bit compare register 52 (CR52) ... 100
8-bit compare register 53 (CR53) ... 100
8-bit timer counter 50 (TM50) ... 99
8-bit timer counter 51 (TM51) ... 99
8-bit timer counter 52 (TM52) ... 99
8-bit timer mode control register 50 (TMC50) ... 102
8-bit timer mode control register 51 (TMC51) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102

#### [A]

A/D conversion result register 3 (ADCR3) ... 132, 146A/D converter mode register 3 (ADM3) ... 133Analog input channel specification register 3 (ADS3) ... 134

[B]

BEEP clock select register 0 (BEEPCL0) ... 128

#### [C]

Clock output select register (CKS) ... 129

#### [D]

DTS system clock select register (DTSCK) ... 88

#### [E]

External interrupt falling edge enable register (EGN) ... 164 External interrupt rising edge enable register (EGP) ... 164

#### [I]

IF counter control register (IFCCR) ... 198 IF counter gate judge register (IFCJG) ... 198 IF counter mode select register (IFCMD) ... 197 IF counter register (IFCR) ... 196 Internal expansion RAM size switching register (IXS) ... 222 Interrupt mask flag register 0H (MK0H) ... 162 Interrupt mask flag register 0L (MK0L) ... 162 Interrupt request flag register 0H (IF0H) ... 161

#### [M]

Memory size switching register (IMS) ... 221

#### [0]

Oscillation stabilization time select register (OSTS) ... 124, 204

#### [P]

PLL data register (PLLR) ... 190, 191, 192 PLL data register 0 (PLLR0) ... 180 PLL data register H (PLLRH) ... 180 PLL data register L (PLLRL) ... 180 PLL data transfer register (PLLNS) ... 184 PLL mode select register (PLLMD) ... 181 PLL reference mode register (PLLRF) ... 182 PLL unlock F/F judge register (PLLUL) ... 183 POC status register (POCS) ... 218, 219 Port 0 (P0) ... 70 Port 1 (P1) ... 71 Port 3 (P3) ... 72 Port 4 (P4) ... 74 Port 5 (P5) ... 75 Port 6 (P6) ... 76 Port 7 (P7) ... 77 Port 12 (P12) ... 80 Port 13 (P13) ... 82 Port mode register 0 (PM0) ... 83 Port mode register 3 (PM3) ... 83 Port mode register 4 (PM4) ... 83 Port mode register 5 (PM5) ... 83 Port mode register 6 (PM6) ... 83 Port mode register 7 (PM7) ... 83 Port mode register 12 (PM12) ... 83 Power-fail comparison mode register 3 (PFM3) ... 135 Power-fail comparison threshold value register 3 (PFT3) ... 132, 141 Priority specification flag register 0H (PR0H) ... 163 Priority specification flag register 0L (PR0L) ... 163 Processor clock control register (PCC) ... 90 Pull-up resistor option register 4 (PU4) ... 86

#### [S]

Serial I/O shift register 30 (SIO30) ... 149 Serial I/O shift register 31 (SIO31) ... 149 Serial I/O shift register 32 (SIO32) ... 149 Serial operating mode register 30 (CSIM30) ... 150 Serial operating mode register 31 (CSIM31) ... 150 Serial operating mode register 32 (CSIM32) ... 150 Serial port select register 32 (SIO32SEL) ... 151

#### [T]

Timer clock select register 50 (TCL50) ... 101 Timer clock select register 51 (TCL51) ... 101 Timer clock select register 52 (TCL52) ... 101 Timer clock select register 53 (TCL53) ... 102

#### [W]

Watchdog timer clock select register (WDCS) ... 122 Watchdog timer mode register (WDTM) ... 123

# B.2 Register Index (Symbol)

## [A]

| <b>[A]</b><br>ADCR3:<br>ADM3:<br>ADS3:                                           | A/D conversion result register 3 132, 146<br>A/D converter mode register 3 133<br>Analog input channel specification register 3 134                                                                                                                                                                                     |
|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [ <b>B]</b><br>BEEPCL0:                                                          | BEEP clock select register 0 128                                                                                                                                                                                                                                                                                        |
| [C]<br>CKS:<br>CR50:<br>CR51:<br>CR52:<br>CR53:<br>CSIM30:<br>CSIM31:<br>CSIM32: | Clock output select register 129<br>8-bit compare register 50 100<br>8-bit compare register 51 100<br>8-bit compare register 52 100<br>8-bit compare register 53 100<br>Serial operating mode register 30 150<br>Serial operating mode register 31 150<br>Serial operating mode register 32 150                         |
| <b>[D]</b><br>DTSCK:                                                             | DTS system clock select register 88                                                                                                                                                                                                                                                                                     |
| <b>[E]</b><br>EGN:<br>EGP:                                                       | External interrupt falling edge enable register 164<br>External interrupt rising edge enable register 164                                                                                                                                                                                                               |
| [I]<br>IF0H:<br>IF0L:<br>IFCCR:<br>IFCJG:<br>IFCMD:<br>IFCR:<br>IMS:<br>IXS:     | Interrupt request flag register 0H 161<br>Interrupt request flag register 0L 161<br>IF counter control register 198<br>IF counter gate judge register 198<br>IF counter mode select register 197<br>IF counter register 196<br>Memory size switching register 221<br>Internal expansion RAM size switching register 222 |
| <b>[M]</b><br>MKOH:<br>MKOL:                                                     | Interrupt mask flag register 0H 162<br>Interrupt mask flag register 0L 162                                                                                                                                                                                                                                              |
| [ <b>0]</b><br>OSTS:                                                             | Oscillation stabilization time select register 124, 204                                                                                                                                                                                                                                                                 |
| <b>[P]</b><br>P0:<br>P1:<br>P3:                                                  | Port 0 70<br>Port 1 71<br>Port 3 72                                                                                                                                                                                                                                                                                     |

| P4:      | Port 4 74                                                 |
|----------|-----------------------------------------------------------|
| P5:      | Port 5 75                                                 |
| P6:      | Port 6 76                                                 |
| P7:      | Port 7 77                                                 |
| P12:     | Port 12 80                                                |
| P13:     | Port 13 82                                                |
| PCC:     | Processor clock control register 90                       |
| PFM3:    | Power-fail comparison mode register 3 135                 |
| PFT3:    | Power-fail comparison threshold value register 3 132, 141 |
| PLLMD:   | PLL mode select register 181                              |
| PLLNS:   | PLL data transfer register 184                            |
| PLLR:    | PLL data register 190, 191, 192                           |
| PLLR0:   | PLL data register 0 180                                   |
| PLLRF:   | PLL reference mode register 182                           |
| PLLRH:   | PLL data register H 180                                   |
| PLLRL:   | PLL data register L 180                                   |
| PLLUL:   | PLL unlock F/F judge register 183                         |
| PM0:     | Port mode register 0 83                                   |
| PM3:     | Port mode register 3 83                                   |
| PM4:     | Port mode register 4 83                                   |
| PM5:     | Port mode register 5 83                                   |
| PM6:     | Port mode register 6 83                                   |
| PM7:     | Port mode register 7 83                                   |
| PM12:    | Port mode register 12 83                                  |
| POCS:    | POC status register 218, 219                              |
| PR0H:    | Priority specification flag register 0H 163               |
| PR0L:    | Priority specification flag register 0L 163               |
| PU4:     | Pull-up resistor option register 4 86                     |
| [S]      |                                                           |
| SIO30:   | Serial I/O shift register 30 149                          |
| SIO31:   | Serial I/O shift register 31 149                          |
| SIO32:   | Serial I/O shift register 32 149                          |
| SIO32SEI | L: Serial port select register 32 151                     |
|          |                                                           |

# [T]

| Timer clock select register 50 101       |
|------------------------------------------|
| Timer clock select register 51 101       |
| Timer clock select register 52 101       |
| Timer clock select register 53 102       |
| 8-bit timer counter 50 99                |
| 8-bit timer counter 51 99                |
| 8-bit timer counter 52 99                |
| 8-bit timer counter 53 99                |
| 8-bit timer mode control register 50 102 |
| 8-bit timer mode control register 51 102 |
| 8-bit timer mode control register 52 102 |
| 8-bit timer mode control register 53 104 |
|                                          |

[W]

WDCS: Watchdog timer clock select register ... 122

WDTM: Watchdog timer mode register ... 123

#### APPENDIX C REVISION HISTORY

A history of the revisions up to this edition is shown below. "Applied to:" indicates the chapters to which the revision was applied.

| Edition | Description                                                                                                                          | Applied to:                                          |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| 2nd     | Change of $\mu$ PD178053, 178054, and 178F054 status from under development to development completed                                 | Throughout                                           |
|         | Modification of Related Documents                                                                                                    | PREFACE                                              |
|         | Modification of 1.5 Development of 8-Bit DTS Series                                                                                  | CHAPTER 1 OUTLINE                                    |
|         | Modification of bit units for manipulation for OSTS in <b>Table 3-4 Special Function</b><br><b>Registers</b>                         | CHAPTER 3<br>CPU ARCHITECTURE                        |
|         | Deletion of pins P10 to P15 from Table 4-3 Port Mode Register and Output Latch<br>Settings When Using Alternate Functions            | CHAPTER 4<br>PORT FUNCTIONS                          |
|         | Modification of description in (3) Oscillation stabilization time select register (OSTS) in 8.3 Registers Controlling Watchdog Timer | CHAPTER 8<br>WATCHDOG TIMER                          |
|         | Addition of electrical specifications                                                                                                | CHAPTER 19<br>ELECTRICAL<br>SPECIFICATIONS           |
|         | Addition of package drawing                                                                                                          | CHAPTER 20<br>PACKAGE DRAWING                        |
|         | Addition of recommended soldering conditions                                                                                         | CHAPTER 21<br>RECOMMENDED<br>SOLDERING<br>CONDITIONS |
|         | Modification of Figure A-1 Configuration of Development Tools                                                                        | APPENDIX A                                           |
|         | Addition of A.1 Software Package and A.3 Control Software                                                                            | DEVELOPMENT TOOLS                                    |
|         | Addition of Note 2 to A.2 Language Processing Software                                                                               |                                                      |
|         | Addition of description for IE-78K0-NS-A to A.5 Debugging Tools (Hardware)                                                           |                                                      |
|         | Deletion of MX78K0 from A.7 Embedded Software                                                                                        |                                                      |



# Facsimile Message

FAX

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

Address

Tel.

From:

Name

Company

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: +1-800-729-9288<br>+1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Market Communication Dept.<br>Fax: +49-211-6503-274                     | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: +82-2-528-4411         | <b>Japan</b><br>NEC Semiconductor Technical Hotline<br>Fax: +81- 44-435-9608                 |
| <b>South America</b><br>NEC do Brasil S.A.<br>Fax: +55-11-6462-6829                                                | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: +886-2-2719-5951                         |                                                                                              |

I would like to report the following error/make the following suggestion:

Document title:

Document number: \_\_\_\_\_

Page number: \_\_\_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |